uniapp---调用H5端电脑摄像头进行拍照

1.首先安装依赖:

npm i html2canvas

2.uniap html样式

<view  @click="test">进行拍摄</view>
<div>
  <!-- 这里就是摄像头显示的画面 -->
  <video id="video" width="400" height="300"></video>
  <div>
    <button   @click="takePhone" style="margin-top: 10px;">拍照</button>
  </div>
</div>

<div>图片截图画面</div>
  <!-- 这里是点击拍照显示的图片画面 -->
  <img  :src="imgUrl" ></img>
</div>

3.uniapp 中js代码

import html2canvas from 'html2canvas'


data() {
  return {
    imgUrl:"",
    blobFile: null,
    canvas: null,
    video:null,
    mediaStreamTrack: '',
    
  };
},
onShow() {
  // 摄像头
  this.video = document.querySelector('video');
},
  methods: {
    //点击拍照截图画面
     takePhone() {
             html2canvas(document.querySelector('video'), {
                 backgroundColor: null,
                 useCORS: true // 如果截图的内容里有图片,可能会有跨域的情况,加上这个参数,解决文件跨域问题
             }).then((canvas) => {
                 let url = canvas.toDataURL('image/png');
                 this.imgUrl = url;

            })
      },
         test(){
              var video = document.querySelector('video');
              // 兼容代码
              window.URL = (window.URL || window.webkitURL || window.mozURL || window.msURL);
              if (navigator.mediaDevices === undefined) {
                  navigator.mediaDevices = {};
              }
              if (navigator.mediaDevices.getUserMedia === undefined) {
                  navigator.mediaDevices.getUserMedia = function(constraints) {
                      var getUserMedia = navigator.webkitGetUserMedia || navigator.mozGetUserMedia || navigator.msGetUserMedia;
                      if (!getUserMedia) {
                          return Promise.reject(new Error('getUserMedia is not implemented in this browser'));
                      }
                      return new Promise(function(resolve, reject) {
                          getUserMedia.call(navigator, constraints, resolve, reject);
                      });
                  }
              }
              //摄像头调用配置
              var mediaOpts = {
                  audio: false,
                  video: { facingMode: "user"} 
                  
              }

              let that=this;
              navigator.mediaDevices.getUserMedia(mediaOpts).then(function(stream) {
                  that.mediaStreamTrack = stream;
                  video = document.querySelector('video');
                  if ("srcObject" in video) {
                      video.srcObject = stream
                  } else {
                      video.src = window.URL && window.URL.createObjectURL(stream) || stream
                  }
                  video.play();
              }).catch(function (err) {
                  console.log(err)
              });
      },                      
    }

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值