H5移动端调用相机或相册

一: 前提

    在做H5时,有时要实现拍照功能,这就要调取手机端的相机,当时,在网上搜了很多能实现的方式,最后还是用html5自带的 input标签,实现移动端调用手机摄像头。好了,话不多说,下面就是我实现的代码:

二:实现

(一):调用手机相机或相册

      <!--图片二-->
        <label for="xFile2" style="padding-top:15px;" class=" cameraImg2" @click="removeImg2();">
          <span v-if="imgList2.length == ''" class="glyphicon-camera" >
            <p style="line-height:5px;">
             <label>图片二</label>
            <!--调取相机-->
             <input type="file" id="xFile2" capture="camera" multiple="multiple" accept="image/*" class="imgInp1" @change='onUpload2($event)'  style="position:absolute;clip:rect(0 0 0 0); width: 100%; height: 105px; top:0px;" v-if="judgeFan">
           </p>
         </span>
        </label>

     其中input标签type="file"的参数capture表示,可以捕获到系统默认的设备,比如:camera照相机;camcorder摄像机;microphone录音,accept表示,直接打开系统文件目录,multiple属性,表示可以支持多选。

(二): 获取图片同时压缩,然后传给后台


    // 解决ios照片旋转问题
    //获取照片的拍摄方向
    getOrientation(file, callback){
      var reader = new FileReader();
      reader.onload = function(e) {
        var view = new DataView(e.target.result);
        if (view.getUint16(0, false) != 0xFFD8){
          return callback(-2);
        }
        var length = view.byteLength, offset = 2;
        while (offset < length) {
          var marker = view.getUint16(offset, false);
          offset += 2;
          if (marker == 0xFFE1) {
            if (view.getUint32(offset += 2, false) != 0x45786966){
              return callback(-1);
            }
            var little = view.getUint16(offset += 6, false) == 0x4949;
            offset += view.getUint32(offset + 4, little);
            var tags = view.getUint16(offset, little);
            offset += 2;
            for (var i = 0; i < tags; i++){
              if (view.getUint16(offset + (i * 12), little) == 0x0112)
                return callback(view.getUint16(offset + (i * 12) + 8, little));
            }
          }else if ((marker & 0xFF00) != 0xFF00){
            break;
          }else {
            offset += view.getUint16(offset, false);
          }
        }
        return callback(-1);
      };
      reader.readAsArrayBuffer(file);
    },

/*
获取图片的事件
*/
onUpload(input) {
      var _this = this;
      if (_this.judgeZheng) {
        _this.judgeZheng = false;
        _this.hideImg2=true;
      /*
       imglist 是定义的一个存放图片的数组,来判断只能上传一张图片
     */
        if (this.imgList.length >= 1) {
          $.alert("只能上传一张照片!");
          return;
        }
        if (input.target.files && input.target.files[0]) {
          if (window.FileReader) {
            var name = input.target.value.substring(
              input.target.value.lastIndexOf(".") + 1,
              input.target.value.lastIndexOf(".").length
              );
            var timeStamp = input.timeStamp;
            /*
           创建一个FileReader对象,用来获取文件
           */
            var reader = new FileReader();
            reader.onload = function(e) {
              var objs = {
                url: e.target.result,
                name: name,
                timeStamp: timeStamp
              };
              ysImg(objs, function(objs) {
                _this.imgListzheng = objs.url;
                _this.img_file = input;
                _this.thumbnailUrl = objs.url;
               _this.img_data = objs.url;
              _this.img_name ='11.jpg';
              _this.timeStamp = objs.timeStamp;
            });
              function ysImg(objs, callback) {
              //设置压缩图片的最大高度
              var imgarr = [];
              var MAX_HEIGHT = 1000;
              //获取拍摄方向
              _this.getOrientation(input.target.files[0], function(orientation) {
                _this.orientation = orientation;
              });
              // 创建一个 Image 对象
              var image = new Image();
              image.src = objs.url;
              // 绑定 load 事件处理器,加载完成后执行
              image.onload = function() {
                // 获取 canvas DOM 对象
                var canvas = document.createElement("canvas");
                // 如果高度超标
                if (image.height > MAX_HEIGHT && image.height >= image.width) {
                  // 宽度等比例缩放 *=
                  image.width *= MAX_HEIGHT / image.height;
                  image.height = MAX_HEIGHT;
                }
                //考录到用户上传的有可能是横屏图片同样过滤下宽度的图片。
                if (image.width > MAX_HEIGHT && image.width > image.height) {
                  // 宽度等比例缩放 *=
                  image.height *= MAX_HEIGHT / image.width;
                  image.width = MAX_HEIGHT;
                }
                // 获取 canvas的 2d 画布对象,
                var ctx = canvas.getContext("2d");
                // canvas清屏,并设置为上面宽高
                ctx.clearRect(0, 0, canvas.width, canvas.height);
                // 重置canvas宽高
                canvas.width = image.width ;
                canvas.height = image.height ;
                //判断图片拍摄方向是否旋转了90度
                if(_this.orientation == 6){
                  var x = canvas.width / 2;                //画布宽度的一半
                  var y = canvas.height / 2;               //画布高度的一半
                  ctx.clearRect(0,0, canvas.width, canvas.height);           //先清掉画布上的内容
                  ctx.translate(x,y);                      //将绘图原点移到画布中点
                  ctx.rotate( (Math.PI / 180) * 90 );      //旋转角度
                  ctx.translate(-x,-y);                    //将画布原点移动
                  ctx.drawImage(image, 0, 0, image.width, image.height);       //绘制图片
                }else{
                  // 将图像绘制到canvas上
                  ctx.drawImage(image, 0, 0, image.width, image.height);
                  // !!! 注意,image 没有加入到 dom之中
                  //        document.getElementById('img').src = canvas.toDataURL("image/png");
                }
                _this.blob = canvas.toDataURL("image/jpeg",0.5);
                if (objs.url.length <_this.blob.length) {
                  objs.url = objs.url;
                } else {
                  objs.url =_this.blob;
                }
                var arrName=_this.blob.split(",");
                var strName1=arrName[1];
                 /* 将获取的图片资源通过接口上传到后台
                */
                _this.API.post('/gateway/gateway',{fileContent:strName1,fileName:'11.jpg',fileType:"A01"})
                .then(function(res){
                 if(res.code=="000000"){
                  if(res.data.idCardNumber) {
                   _this.noName=res.data.name;
                   _this.noIdCardNumber=res.data.idCardNumber;
                   if(_this.blob3) {
                     _this.name=_this.noName;
                     _this.idCardNumber =  _this.noIdCardNumber
                   }
                 } 
                 _this.imgList.push(_this.imgListzheng);
               }else{
                _this.imgList=[];
                _this.judgeZheng = true;   
              }
            })
                //将转换结果放在要上传的图片数组里
                callback(objs);
              };
            }
          };
          reader.onabort = function() {
            alert("上传中断");
          };
          reader.onerror = function() {
            alert("上传出错");
          };
          reader.readAsDataURL(input.target.files[0]);
        } else {
          alert("Not supported by your browser!");
        }
      }
    } else {
    }
  },

亲测有用哟。如果对你有帮助,用你的小手帮忙点个赞哟。 ღ( ´・ᴗ・` )比心

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 214,904评论 6 497
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,581评论 3 389
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 160,527评论 0 350
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,463评论 1 288
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,546评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,572评论 1 293
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,582评论 3 414
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,330评论 0 270
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,776评论 1 307
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,087评论 2 330
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,257评论 1 344
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,923评论 5 338
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,571评论 3 322
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,192评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,436评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,145评论 2 366
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,127评论 2 352

推荐阅读更多精彩内容