Flash/Flex学习笔记(5):捕获摄像头(续)--在线抓屏并保存到客户端本地

必须有摄像头,上面的演示才能正常播放。

思路:

使用摄像头以及在线抓屏在上一节Flash/Flex学习笔记(2):捕获摄像头 里已经讲过了,就不重复粘贴了,至于在客户端保存文件,Flash里用起来也很简单:直接调用 FileReference 即可,另外为了减少图片大小,还可能借助AS3.0的扩展库(项目地址http://code.google.com/p/as3corelib/),把bmp格式的位置转换成jpeg再保存

扩展:

结合本文的方法,再配合Flash/Flex学习笔记(4):如何打开网页及Get/Post数据 ,可以很方便的做出"在线大头贴"或"在线生成会员头象"等功能 源代码:

var W:int=stage.stageWidth;//场景的原始宽度
    var H:int=stage.stageHeight;//场景的原始高度
    stage.scaleMode=StageScaleMode.NO_SCALE;//舞台禁止缩放,但是好象没效果?
    var video:Video;
    var camera:Camera=Camera.getCamera();//获取摄像头
    lblAuthor.addEventListener(MouseEvent.CLICK,function(){
    navigateToURL(new URLRequest("http://www.cnblogs.com/yjmyzz"),"_blank")
    });
    //检测摄像头
    if (camera==null) {
    trace("未检测到摄像头!");
    lbl1.text="未检测到摄像头!";
    btnCapture.visible=false;
    tilelst1.visible = false;
    lblMemo.visible = false;
    } else {
    camera.addEventListener(ActivityEvent.ACTIVITY,activityHander);
    video=new Video(camera.width,camera.height);
    trace("视频宽度:" + camera.width + ",视频高度:" + camera.height);
    video.attachCamera(camera);
    //定位到水平中心点
    video.x = (W - video.width) /2;
    video.y=10;
    addChild(video);//加载到当前舞台中
    btnCapture.x = (W - btnCapture.width) /2;
    btnCapture.y=video.y+video.height+5;
    btnCapture.addEventListener(MouseEvent.CLICK,captureImage);
    }
    //检测摄像头活动变化
    function activityHander(e:ActivityEvent):void {
    trace("activityHander:" + e);
    }
    var dp:DataProvider = new DataProvider();
    tilelst1.addEventListener(MouseEvent.CLICK,saveImage);
    //双击将截图保存到本地
    function saveImage(e:MouseEvent) {
    if (e.target.hasOwnProperty("source")) { //检查只有点击了图象,才保存
    var jpegEncoder:JPGEncoder = new JPGEncoder();
    var bitmap:Bitmap = e.target.data.source;
    var jpegArr:ByteArray=jpegEncoder.encode(bitmap.bitmapData);//压缩成jpeg
    trace(jpegArr.length);
    var file:FileReference=new FileReference();
    var fileName:String= e.target.data.label +  ".jpg";//设置文件名
    file.save(jpegArr,fileName);//保存到本地
    }
    }
    //视频截图处理
    function captureImage(e:MouseEvent):void {
    //trace("你点击了按钮");
    var bit:BitmapData=new BitmapData(video.width,video.height);
    bit.draw(video);
    var bmp:Bitmap=new Bitmap(bit);
    var d:Date = new Date();
    dp.addItem({label:"截图" + d.getFullYear() + d.getMonth() + d.getDay() + d.getHours() + d.getMinutes() + d.getSeconds() + d.getMilliseconds(),source:bmp});
    tilelst1.dataProvider=dp;
    trace(dp.length);
    tilelst1.scrollToIndex(dp.length-1);//滚动条自动拉到最后一张图片
    }
    stop();

示例源代码下载: http://cid-2959920b8267aaca.skydrive.live.com/self.aspx/Flash/GetCamera2.rar

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

发表于

我来说两句

0 条评论
登录 后参与评论

相关文章

来自专栏极客编程

最全的资源教程 转

7712
来自专栏编程

iOS一种动态栅格布局方案

前言 在日常开发过程中,我们会遇到一些需要不定期动态改变布局的页面或视图块,下面用张图展示一下: ? zdm_home.png 我以这张图解释一下需求,图上的几...

3846
来自专栏数据小魔方

条件格式小技巧——图表集!

今天跟大家分享条件格式的另一个贴心小技巧——图表集! ▽▼▽ 也许大家用的不多,不过这个小技巧之所以要跟大家分享,是因为它采用的迷你小图标的形式,非常细致的刻画...

3405
来自专栏编程

实现微信朋友圈所有动态点赞的自动化用例

本人在是呀UiAutomator的过程中,突发奇想,写一个自动给朋友圈点赞的用例,经过尝试,终于成功,效果不错。这个方法用的是for循环,也可以用while循环...

72310
来自专栏张俊红

python在租房过程中的应用

总第84篇 01|背景介绍: 租房是再普遍不过的一件事情了,我们在租房过程中常考量的两个因素是出租房离公司的远近以及价格,而我们一般都会去链家上看相应的信息,但...

4166
来自专栏章鱼的慢慢技术路

使用3ds Max制作简单卧室

9053
来自专栏Jerry的SAP技术分享

SAP成都研究院C4C光明左使:SAP Cloud for Customer 使用SAP UI5的独特之处

2017年7月,SAP成都研究院C4C开发团队刚刚建立。某个周一早晨的Scrum meeting,新出现一位眉清目秀的小伙子,向大家自我介绍:“大家好,我叫杨x...

1612
来自专栏hotqin888的专栏

基于Bootstrap垂直响应的jQuery时间轴特效

版权声明:本文为博主原创文章,未经博主允许不得转载。 https://blog.csdn.net/hotqin888/article/det...

4854
来自专栏iOS技术

iOS 布局进阶:你真的会用 autolayout 么?

iOS系统已经迎来了10.3.2版本,iOS软件开发发展至今已经相当成熟了。布局的方式从frame、size、center到如今强大的autolayout,将U...

2555
来自专栏cnblogs

vue原来可以这样上手

       今儿与一群友讨论vue相关问题让我思量极深,1.我们是否在争对性解决问题或者说是帮助别人;2.我们是否在炫耀自己的技能。以下是被戏剧化的对白: ...

2199

扫码关注云+社区

领取腾讯云代金券