利用html5调用本地摄像头拍照上传图片

 

html5概念啥的就不废话了,不知道的 百度, 谷歌一堆。。今天学了学html5中的Canvas结合新增的<video>标签来获取本地摄像头,在html5之前,要在浏览器获取本地摄像头只有通过插件(ActiveX,但是这种只有IE支持)或者是flash来获取(或许你没学过flash那就很坑爹了),在之后微软的silvertlight中也可以获取,但这些都比较麻烦,在html5的世界里,要获取本地摄像头,只要配合js就可以轻松获取。。

目前支持html5的浏览器(参考http://www.cnblogs.com/jerry_cong/archive/2011/05/15/2047143.html

先看看效果。。。(个人测试:使用谷歌Chrome 23.0.1271.97)

看看主要代码吧:

这个是前台HTML的代码。

1
2
3
4
5
<div id="contentHolder">   
    <video id="video" width="320" height="320" autoplay></video>   
    <button id="snap" style="display:none"> 拍照</button>   
    <canvas style="display:none" id="canvas" width="320" height="320"></canvas>   
</div>

下面这个是主要代码了。(jquery)

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
<script>   
   //判断浏览器是否支持HTML5 Canvas   
       window.onload = function () {   
           try {   
               //动态创建一个canvas元素,并获取他2Dcontext。如果出现异常则表示不支持   
               document.createElement("canvas").getContext("2d");   
               document.getElementById("support").innerHTML = "浏览器支持HTML5 CANVAS";   
           }   
           catch (e) {   
               document.getElementById("support").innerHTML = "浏览器不支持HTML5 CANVAS";   
           }   
          
       };   
          
       //这段代码主要是获取摄像头的视频流并显示在Video标签中   
       window.addEventListener("DOMContentLoaded"function () {   
           var canvas = document.getElementById("canvas"),   
               context = canvas.getContext("2d"),   
               video = document.getElementById("video"),   
               videoObj = { "video"true },   
               errBack = function (error) {   
                   console.log("Video capture error: ", error.code);   
               };   
               //navigator.getUserMedia这个写法在Opera中好像是navigator.getUserMedianow   
           if (navigator.getUserMedia) {   
               navigator.getUserMedia(videoObj, function (stream) {   
                   video.src = stream;   
                   video.play();   
               }, errBack);   
           else if (navigator.webkitGetUserMedia) {   
               navigator.webkitGetUserMedia(videoObj, function (stream) {   
                   video.src = window.webkitURL.createObjectURL(stream);   
                   video.play();   
               }, errBack);   
           }   
           //这个是拍照按钮的事件,   
           $("#snap").click(function () {   
               context.drawImage(video, 0, 0, 320, 320);   
               //CatchCode();   
           });   
          
       }, false);   
          
       //定时器   
       var interval = setInterval(CatchCode, "300");   
          
          
       //这个是无刷新上传图像的   
       function CatchCode() {   
           $("#snap").click();//实际运用可不写,测试代码,因为单击拍照按钮就获取了当前图像,有其他用途   
           var canvans = document.getElementById("canvas"); //获取浏览器页面的画布对象              
           //以下开始编码数据   
                      
           var imgData = canvans.toDataURL(); //将图像转换为base64数据   
           var base64Data = imgData.substr(22); //在前端截取22位之后的字符串作为图像数据   
                    
           //开始异步上传   
           $.post("uploadImgCode.ashx", { "img": base64Data }, function (data, status) {   
               if (status == "success") {   
                   if (data == "OK") {   
                       alert("二维码已经解析");   
                   }   
                   else {   
                       // alert(data);   
                   }   
               }   
               else {   
                   alert("数据上传失败");   
               }   
           }, "text");   
          
       }   
   </script>

最后的就是接收经过base64编码之后的图像文件了。

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
public void ProcessRequest (HttpContext context) {   
      string img;//接收经过base64编码之后的字符串   
      context.Response.ContentType = "text/plain";   
      try
      {   
          img =context.Request["img"].ToString();//获取base64字符串   
          byte[] imgBytes = Convert.FromBase64String(img);//将base64字符串转换为字节数组   
          System.IO.Stream stream = new System.IO.MemoryStream(imgBytes);//将字节数组转换为字节流   
          //将流转回Image,用于将PNG格式照片转为jpg,压缩体积以便保存。   
          System.Drawing.Image imgae = System.Drawing.Image.FromStream(stream);   
          imgae.Save(context.Server.MapPath("~/Test/") + Guid.NewGuid().ToString()+".jpg", System.Drawing.Imaging.ImageFormat.Jpeg);//保存图片   
          context.Response.Write("OK");//输出调用结果   
         
      }   
      catch (Exception msg)   
      {   
          img = null;   
          context.Response.Write(msg);   
          return;   
         
      }   
             
  }

至此B/S通过本地摄像头拍照上传就完成了。HTML5的强大之处,爱不释手了。。。不在像以前需要写一堆烦人的东东了,而且你也可以不用去学flash...

额外说一句,如果您还在用IE6\IE7那您还是别玩html5了...

利用html5调用本地摄像头拍照上传图片[转]的更多相关文章

  1. 利用html5调用本地摄像头拍照上传图片

    这个是前台HTML的代码. <div id="contentHolder"> <video id="video" width="32 ...

  2. 怎样让HTML5调用手机摄像头拍照——实践就是一切

    原文:怎样让HTML5调用手机摄像头拍照--实践就是一切 NanShan 小编将思路提供给了大家.学编程最重要的是实践,我这尽管有完好的代码,可是希望大家都能够自己写出属于自己的代码 HTML5 Th ...

  3. 调用本地摄像头拍照(H5和画布)

    关于H5 和 画布 调用本地摄像头拍照功能的实现 1.代码的实现(html部分) <input type="button" title="开启摄像头" v ...

  4. HTML5调用本地摄像头画面,拍照,上传服务器

    实现功能和适用业务 采集本地摄像头获取摄像头画面,拍照保存,上传服务器: 前端上传图片处理,展示,缩小,裁剪,上传服务器 实现步骤 调取本地摄像头(getUserMedia)/上传图片,将图片/视频显 ...

  5. getUserMedia API及HTML5 调用手机摄像头拍照

    getUserMedia API简介 HTML5的getUserMedia API为用户提供访问硬件设备媒体(摄像头.视频.音频.地理位置等)的接口,基于该接口,开发者可以在不依赖任何浏览器插件的条件 ...

  6. html5调用手机摄像头,实现拍照上传功能

    今天做手机网站,想实现手机扫描二维码功能.首先实现在浏览器中调用手机摄像头,实现拍照功能并且把拍下的照片显示在页面并上传到服务器上,然后再在服务器端进行分析. 首先实现在浏览器中调用摄像头,当然用现在 ...

  7. H5混合开发二维码扫描以及调用本地摄像头

    今天主管给了我个需求,说要用混合开发,用H5调用本地摄像头进行扫描二维码,我之前有做过原生安卓的二维码扫一扫,主要是通过调用zxing插件进行操作的,其中还弄了个闪光灯.但是纯H5的没接触过,心里没底 ...

  8. HTML5调用手机摄像头,仅仅支持OPPOHD浏览器

    <!doctype html> <html lang="en"> <head> <meta charset="UTF-8&quo ...

  9. 调用本地摄像头并通过canvas拍照

    首先我们需要新建一个video标签,并且放到html里边 var video = document.createElement("video"); video.autoplay=& ...

随机推荐

  1. django基础入门

    1. http协议 1.1 请求协议 请求协议格式: 请求首行: // 请求方式 请求路径 协议和版本,例如:GET /index.html HTTP/1.1 请求头信息: // 请求头名称:请求头内 ...

  2. 【8.30校内测试】【找规律模拟】【DP】【二分+贪心】

    对于和规律或者数学有关的题真的束手无策啊QAQ 首先发现两个性质: 1.不管中间怎么碰撞,所有蚂蚁的相对位置不会改变,即后面的蚂蚁不会超过前面的蚂蚁或者落后更后面的蚂蚁. 2.因为所有蚂蚁速度一样,不 ...

  3. [转] Eclipse的Tomcat插件安装

      Eclipse的Tomcat服务器插件tomcatPlugin是由Sysdeo公司开发的,其下载地址是:http://www.eclipsetotale.com/tomcatPlugin.html ...

  4. bzoj 4001 [TJOI2015]概率论 数学

    4010: [HNOI2015]菜肴制作 Time Limit: 20 Sec  Memory Limit: 256 MB 题目连接 http://www.lydsy.com/JudgeOnline/ ...

  5. 最新iOS砸壳方式Frida (Mac OSX)

    1. 安装Frida 首先需要安装Python3,我下载的是 macOS 64-bit installer 安装,因Macbook本机自带python为2.7.x,故需要配置~/.bash_profi ...

  6. 装饰者模式:轻松记住IO类的关系与API

    开门见山 目录 概述与模型 1.概述 含义:动态地将责任附加到对象上.若要拓展功能,装饰者提供了比继承更有弹性的替代方案. 初衷:需要动态为某一个类拓展.通常我们会使用继承,但是继承的话,会产生很多子 ...

  7. OC利用正则表达式获取网络资源(网络爬虫)

    在开发项目的过程,很多情况下我们需要利用互联网上的一些数据,在这种情况下,我们可能要写一个爬虫来爬我们所需要的数据.一般情况下都是利用正则表达式来匹配Html,获取我们所需要的数据.一般情况下分以下三 ...

  8. Mysql5.7全新的root密码规则

    http://blog.csdn.net/erlib/article/details/48003681

  9. shell 编译和执行java文件

    编译java程序 javac test.java 执行java程序 java test 附件test.java class test{         public static void main( ...

  10. [Js插件]使用JqueryUI的弹出框做一个“炫”的登录页面

    引言 查看项目代码的时候,发现项目中用到JqueryUi的弹出框,可拖拽,可设置模式对话框,就想着使用它弄一个登录页面. 弹出框 在Jquery Ui官网可定制下载弹出框,下载和弹出框下载相关的js文 ...