欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

Vue拖动截图功能的简单实现方法

程序员文章站 2022-06-18 18:16:09
拖动鼠标进行页面截图(也可指定区域拖动截图)一、安装html2canvas、vue-croppernpm i html2canvas --save //用于将指定区域转为图片npm...

拖动鼠标进行页面截图(也可指定区域拖动截图)

一、安装html2canvas、vue-cropper

npm i html2canvas --save          //用于将指定区域转为图片
npm i vue-cropper -s             //将图片进行裁剪

二、在main.js注册vue-cropper组件

import vuecropper from 'vue-cropper'
vue.use(vuecropper)

三、页面中引入html2canvas

  import html2canvas from "html2canvas"
  export default{
  }

四、代码分解

1、将指定区域转为图片

this.$nexttick(()=>{
   html2canvas(document.body,{}).then(canvas => {    
     let dataurl = canvas.todataurl("image/png");
     this.uploadimg = dataurl
     this.loading = true
   });
 })

这里是将body整个页面转为图片,得到base64格式数据,其他区域直接获取class或者id

2、将生成的图片进行拖动截图

<template>
	<div class="pop_alert" v-if="show">
	   <vuecropper
	      @mouseenter.native="enter"
	      @mouseleave.native="leave"
	      ref="cropper"
	      :img="uploadimg"
	      :outputsize="option.size"
	      :outputtype="option.outputtype"
	      :info="true"
	      :full="option.full"
	      :canmove="option.canmove"
	      :canmovebox="option.canmovebox"
	      :original="option.original"
	      :autocrop="option.autocrop"
	      :fixed="option.fixed"
	      :fixednumber="option.fixednumber"
	      :centerbox="option.centerbox"
	      :infotrue="option.infotrue"
	      :fixedbox="option.fixedbox"
	      style="background-image:none"
	    ></vuecropper>
	    <div class="btn_box">
	    	<div @click="save">确认截图</div>
	   	    <div @click="close">取消</div>
	    </div>
	 </div>
 </template>
<script>
 export default{
   data(){
       option: {
          info: true, // 裁剪框的大小信息
          outputsize: 0.8, // 裁剪生成图片的质量
          outputtype: "jpeg", // 裁剪生成图片的格式
          canscale: false, // 图片是否允许滚轮缩放
          autocrop: false, // 是否默认生成截图框
          fixedbox: false, // 固定截图框大小 不允许改变
          fixed: false, // 是否开启截图框宽高固定比例
          fixednumber: [7, 5], // 截图框的宽高比例
          full: true, // 是否输出原图比例的截图
          canmove: false, //时候可以移动原图
          canmovebox: true, // 截图框能否拖动
          original: false, // 上传图片按照原始比例渲染
          centerbox: false, // 截图框是否被限制在图片里面
          infotrue: true // true 为展示真实输出图片宽高 false 展示看到的截图框宽高
        },
        uploadimg:"",
        show: false
   },
   methods:{
     enter() {
       if (this.uploadimg == "") {
         return;
       }
       this.$refs.cropper.startcrop(); //开始裁剪
     },
     leave() {
       this.$refs.cropper.stopcrop();//停止裁剪
     },
     save() {        //确认截图
        this.$refs.cropper.getcropdata((data) => {      //获取截图的base64格式数据
          console.log(data)
          this.show = false
        })
        // this.$refs.cropper.getcropblob(data => { //获取截图的blob格式数据
        //   this.cutimg = data;
        // });
      },
      close(){        //取消
        this.show = false
      }
   }
 }
 </script>

五、全部代码

<template>
   <div>
     <div @click="tailoring">裁剪</div>
	<!--继续写页面的其他内容 pop_alert可封装成组件使用-->
	
     <div class="pop_alert" v-if="show">
	   <vuecropper
	      @mouseenter.native="enter"
	      @mouseleave.native="leave"
	      ref="cropper"
	      :img="uploadimg"
	      :outputsize="option.size"
	      :outputtype="option.outputtype"
	      :info="true"
	      :full="option.full"
	      :canmove="option.canmove"
	      :canmovebox="option.canmovebox"
	      :original="option.original"
	      :autocrop="option.autocrop"
	      :fixed="option.fixed"
	      :fixednumber="option.fixednumber"
	      :centerbox="option.centerbox"
	      :infotrue="option.infotrue"
	      :fixedbox="option.fixedbox"
	      style="background-image:none"
	    ></vuecropper>
	    <div class="btn_box">
	    	<div @click="save">确认截图</div>
	   	    <div @click="close">取消</div>
	    </div>
	 </div>
   </div>
</template>
<script>
import html2canvas from "html2canvas"
 export default{
  data(){
   return{
     option: {
          info: true, // 裁剪框的大小信息
          outputsize: 0.8, // 裁剪生成图片的质量
          outputtype: "jpeg", // 裁剪生成图片的格式
          canscale: false, // 图片是否允许滚轮缩放
          autocrop: false, // 是否默认生成截图框
          fixedbox: false, // 固定截图框大小 不允许改变
          fixed: false, // 是否开启截图框宽高固定比例
          fixednumber: [7, 5], // 截图框的宽高比例
          full: true, // 是否输出原图比例的截图
          canmove: false, //时候可以移动原图
          canmovebox: true, // 截图框能否拖动
          original: false, // 上传图片按照原始比例渲染
          centerbox: false, // 截图框是否被限制在图片里面
          infotrue: true // true 为展示真实输出图片宽高 false 展示看到的截图框宽高
        },
        uploadimg:"",
        show: false
   }
  },
  methods:{
    tailoring(){            //裁剪
      this.$nexttick(()=>{
           html2canvas(document.body,{}).then(canvas => {
             let dataurl = canvas.todataurl("image/png");
             this.uploadimg = dataurl
             this.show = true
           });
       })
    },
    enter() {
       if (this.uploadimg == "") {
         return;
       }
       this.$refs.cropper.startcrop(); //开始裁剪
     },
     leave() {
       this.$refs.cropper.stopcrop();//停止裁剪
     },
     save() {        //确认截图
        this.$refs.cropper.getcropdata((data) => {      //获取截图的base64格式数据
          console.log(data)
          this.show = false
        })
        // this.$refs.cropper.getcropblob(data => { //获取截图的blob格式数据
        //   this.cutimg = data;
        // });
      },
      close(){        //取消
        this.show = false
      }
   }
 }
</script>
<style>
	.pop_alert{
      width: 100%;
	  height: 100%;
	  position: absolute;
	  top: 0;
	  left: 0;
	  border: 1px dashed red;
	  background-color: #000000;
    }
    .btn_box{
        position: absolute;
	    top: 0;
	    color: red;
	    right: 0;
	    font-size: 30px;
	    display: flex;
        align-items: center;
	    z-index: 6666;
    }
</style>

效果图

Vue拖动截图功能的简单实现方法

Vue拖动截图功能的简单实现方法

总结

到此这篇关于vue拖动截图功能实现的文章就介绍到这了,更多相关vue拖动截图功能内容请搜索以前的文章或继续浏览下面的相关文章希望大家以后多多支持!

相关标签: vue 拖动 截图