5

我有一个带有网络摄像头和图像的简单动作脚本文件。我想要做的是 - 当一个按钮被点击时,我想捕捉网络摄像头和图像的瞬间并将其呈现在浏览器上的 DIV 中。我该如何捕捉它?我猜需要使用位图数据。我想通过代码做到这一点

4

1 回答 1

6

这是我自己写来回答这个问题的。在 Chrome、FF 和 IE9 中测试。

您需要 Base64 编码器(一个在这里)和 png/jpg 编码器(例如来自 Flex 库)。

作为代码:

package
{
    import flash.display.BitmapData;
    import flash.display.Sprite;
    import flash.events.Event;
    import flash.events.MouseEvent;
    import flash.external.ExternalInterface;
    import flash.media.Camera;
    import flash.media.Video;

    [SWF(width="640", height="480", backgroundColor="#000000")]
    public class CameraToJS extends Sprite
    {
        private var camera:Camera;
        private var video:Video;

        public function CameraToJS()
        {
            addEventListener(Event.ADDED_TO_STAGE, addedToStageHandler);
            stage.addEventListener(MouseEvent.CLICK, saveSnapshot);
        }

        protected function addedToStageHandler(event:Event):void
        {
            camera = Camera.getCamera(); 
            video =  new Video();
            video.attachCamera(camera);
            addChild(video);
        }

        protected function saveSnapshot(event:MouseEvent):void
        {
            var bmData:BitmapData = new BitmapData(video.width, video.height);
            bmData.draw(video);

            var encoder:PNGEncoder = new PNGEncoder();

            ExternalInterface.call("image", Base64.encodeByteArray(encoder.encode(bmData)));
        }
    }
}

Javascript代码:

function image(data)
{
    document.getElementById("img").src = "data:image/png;base64,"+ data;
}
于 2012-05-17T11:49:52.017 回答