Flash/Flex学习笔记(11):如何检测摄像头是否被占用
时间:2022-04-23
本文章向大家介绍Flash/Flex学习笔记(11):如何检测摄像头是否被占用,主要内容包括其使用实例、应用技巧、基本知识点总结和需要注意事项,具有一定的参考价值,需要的朋友可以参考一下。
原理:摄像头激活后,持续检测与之关联的Video对象是否在播放(即每秒帧数)
btnCheck.addEventListener(MouseEvent.CLICK,btnCheckClick);
var cam:Camera;
var video:Video;
var intervalId:uint;
var intelvalTimes:uint=0;
function btnCheckClick(e:MouseEvent) {
cam=Camera.getCamera();
if (cam==null) {
lblResult.text="未安装摄像头!";
return;
}
cam.addEventListener(StatusEvent.STATUS, statusHandler);
cam.addEventListener(ActivityEvent.ACTIVITY,camActivityHandler);
video=new Video(cam.width,cam.height);
//trace("视频宽度:" + cam.width + ",视频高度:" + cam.height);
video.x=10;
video.y=40;
video.attachCamera(cam);//执行这句时,flash才会弹出摄像头是否允许使用提示框
}
//摄像头有活动时,被触发
function camActivityHandler(e:ActivityEvent) {
trace(e);
intervalId=setInterval(checkCallBack,100);
}
function checkCallBack():void {
intelvalTimes+=1;
trace(intelvalTimes);
if (cam.currentFPS>0) {
lblResult.text="摄像头工作正常!";
clearInterval(intervalId);
addChild(video);//加载到当前舞台中
} else {
if (intelvalTimes>=20) {//持续检测2秒,仍然无图象的话,认为"设备无法使用(占用中)"
lblResult.text="设备无法使用(有可能被占用)";
clearInterval(intervalId);
}
}
}
//用户选择"同意"或"不允许"使用摄像头时触发
function statusHandler(e:StatusEvent) {
trace(e);
if (e.code=="Camera.Muted") {
lblResult.text="您不允许使用摄像头!";
} else if (e.code == "Camera.Unmuted") {
lblResult.text="摄像头视频获取中...";
}
}
- HDU 5144 NPY and shot(物理运动学+三分查找)
- 深度|Python股票数据分析
- HDU 2438 Turn the corner(三分查找)
- UVAlive 3708 Graveyard(最优化问题)
- HDU 1754 I Hate It(线段树之单点更新,区间最值)
- Selenium2+python自动化19-单选和复选框
- Uva 11300 Spreading the Wealth(递推,中位数)
- Uva 11729 Commando War (简单贪心)
- UVA 11292 Dragon of Loowater(简单贪心)
- Codeforces Beta Round #2 A,B,C
- 牛顿迭代法(Newton's Method)
- 最长递减子序列(nlogn)(个人模版)
- Selenium2+python自动化26-js处理内嵌div滚动条
- Selenium2+python自动化25-js处理日历控件
- JavaScript 教程
- JavaScript 编辑工具
- JavaScript 与HTML
- JavaScript 与Java
- JavaScript 数据结构
- JavaScript 基本数据类型
- JavaScript 特殊数据类型
- JavaScript 运算符
- JavaScript typeof 运算符
- JavaScript 表达式
- JavaScript 类型转换
- JavaScript 基本语法
- JavaScript 注释
- Javascript 基本处理流程
- Javascript 选择结构
- Javascript if 语句
- Javascript if 语句的嵌套
- Javascript switch 语句
- Javascript 循环结构
- Javascript 循环结构实例
- Javascript 跳转语句
- Javascript 控制语句总结
- Javascript 函数介绍
- Javascript 函数的定义
- Javascript 函数调用
- Javascript 几种特殊的函数
- JavaScript 内置函数简介
- Javascript eval() 函数
- Javascript isFinite() 函数
- Javascript isNaN() 函数
- parseInt() 与 parseFloat()
- escape() 与 unescape()
- Javascript 字符串介绍
- Javascript length属性
- javascript 字符串函数
- Javascript 日期对象简介
- Javascript 日期对象用途
- Date 对象属性和方法
- Javascript 数组是什么
- Javascript 创建数组
- Javascript 数组赋值与取值
- Javascript 数组属性和方法
- LeetCode25|二叉树的镜像
- 生成接口测试报告
- LeetCode24|第一个只出现一次的字符
- LeetCode27|最长公共前缀
- 搭建简易的物联网服务端和客户端-蓝牙控制(十六)
- java基础|CollectionUtils工具的基本使用
- LeetCode36|二叉树的右视图
- LeetCode35|完全二叉树的节点个数
- LeetCode34|数组中的第k个最大元素
- LeetCode33|寻找重复数
- LeetCode32|前k个高频元素
- LeetCode31|打印从1到最大的n位数
- LeetCode30|翻转单词顺序
- LeetCode28|最后一个单词的长度
- VS2015创建UWP报“vstemplate文件引用的向导类”错误