• HTML5轻松实现拍照上传功能[转载]


    转载 http://www.18sucai.com/article/275.htm

    传统方法如果想实现拍照功能,需要后台应用程序复杂的编写,但随着html5的发展,在HTML5规范的支持下,Web App已经实现了手机上拍照功能,完全是使用HTML5技术完成。在下面,我将为大家讲解Web App如何用手机进行拍照,显示在页面上并上传到服务器。

    首先拍照肯定是视频流,HTML5中已经可以实现获取视频流,主要使用getUserMedia()方法。

    1、 HTML5获取视频流

    HTML5 The Media Capture API提供了对摄像头的可编程访问,用户可以直接用getUserMedia获得摄像头提供的视频流。我们需要做的是添加一个HTML5的Video标签,并将从摄像头获得视频作为这个标签的输入来源(请注意目前仅Chrome和Opera支持getUserMedia)。

    XML/HTML Code复制内容到剪贴板
    <videoidvideoid=”video”autoplay=”"></video>  
    <script>  
    varvideo_element=document.getElementById(‘video’);  
    if(navigator.getUserMedia){//operashoulduseopera.getUserMedianow  
    navigator.getUserMedia(‘video’,success,error);  
    }  
    functionsuccess(stream){  
    video_element.src=stream;  
    }  
    </script>

    2、HTML5中拍照

    拍照功能,我们采用HTML5的Canvas实时捕获Video标签的内容,Video元素能作为Canvas图像的输入,这一点很棒。主要代码如下:

    JavaScript Code复制内容到剪贴板
    var canvas=document.createElement('canvas');    
    var ctx=canvas.getContext('2d');
    var cw=vw;
    var ch=vh;
    ctx.fillStyle=”#ffffff”;
    ctx.fillRect(0,0,cw,ch);
    ctx.drawImage(video_element,0,0,vvw,vvh,0,0,vw,vh);
    document.body.append(canvas);

    3、HTML5获取图片

    下面我们要从Canvas获取图片数据,其核心思路是用canvas的toDataURL将Canvas的数据转换为base64位编码的PNG图像,类似于“data:image/png;base64,xxxxx”的格式。

    JavaScript Code复制内容到剪贴板
    var imgData=canvas.toDataURL(“image/png”);  
    因为真正图像数据是base64编码逗号之后的部分,所以我们实际服务器处理的图像数据应该是这部分,我们可以用两种办法来获取。

    第一种:是在前端截取22位以后的字符串作为图像数据,例如:

    JavaScript Code复制内容到剪贴板
    var data=imgData.substr(22);  
    如果要在上传前获取图片的大小,可以使用:

    JavaScript Code复制内容到剪贴板
    var length=atob(data).length;//atobdecodesastringofdatawhichhasbeenencodedusingbase-64encoding  
    第二种:是在后端获取传输的数据后用后台语言截取22位以后的字符串。例如PHP里:

    JavaScript Code复制内容到剪贴板
    $image=base64_decode(str_replace(‘data:image/jpeg;base64,’,”,$data);

    4、HTML5上传图片

    在前端可以使用Ajax将上面获得的图片数据上传到后台脚本。例如使用jQuery时:

    JavaScript Code复制内容到剪贴板
    $.post(‘upload.php’,{‘data’:data});  
     在后台我们用PHP脚本接收数据并存储为图片。

    JavaScript Code复制内容到剪贴板
    functionconvert_data($data){  
    $image=base64_decode(str_replace(‘data:image/jpeg;base64,’,”,$data); 
    save_to_file($image);  
    }  
    functionsave_to_file($image){  
    $fp=fopen($filename,’w');  
    fwrite($fp,$image);  
    fclose($fp);  
    }  
       
    请注意,以上的解决方案不仅用于Web App拍照上传,而且你可以实现把Canvas的输出转换为图片上传的功能。这样你可以使用Canvas为用户提供图片编辑,例如裁剪、上色、涂鸦的画板功能,然后把用户编辑完的图片保存到服务器上。

  • 相关阅读:
    java接口
    java抽象类的特点
    java中的继承
    java中的exception模块
    java中的抽象类abstract
    java多态的案例
    iPhone开发重构:固化条件判断【转】
    服务器负载分析及问题排查
    tidb数据库
    TIDB数据库下载
  • 原文地址:https://www.cnblogs.com/lydialee/p/4340281.html
Copyright © 2020-2023  润新知