勉強したことのメモ

Webエンジニア / プログラマが勉強したことのメモ。

FlashとjQueryを組み合わせたプラグインでWebカメラで撮影した画像をアップロード

   2024/01/13  jQuery

FlashとjQueryを組み合わせたプラグインを用いてWebカメラで撮影した画像をフォーム等でアップロードする方法のメモ。jQuery webcam pluginというのがswfも同梱されてて非常に便利だった。

 

jQuery webcam plugin

http://www.xarg.org/project/jquery-webcam-plugin/

 

使い方

撮影ページ

<?php
$id = md5(uniqid(rand(), true));
?>
<!DOCTYPE html>
<html>
<head>

</head>
<body>
<div id="jquery_camera"></div>
<button id="btn">キャプチャ</button>
</div>
<?php if($_GET['id']){ ?>
<img src="<?php echo $_GET['id']?>.jpg">
<?php } ?>
<script type="text/javascript" src="https://ajax.googleapis.com/ajax/libs/jquery/1.9.1/jquery.min.js"></script>
<script type="text/javascript" src="./jquery.webcam.min.js"></script>
<script type="text/javascript">
$(function(){
    var width = 320;
    var height = 240;
    $("#jquery_camera").webcam({
        width: width,
        height: height,
        mode: "save",
        swffile: "./jscam.swf",
        onTick: function() {},
        onSave : function () {
            window.location = "./index.php?id=<?php echo $id;?>";
        },
        // Capture時に呼び出される
        onCapture: function() {
            webcam.save('./upload.php?id=<?php echo $id;?>');
        },
        debug: function() {},
        onLoad: function() {
            $("#btn").click(function(){
                webcam.capture();
            });
        }
    });
})
</script>

</body>
</html>

保存ページ

<?php
$name = $_REQUEST['id'];
$str = file_get_contents("php://input");
file_put_contents("/hoge/webcam/{$name}.jpg", pack("H*", $str));
?>

 

その他

これならIEでも撮影できる。ただスマホだとflash使えない場合が多いので、他の方法も探しておいたほうが良さそう。

 - jQuery

  関連記事

jQueryにて何らかの処理中にブラウザをロックする「waitMe」プラグインの利用方法

jQueryにて何らかの処理中、ユーザーによるクリックや入力等の動作を防ぎたい。 ...

jQuery UIを使って簡単にダイアログを表示させる方法

ブラウザ上でユーザーに対してちょっとした確認を行いたい場合はJavaScript ...

jQuery.uploadでリアルタイムプレビュー

やりたい事は、 ・<input type="file">で画像を選択 ...

「slick」で作成したスライダー画像にランキングの順位を表示する方法

「slick」で作成したスライダー画像に対して、ランキングの順位を表示したいとい ...

jQueryのトースト(通知)用ライブラリ「iziToast.js」の利用方法

システム構築の際、エラー表示をJavaScriptのアラートではなくトースト(通 ...