zoukankan      html  css  js  c++  java
  • MUI 拍照或选取照片上传作为头像

    1.第一种方法是用H5来实现的

      HTML:

    1 <label>
    2     <input style="opacity: 0;" type="file" accept="image/*" id="head_img_change"/>
    3     <img id="headimg" src="img/erma_search_goods_detail.png">
    4 </label>

      JQ:

     1 $(function(){
     2 
     3     $("#head_img_change").change(function() {
     4       var $file = $(this);
     5       var fileObj = $file[0];
     6       var windowURL = window.URL || window.webkitURL;
     7       var dataURL;
     8       var $img = $("#headimg");
     9       if(fileObj && fileObj.files && fileObj.files[0]){
    10         dataURL = windowURL.createObjectURL(fileObj.files[0]);
    11         $img.attr('src',dataURL);
    12       }else{
    13         dataURL = $file.val();
    14         var imgObj = document.getElementById("headimg");
    15         // 1、在设置filter属性时,元素必须已经存在在DOM树中,动态创建的Node,也需要在设置属性前加入到DOM中,先设置属性再加入,无效;
    16         // 2、src属性需要像下面的方式添加,上面的两种方式添加,无效;
    17         imgObj.style.filter = "progid:DXImageTransform.Microsoft.AlphaImageLoader(sizingMethod=scale)";
    18         imgObj.filters.item("DXImageTransform.Microsoft.AlphaImageLoader").src = dataURL;
    19       }
    20     });
    21 
    22   })

      说明:1)外部加个label是为了把让用户点击的时候在范围内的都会触发input

         2)H5  input file上传图片,调用API:<input type="file" accept="image/*;capture=camera">直接调用相机
                           <input type="file" accept="image/*" />调用相机、图片或者相册

           注:部分android机只能调用本地相册,相机调用不了或者只能调用相机,不能调用相册。

         3)此方法是网上的一种方法,做了兼容的,IE6以上都能正常运行。

    2.第二种方法:MUI h5+

       不用引入mui.js或mui.min.js,直接在hbuilder这个IDE中新建移动app,然后在页面中直接调用方法就行了,当然,需要在manifest.json中先配置权限,然后真机调试才能看到效果。点击这里是拍照调用方法的文档

    function getImage(){
        var cameraObj = plus.camera.getCamera();
        cameraObj.captureImage(function(path){
            CompressImage(path)
        }, function(e){
            console.log('取消拍照');
        }, {
            filename:'_doc/pic/',
            index:1
        });
    }
    function CompressImage(path){
        plus.zip.compressImage( {
            src:path,
            dst:path,
            overwrite:true,
            quality:60,
            rotate:90
        }, function(event){
            var _src=event.target;
            mui.confirm("是否保存该图片","温馨提示",["否","是"],function(e){
                console.log(_src)
                if(e.index){
                    plus.gallery.save(_src, function(evt){
                        $(".box").append('<img src="'+evt.file+'">');
                        mui.alert('保存成功'+evt.file);
                        
                    }, function(err){
                        mui.alert('保存失败: '+JSON.stringify(err));
                        
                    });
                }
            })
    
            console.log(event.size)
        }, function(err){
            
        });
    }

     说明: 

      getImage()是点击拍照按钮之后触发的事件。CompressImage(path)是压缩图片的事件。

      拍照上传需要用到5+的api。plus.camera.getCamera()是获取到camera摄像头对象

      该对象有三个方法,其中一个是captureImage,它有三个参数,captureImage(successCB, errorCB, option)

        successCB:拍照操作成功的回调函数(必选)CameraSuccessCallback

        errorCB:拍照操作失败的回调函数(可选)CameraErrorCallback

        option:摄像头拍照参数(必选)CameraOption。

        option这个对象的属性:filename: 拍照或摄像文件保存的路径;

                   index: 拍照或摄像默认使用的摄像头,1表示主摄像头(后),2表示辅摄像头(前) 

     

      compressImage是图片压缩的方法,属于5+里的zip接口。plus.zip.compressImage( options, successCB, errorCB),它也有三个参数,具体的参数信息可查看这里

      plus.gallery.save是保存文件到本地的方法,属于5+里的gallery接口,plus.gallery.save( path, successCB, errorCB )。它也有三个参数,具体的参数信息可查看这里

     在上面的compressImage方法中,我加入了rotate:90的属性,是因为手持设备不同方向所拍摄的照片方向不同,照片的方向都会不同,但相册中会自动纠正,这一问题在ios和android中都存在。

     一般你只要竖直拍摄的照片,在页面上显示的时候就会自动旋转90度的样子。所以这里强制旋转90度,适用于大部分情况,但是如果拍摄的时候横着拍,或者180度倒着拍就不行了。
     可以考虑使用Exif.js来获取图片的拍照方向,然后设置旋转就能解决问题。

     拍照完成了,上传的话,就可以用canvas把图片编码成base64,然后在后台解码base64就行了。也可以考虑使用5+api中的uploader来上传

     这里有我自己总结的 5+ runtime 常用api,里面有详细的说明


    第三种方法是通过form表单来实现:只需两步
    第一步:html
    <form action="" method="post" enctype="multipart/form-data">
        <input type="file" onchange="uploadImg(this,'behindeImg')" class="comFileBtn"  accept="image/*"/>
    </form>
    第二步:js 
    //上传图片
    //that是该input,imgName是图片要显示的src的位置
    function uploadImg(that,imgName){
        var reads= new FileReader();
        var fileObj=that.files[0];
        var imageType = /^image//;
        //是否是图片,如果input没加accept属性,这里也可以判断
        if (!imageType.test(fileObj.type)) {
            alert("请选择图片!");
            return;
        }
        //读取完成
        reads.readAsDataURL(fileObj);
        reads.onload = function(e) {
            //图片路径设置为读取的图片
            $("#"+imgName).attr('src',e.target.result) ;
        };
    }

     这样,后台也可以通过读取表单数据来获取内容了

  • 相关阅读:
    [译] iOS 11.4.1 Beta:全新的USB限制模式
    [杂] 无人机取证的一些研究
    [杂] 将高版本iTunes备份恢复到低版本iOS设备中
    [手机取证] Apple Watch取证初探
    [手机取证] 绕过屏幕锁定启用调试模式-For Android 4.4.2
    [手机取证] “神器”IP-BOX的一些问题
    [杂] BOSE QC15维修小记
    iOS 8潜在的取证问题
    [Fraud] China UnionPay defrauded in Macau money laundering scandal
    [DFNews] Fire-Eye与Fox IT联合推出Cryptolocker解锁网站
  • 原文地址:https://www.cnblogs.com/zjjDaily/p/6073036.html
Copyright © 2011-2022 走看看