vue 2.0需求拍摄证件照(需要设置人头取景框,鼠标也拖拽,键盘方向键可调整位置)

这篇具有很好参考价值的文章主要介绍了vue 2.0需求拍摄证件照(需要设置人头取景框,鼠标也拖拽,键盘方向键可调整位置)。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

继续昨天的代码更新一下
需求是: vue2 主页面是一个表格,存在按钮点击进行调取摄像头拍照,拍照呢要有头像的取景框,鼠标可移动,键盘通过方向键也可移动,调整了昨天的代码存在的问题,拖动会拍照一部分外面的内容,
今天,疑惑点在获取更新后的节点,及怎么设置键盘事件监听的方法上。
忘记使用 updated 里获取更新后的dom 做监听 通过$nexttick去获取;
忘记使用原生 js 做事件监听,
目前还未完成,下一步需要做的是键盘操作dom移动。
cv的太多,稍微创新一点的需求就做的好慢啊,加油自己!!

回顾一下dom操作的跳转
vue 人相框摄像头,vue.js,计算机外设,javascript

取景框如图:也可下载获取。vue 人相框摄像头,vue.js,计算机外设,javascript
vue代码如下:文章来源地址https://www.toymoban.com/news/detail-800711.html

<template>
  <div>
    <!--开启摄像头的弹窗-->
    <div
      class="info2"
      @click="onTake"
      style="width: 200px; height: 200px; border: 1px solid skyblue"
    >
      <el-image v-if="url" :src="url"></el-image>
      <div v-if="!url" style="line-height: 200px; text-align: center">
        暂无图片
      </div>
    </div>

    <!--开启摄像头的拍照和-->
    <el-dialog
      title="拍照上传"
      :visible.sync="visible"
      @close="onCancel1"
      width="1065px"
    >
      <div class="box">
        <!-- 蒙层 -->
        <div
          id="camerabox"
          ref="camerabox"
          @keydown="handleKeyDown()"
          @click="cameraBoxMove"
          v-drag
        ></div>

        <video
          id="videoCamera"
          class="canvas"
          :width="videoWidth"
          :height="videoHeight"
          autoPlay
        ></video>
        <canvas
          id="canvasCamera"
          class="canvas"
          :width="videoWidth"
          :height="videoHeight"
        ></canvas>
      </div>

      <div slot="footer">
        <el-button @click="drawImage" icon="el-icon-camera" size="small">
          拍照
        </el-button>
        <el-button
          v-if="os"
          @click="getCompetence"
          icon="el-icon-video-camera"
          size="small"
        >
          打开摄像头
        </el-button>
        <el-button
          v-else
          @click="stopNavigator"
          icon="el-icon-switch-button"
          size="small"
        >
          关闭摄像头
        </el-button>
        <el-button @click="resetCanvas" icon="el-icon-refresh" size="small">
          重置
        </el-button>
        <el-button @click="onCancel" icon="el-icon-circle-close" size="small">
          完成
        </el-button>
      </div>
    </el-dialog>
  </div>
</template>

<script>
import "@/utils/drage.js";
export default {
  name: "photo",
  //对参数进行设置
  data() {
    return {
      url: "", // 上传的图片的地址
      visible: false, //弹窗
      videoWidth: 1024, // 绘画布的宽高
      videoHeight: 700,
      os: false, //控制摄像头开关
      thisCancas: null,
      thisContext: null,
      thisVideo: null,
      imgSrc: undefined,
      imgFile: null,
      top: null,
      left: null,
    };
  },
  updated() {

    this.handleKeyDown(Event)
   
  },

  methods: {
    /*调用摄像头拍照开始*/
    onTake() {
      this.visible = true;
      this.getCompetence();
      this.imgSrc = "";
    },
    handleKeyDown(event) {
      this.getTopLeft()
      this.$nextTick(() => {
        const _this = this;
        let MC = _this.$refs.camerabox;
        // console.log(' this',MC)
        document.addEventListener('keydown',function(e){ 
          // console.log(e.key)
          if(e.key === 'ArrowLeft' ) {  // ←
            console.log('←', MC)
            this.left - 5
          }
          if(e.key === 'ArrowRight' ) {  // ←
            console.log('→', )
            this.left + 5
          }
          if(e.key === 'ArrowUp' ) {  // ←
            console.log('↑', )
            this.top - 5  
          }
          if(e.key === 'ArrowDown' ) {  // ←
            console.log('↓', )
            this.top + 5  
                
          }
        })

      })
    },

    /*关闭弹窗,以及关闭摄像头功能*/
    onCancel1() {
      this.visible = false;
      this.stopNavigator(); // 关闭摄像头
    },

    // 调用摄像头权限
    getCompetence() {
      //必须在model中render后才可获取到dom节点,直接获取无法获取到model中的dom节点
      this.$nextTick(() => {
        const _this = this;
        this.os = false; //切换成关闭摄像头
        // 获取画布节点
        this.thisCancas = document.getElementById("canvasCamera");
        // 为画布指定绘画为2d类型
        this.thisContext = this.thisCancas.getContext("2d");
        //获取video节点
        this.thisVideo = document.getElementById("videoCamera");
        // 旧版本浏览器可能根本不支持mediaDevices,我们首先设置一个空对象
        if (navigator.mediaDevices === undefined) {
          navigator.menavigatordiaDevices = {};
        }
        // 一些浏览器实现了部分mediaDevices,我们不能只分配一个对象
        // 使用getUserMedia,因为它会覆盖现有的属性。
        // 这里,如果缺少getUserMedia属性,就添加它。
        if (navigator.mediaDevices.getUserMedia === undefined) {
          navigator.mediaDevices.getUserMedia = function (constraints) {
            // 首先获取现存的getUserMedia(如果存在)
            let getUserMedia =
              navigator.webkitGetUserMedia ||
              navigator.mozGetUserMedia ||
              navigator.getUserMedia;
            // 有些浏览器不支持,会返回错误信息
            // 保持接口一致
            if (!getUserMedia) {
              return Promise.reject(
                new Error("getUserMedia is not implemented in this browser")
              );
            }
            // 否则,使用Promise将调用包装到旧的navigator.getUserMedia
            return new Promise(function (resolve, reject) {
              getUserMedia.call(navigator, constraints, resolve, reject);
            });
          };
        }
        const constraints = {
          audio: false,
          video: {
            width: _this.videoWidth,
            height: _this.videoHeight,
            transform: "scaleX(-1)",
          },
        };
        navigator.mediaDevices
          .getUserMedia(constraints)
          .then(function (stream) {
            // 旧的浏览器可能没有srcObject
            if ("srcObject" in _this.thisVideo) {
              _this.thisVideo.srcObject = stream;
            } else {
              // 避免在新的浏览器中使用它,因为它正在被弃用。
              _this.thisVideo.src = window.URL.createObjectURL(stream);
            }
            _this.thisVideo.onloadedmetadata = function (e) {
              _this.thisVideo.play();
            };
          })
          .catch((err) => {
            this.$notify({
              title: "警告",
              message: "没有开启摄像头权限或浏览器版本不兼容.",
              type: "warning",
            });
          });
      });

      // this.cameraBoxMoveKey()
    },

    /* 蒙层鼠标拖动移动 */
    cameraBoxMove() {
      this.getTopLeft();
      this.dontOut();
    },
    getTopLeft(){
      let reg = new RegExp("px", "g");
      this.top = this.$refs.camerabox.style.top.replace(reg, "");
      this.left = this.$refs.camerabox.style.left.replace(reg, "");
      console.log(this.top, this.left);
    },
    cameraBoxMoveKey() {
      let dd = window.document.getElementById("camerabox");
      console.log("dd", dd);
    },
    /* 不让出区域 */
    dontOut() {
      if (this.top < 0) {
        this.$refs.camerabox.style.top = "0px";
      }
      if (this.left < 0) {
        this.$refs.camerabox.style.left = "0px";
      }
      if (this.left > 712) {
        this.$refs.camerabox.style.left = "712px";
      }
      if (this.top > 277) {
        this.$refs.camerabox.style.top = "277px";
      }
      this.getTopLeft();

    },

    //调用摄像头 --- 进行绘制图片
    drawImage() {
      // this.getMousePoint()
      let dw = this.$refs.camerabox.clientWidth;
      let dh = this.$refs.camerabox.clientHeight;

      // 点击,canvas画图
      this.thisContext.drawImage(
        this.thisVideo,
        this.left, // 设置 为鼠标的起点x
        this.top, // 设置 为鼠标的起点x
        314,
        420,
        0, //  这个坐标 0
        0, //  这个坐标 0
        dw, //  拍片的宽
        dh //  拍片的高
      );
      // 获取图片base64链接
      this.imgSrc = this.thisCancas.toDataURL("image/png");
    },

    //清空画布
    clearCanvas(id) {
      let c = document.getElementById(id);
      let cxt = c.getContext("2d");
      cxt.clearRect(0, 0, c.width, c.height);
    },

    //重置画布
    resetCanvas() {
      // this.imgSrc = "";
      this.clearCanvas("canvasCamera");
    },

    //关闭摄像头
    stopNavigator() {
      if (this.thisVideo && this.thisVideo !== null) {
        this.thisVideo.srcObject.getTracks()[0].stop();
        this.os = true; //切换成打开摄像头
      }
    },
    /*调用摄像头拍照结束*/

    /*完成拍照并对其照片进行上传*/
    onCancel() {
      if (!this.imgSrc) {
        alert("请点击拍照,确认照片后才能完成!");
        return false;
      }
      this.visible = false;
      this.stopNavigator();
      /* this.resetCanvas();*/
      // console.log(this.imgSrc);
      this.imgFile = this.dataURLtoFile(this.imgSrc, new Date() + ".png");
      console.log(this.imgFile);
      // let par = {
      //   photo: this.imgFile,
      // };
      let data = new FormData();
      data.append("photo", this.imgFile); //1是图片,2是视频
      // data.append("code", this.addForm.code);
      console.log(data);

      // checkbeforepersonalphoto上传图片的接口
      //  checkbeforepersonalphoto(data).then(res => {
      //    if (res.code == "1") {
      //      this.$message({
      //        message: "上传成功",
      //        type: "success"
      //      });
      //      this.url = res.data;
      //    }
      //  });
    },

    dataURLtoFile(dataurl, filename) {
      var arr = dataurl.split(",");
      var mime = arr[0].match(/:(.*?);/)[1];
      var bstr = atob(arr[1]);
      var n = bstr.length;
      var u8arr = new Uint8Array(n);
      while (n--) {
        u8arr[n] = bstr.charCodeAt(n);
      }
      return new File([u8arr], filename, { type: mime });
    },
  },
};
</script>
<style scoped>
.box {
  position: relative;
}
#camerabox {
  width: 310px;
  height: 419px;
  top: 0px;
  left: 0px;
  right: 0px;
  bottom: 0px;
  border: 2px solid skyblue;
  position: absolute;
  background: url(../../public/selectImage.png);
  background-repeat: no-repeat;
  z-index: 9999;
}
</style>
<!-- <style lang="scss" scoped>
.info2 {
  width: 10%;
  height: 100px;
}
.box {
  display:flex;
}
</style> -->

到了这里,关于vue 2.0需求拍摄证件照(需要设置人头取景框,鼠标也拖拽,键盘方向键可调整位置)的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • 基于springboot+vue+Mysql的滴答拍摄影项目

    开发语言:Java 框架:springboot JDK版本:JDK1.8 服务器:tomcat7 数据库:mysql 5.7(一定要5.7版本) 数据库工具:Navicat11 开发软件:eclipse/myeclipse/idea Maven包:Maven3.3.9 系统展示 管理员登录界面 用户管理界面 摄影作品管理界面 摄影服务管理界面 预约信息管理界面 摄影论坛管理界

    2024年04月08日
    浏览(46)
  • VUE+faceApi.js实现摄像头拍摄人脸识别

    需求:前端获取到摄像头信息,通过模型来进行判断人像是否在镜头中,镜头是否有被遮挡。 实现步骤: 1、通过video标签来展示摄像头中的内容 2、通过canvas来绘制视频中信息进行展示 3、在拍照时候将canvas的当前帧转成图片 下载依赖 face-api.js是核心依赖必须要下 element-ui为

    2024年02月01日
    浏览(38)
  • 功能需求-根据页面生成pdf,pdf不需要下载只需把文件流上传到服务器

    根据自身当下技术的水平和实际情况,做一个简单的记录。 在项目中有采购合同和销售合同,这些合同新建好之后都需要有人去审核,审核通过后需要把合同生成一个pdf文件然后后端给保存起来 在项目中有采购合同和销售合同,这些合同新建好之后都需要有人去审核,审核

    2024年02月13日
    浏览(45)
  • 图片填满div,真让人头大

    家人们,这图片到底怎样才能完全填满div啊,想问度娘结果搜索的问题都乱七八糟的 (怎么那么多问题QAQ),描述问题都描述不来 具体问题如下:图片有自己的分辨率大小,例如宽100px,高100px,将图片添加到div中: div class=\\\"xx\\\" img src=\\\"xxx\\\" /div 接着用css代码编辑样式的时候,

    2024年02月03日
    浏览(31)
  • 终极指南:Scrum中如何设置需求优先级

    需求众多不知道如何下手?总想先做简单的需求,复杂需求却一拖再拖?那么,我们是时候开始考虑如何设置需求优先级了。 本期终极指南将展示如何为需求设置有效优先级,如何有效管理工作量,让效率指数倍增长,搭配 《 Scrum流程:如何科学地进行需求优先级排序 ?

    2024年02月08日
    浏览(48)
  • redis7.2.0 centos源码编译安装并设置开机自启动

    下载源码包 编译编码 编译编码 此时默认redis-server redis-cli等命令行安装到目录/usr/local/bin/目录中。 如果你想安装命令行到指定目录中你可以指定位置 如 make install PREFIX=/usr/local/redis 修改redis.conf 后台启动 daemonize yes 支持远程连接 注释或者指定为0.0.0.0 bind 127.0.0.1 -::1 protected

    2024年02月10日
    浏览(54)
  • uniapp设置手机通知权限以及uniapp-push2.0推送

    unipush2.0代码 提醒用户开启通知权限,与unipush功能联用 效果图: 方法: 直接使用即可,在真机或模拟器运行 在App.vue文件进行操作,除去代码操作还需在开发者后台-unipush添加安卓包名,若有疑问可私信或者评论,

    2024年02月04日
    浏览(39)
  • Vue 2.0 学习笔记

    我们new出来的vue对象,他的data对象中一般存放我们需要绑定的值,而这些值我们可以在html中利用 {{name}} 的方式打印出来,他的实现过程如图 步骤大概如下,我们再data里面存放的数据,vue会将它存放在vue实例的_data属性下,同时利用 Object.defineProperty 设置了get和set方法。 那为

    2024年02月03日
    浏览(33)
  • 让测试人头疼的web自动化之验证码识别彻底解决方案

    对于web应用程序来讲,处于安全性考虑,在登录的时候,都会设置验证码,验证码的类型种类繁多,有图片中辨别数字字母的,有点击图片中指定的文字的,也有算术计算结果的,再复杂一点就是滑动验证的。诸如此类的验证码,对我们的系统增加了安全性的保障,但是对于

    2024年01月17日
    浏览(35)
  • Settings系列(三)根据需求动态添加删除一级菜单、二级菜单的设置项

    当时遇到定制需求,需要根据实际需要隐藏Settings的菜单项,于是开始了寻找方法 在看了一下源码,经过尝试后,确认生效后,就简单说明一下Settings中布局中主要组成元素 Settings中的菜单项是由 PreferenceScreen 和Preference组成的。其中PreferenceScreen 类似于我们平常使用布局中的

    2024年02月15日
    浏览(42)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包