使用HTML5技术控制电脑或手机上的摄像头

 移动设备和桌面电脑上的客户端API起初并不是同步的。最初总是移动设备上先拥有某些功能和相应的API,但慢慢的,这些API会出现在桌面电脑上。其中一个应用接口技术就是getUserMedia API,它能让应用开发者访问用户的摄像头或内置相机。下面就展示一下如何通过浏览器来访问你的摄像头,并提取截屏图形。

  下面的代码里写了一部分注释,请阅读:

1.  <!-- 

2.      理想情况下我们应该先判断你的设备上是否 

3.      有摄像头或相机,但简单起见,我们在这里直接 

4.      写出了HTML标记,而不是用JavaScript先判断 

5.      然后动态生成这些标记 

6.  --> 

7.  <video id="video" width="640" height="480" autoplay></video> 

8.  <button id="snap">Snap Photo</button> 

9.  <canvas id="canvas" width="640" height="480"></canvas> 


在写出上面这些标记前应该判断用户的客户端是否有摄像头支持,但这里为了不那么麻烦,这里直接写出了这些HTML标记,需要注意的是我们这里使用的长宽是640×480。

  JavaScript代码

  因为是手工写出的HTML,所以下面的js代码会比你想象的要简单了很多。

1.  // Put event listeners into place 

2.   

3.  window.addEventListener("DOMContentLoaded", function() { 

4.   

5.  // Grab elements, create settings, etc. 

6.   

7.  var canvas = document.getElementById("canvas"), 

8.   

9.  context = canvas.getContext("2d"), 

10.  

11. video = document.getElementById("video"), 

12.  

13. videoObj = { "video": true }, 

14.  

15. errBack = function(error) { 

16.  

17. console.log("Video capture error: ", error.code); 

18.  

19. }; 

20.  

21. // Put video listeners into place 

22.  

23. if(navigator.getUserMedia) { // Standard 

24.  

25. navigator.getUserMedia(videoObj, function(stream) { 

26.  

27. video.src = stream; 

28.  

29. video.play(); 

30.  

31. }, errBack); 

32.  

33. } else if(navigator.webkitGetUserMedia) { // WebKit-prefixed 

34.  

35. navigator.webkitGetUserMedia(videoObj, function(stream){ 

36.  

37. video.src = window.webkitURL.createObjectURL(stream); 

38.  

39. video.play(); 

40.  

41. }, errBack); 

42.  

43. } 

44.  

45. else if(navigator.mozGetUserMedia) { // Firefox-prefixed 

46.  

47. navigator.mozGetUserMedia(videoObj, function(stream){ 

48.  

49. video.src = window.URL.createObjectURL(stream); 

50.  

51. video.play(); 

52.  

53. }, errBack); 

54.  

55. } 

56.  

57. }, false); 

  一旦判断出用户浏览器支持getUserMedia,下面就非常简单了,只需要将那个video元素的src设置为用户的摄像头视频直播连接。这就是用浏览器访问摄像头需要做的所有的事情!

  拍照的功能只能说是稍微复杂一点点。我们在按钮上加入一个监听器,将视频画面画到画布上。

1.  // 触发拍照动作 

2.   

3.  document.getElementById("snap") 

4.   

5.  .addEventListener("click", function() { 

6.   

7.  context.drawImage(video, 0, 0, 640, 480); 

8.   

9.  }); 

 

  以前我们需要使用第三方的插件才能从浏览器里访问用户的摄像头,这不免有些复杂。现在只需要HTML5的画布技术和javaScript,我们就能简单快速的操作用户的摄像头。不仅仅还是访问摄像头,而且是因为HTML5的画布技术及其强大,我们可以给图片上加入各种迷人的滤镜效果。


更多专业前端知识,请上 【猿2048】www.mk2048.com

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/363194.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

好的,每个接触Java字节码的人

Oracle诉Google一案认为&#xff0c;复制Java API的结构&#xff0c;序列和组织是侵犯版权的行为。 侵犯版权不仅是复制行为&#xff0c;而且还适用于拥有该作品副本的所有中间方。 那就是编写/编译任何JVM语言的人&#xff0c;以及在他们拥有的任何设备上都有JAR文件的人&…

手动安装boost库

手动安装boost库。 1,下载boost库&#xff0c;解压到目录。我解压的目录为D:\thirdParty。2&#xff0c;build bjam工具。 转到 D:\thirdParty\boost_1_37_0\tools\jam\src目录&#xff0c;执行build.bat即可生成bin.ntx86目录&#xff0c;里面有个bjam.exe&#xff0c;以后bui…

iSlide——图标库、图示库的用法

iSlide中&#xff0c;有一个“图示库”功能&#xff0c;主要功能是同时排列多块文字或多张图片。单击插图库&#xff0c;会弹出一个新的对话框。从中&#xff0c;可以选择权限、分类、数量数据和样式&#xff0c;也可以直接搜索。 下面就举一个例子&#xff1a;我要开一个班队会…

NSMutableDictionary中 setValue和setObject的区别

对于- (void)setValue:(id)value forKey:(NSString *)key;函数 官方解释如下 Send -setObject:forKey: to the receiver, unless the value is nil, in which case send -removeObject:forKey: 这就很明确的说明了setValue&#xff1a;forKey&#xff1a;中value能够为nil&…

IFrame标签的两个用法介绍

1. 作为弹出层铺底覆盖 大家如果做过那种黑色遮罩盖住整张页面&#xff0c;而碰巧用户用的是IE6&#xff0c;更碰巧的是页面上有select元素&#xff0c;那就有得头疼了&#xff08;原理就不在这里赘述了&#xff09;。我们会发现弹出的DIV没法遮住select, 轮到我们的iframe出场…

[C++ rudiment][转]typedef 使用

typedef似乎很简单&#xff0c;如typedef int integer&#xff1b;然而&#xff0c;这些简单的typedef语句容易让人产生一种误解&#xff0c;typedef就是一种宏替换,把后面的自定义类型替换成前面的已知类型&#xff0c;事实是这样的吗?显然不是&#xff01;首先可以肯定的是&…

预留空间过大的OutOfMemoryError

在分配一个应该很适合我为JVM提供的堆中的数据结构时&#xff0c;为什么会出现OutOfMemoryError&#xff1f; 这是我最近遇到的一个问题。 确实&#xff0c;当查看开发人员要完成的工作并通过-Xmx参数对提供给JVM的堆大小进行三重检查时&#xff0c;似乎确实存在着一些可疑之处…

查看系统剩余空间

1.剩余空间&#xff1a;df -h 2.追踪最耗费硬盘的文件位置 cd /du -h --max-depth1 | sort -rn 转载于:https://www.cnblogs.com/xiaobiaomei/p/10669159.html

【转】理解POCO

理解POCO(Plain Old CLR Object)先要理解POJO。 1、什么是POJO? POJO的名称有多种&#xff0c;pure old java object 、plain ordinary java object 等。  按照Martin Fowler的解释是“Plain Old Java Object”&#xff0c;从字面上翻译为“纯洁老式的java对象”&#xff0c…

『ExtJS』01 001. ExtJS 4 类的定义

ExtJS 4 类的定义类的定义与类方法的调用 样例代码// Define new class Vehicle under the Cookbook namespaceExt.define(Cookbook.Vehicle, {// class configuration goes hereManufacturer : Aston Martin,Model : Vanquish,getDetails : function() {alert(I am an this…

HashMap底层实现原理及面试问题

①HashMap的工作原理 HashMap基于hashing原理&#xff0c;我们通过put()和get()方法储存和获取对象。当我们将键值对传递给put()方法时&#xff0c;它调用键对象的hashCode()方法来计算hashcode&#xff0c;让后找到bucket位置来储存值对象。当获取对象时&#xff0c;通过键对象…

Neo4j 2.1:传递节点ID与UNWIND

在发布Neo4j 2.1时&#xff0c;我们将具有UNWIND子句&#xff0c;该子句使处理事物集合更加容易。 在我的有关创建邻接矩阵的博客文章中&#xff0c;我们想要显示按字母顺序排列的前5个见面组中有多少人&#xff0c;然后检查其他各组中有多少人。 没有UNWIND子句&#xff0c;…

使用C#調用外部程式或是執行DOS命令

在.NET裡要如何調用外部程式呢?? 在.net裡&#xff0c;提供了Process類&#xff0c;提供我們強大的調用外部工具功能&#xff0c;並透過重新導向輸入與輸出&#xff0c;可以取得執行結果&#xff0c;下面就用一個例子來示範在一個WinForm裡輸入一個Dos命令&#xff0c;然後呼…

flex 学习篇 ---- 导航类容器

导航类容器需要使用<mx:ViewStack />。可以直接从ui设计器中拉控件过去舞台或者手动敲代码。 导航类容器就是相当于创建了一个菜单&#xff0c;然后按每个选项都可以进入到不同的页面。 创建了<mx:ViewStack>之后需要为它指定id号。 <mx:ViewStack id"vi…

SQLiteOpenHelper+ContentProvider的使用

效果图&#xff1a; PetDbHelper package com.example.admin.pets;import android.content.Context;import android.database.sqlite.SQLiteDatabase;import android.database.sqlite.SQLiteOpenHelper;import com.example.admin.pets.PetContract.PetEntry;public class PetDb…

[Mac入门] 如果更快的打开程序或文件

今天有位网友问我在Windows下可以用CtrlR快速打开程序/文件夹等&#xff0c;在Mac下有没有相类似的功能&#xff1f;本文将介绍一些我的一般做法。 1.Windows下的CtrlR是什么&#xff1f; 我打算从解释CtrlR开始说起&#xff0c;希望朋友们别嫌烦&#xff5e;。Windows下系统全…

Install Shield制作安装包技巧(SQL篇)

1、检查SQL Server是否安装prototype CheckSQL(); function CheckSQL()BOOL bSuccess;NUMBER nType, nvSize;STRING szVer; STRING szSetupVer, szSetupPath;beginRegDBSetDefaultRoot ( HKEY_LOCAL_MACHINE );szSetupPath "SOFTWARE\\Microsoft\\MSSQLServer\\Setup&quo…

ActiveMQ –经纪人网络解释–第4部分

在前面的第3部分中 &#xff0c;我们已经看到ActiveMQ如何帮助将远程使用者与本地使用者区分开来&#xff0c;这有助于确定从消息生产者到使用者的较短路径。 在第4部分中&#xff0c;我们将研究如何在远程代理上负载均衡并发使用者。 让我们考虑一些高级配置&#xff0c;以平…

总结CSS3新特性(选择器篇)

CSS3新增了嗯- -21个选择器,脚本通过控制台在这里运行; ~: p ~ p {color : red;/*此条规则将用于p后边所有的p...就是除了第一个p的所有p,规则同p:not(:nth-of-type(1)),但是权重要低于后者*/} [attribute^value]: 选择该属性以特定值开头的元素 [attribute$value]: 选择该属…

js获取地址栏信息

设置或获取对象指定的文件名或路径。 window.location.pathname例&#xff1a;http://localhost:8086/topic/index?topicId361alert(window.location.pathname); 则输出&#xff1a;/topic/index设置或获取整个 URL 为字符串。window.location.href例&#xff1a;http://local…