文章详情

短信预约-IT技能 免费直播动态提醒

请输入下面的图形验证码

提交验证

短信预约提醒成功

如何使用Vue实现拖动截图功能

2023-07-04 12:17

关注

这篇文章主要介绍了如何使用Vue实现拖动截图功能的相关知识,内容详细易懂,操作简单快捷,具有一定借鉴价值,相信大家阅读完这篇如何使用Vue实现拖动截图功能文章都会有所收获,下面我们一起来看看吧。

一、安装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"          ></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"          ></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具体轻量级框架、简单易学、双向数据绑定、组件化、数据和结构的分离、虚拟DOM、运行速度快等优势,Vue中页面使用的是局部刷新,不用每次跳转页面都要请求所有数据和dom,可以大大提升访问速度和用户体验。

关于“如何使用Vue实现拖动截图功能”这篇文章的内容就介绍到这里,感谢各位的阅读!相信大家对“如何使用Vue实现拖动截图功能”知识都有一定的了解,大家如果还想学习更多知识,欢迎关注编程网行业资讯频道。

阅读原文内容投诉

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

软考中级精品资料免费领

  • 历年真题答案解析
  • 备考技巧名师总结
  • 高频考点精准押题
  • 2024年上半年信息系统项目管理师第二批次真题及答案解析(完整版)

    难度     813人已做
    查看
  • 【考后总结】2024年5月26日信息系统项目管理师第2批次考情分析

    难度     354人已做
    查看
  • 【考后总结】2024年5月25日信息系统项目管理师第1批次考情分析

    难度     318人已做
    查看
  • 2024年上半年软考高项第一、二批次真题考点汇总(完整版)

    难度     435人已做
    查看
  • 2024年上半年系统架构设计师考试综合知识真题

    难度     224人已做
    查看

相关文章

发现更多好内容

猜你喜欢

AI推送时光机
位置:首页-资讯-后端开发
咦!没有更多了?去看看其它编程学习网 内容吧
首页课程
资料下载
问答资讯