vue 实现无规则截图
网络编程 2021-07-04 14:07www.168986.cn编程入门
这篇文章主要介绍了vue 实现无规则截图的方法,帮助大家更好的理解和学习使用vue框架,感兴趣的朋友可以了解下
大家所见到的大多数都是有规则截图,可以应付大部分的应用场景,对于图片处理,想要将规则交给用户,普通的截图已经满足不了用户了,那我们能不能前端实现图片的任意规则截取,接下来让我一起探讨一下吧!
通过 svg 实现 图片截取
使用svg中clipPath image标签 通过id 映射, 动态位置polygon的坐标,实现图片的截取
<div> <div class="content" @mousemove="mousemove" @mouseup="(e) => {mouseup(e);}"> <!-- 画布展示 --> <svg ref="blackSvg" class="blackSvg" xmlns="http://.w3./2000/svg" width="300" height="300" > <defs> <clipPath id="clippath"> <polygon :points="points"></polygon> </clipPath> </defs> <image xmlns:link="http://.w3./1999/xlink" href="https://ss2.bdstatic./70cFvnSh_Q1YnxGkpoWK1HF6hhy/it/u=3228549874,2173006364&fm=26&gp=0.jpg" rel="external nofollow" width="300" height="300" preserveAspectRatio="none" style="clip-path: url(#clippath)" ></image> </svg> <!-- 拖拽点 --> <ul class="interception"> <li v-for="item in 4" :ref="`li${item}`" :key="item" @mousedown="(e) => {mousedown(e, item);}" ></li> </ul> <!-- 底图展示 --> <img class="blackImge" src="https://ss2.bdstatic./70cFvnSh_Q1YnxGkpoWK1HF6hhy/it/u=3228549874,2173006364&fm=26&gp=0.jpg" alt="" /> <!-- 遮罩层 --> <div class="blackDiv"></div> </div> </div>
css部分
<style lang="sass"> .blackDiv width: 100% height: 100% position: absolute : 0 z-index: 2 background: rgba(0,0,0, 1) .content width:300px height:300px text-align: left position: relative .blackSvg position: absolute : 0 z-index: 3 .blackImge position: absolute : 0 left: 0 width: 300px height: 300px .interception list-style: none position: absolute : 0 margin: 0 padding: 0 z-index: 3 >li position: absolute width: 10px height: 10px background: blue border-radius: 50% cursor: pointer &:hover transform: scale(1.2) transition-duration: .2 >li:nth-child(1) : 10px left: 10px >li:nth-child(2) : 10px left: 100px >li:nth-child(3) : 100px left: 100px >li:nth-child(4) : 100px left: 10px </style> <script>
export default { name: 'Canvas', data() { return { points: '0 0,300 0,300 300,0 300', // 图片展示初始化 status: false, index: 0, disX: 0, disY: 0, coordinates: { // 初始化拖拽点 1: [0, 0], 2: [300, 0], 3: [300, 300], 4: [0, 300], }, }; }, mounted() { this.$nextTick(() => { for (let key in this.coordinates) { const left = this.coordinates[key][0]; const = this.coordinates[key][1]; this.$refs[`li${key}`].style.left = `${left}px`; this.$refs[`li${key}`].style. = `${}px`; if (key == 2 || key == 3) { this.$refs[`li${key}`].style.left = `${left - 10}px`; } if (key == 3 || key == 4) { this.$refs[`li${key}`].style. = `${ - 10}px`; } } document.onmouseup = () => { this.status = false; }; }); }, methods: { //鼠标按下 mousedown(e, index) { this.status = true; this.index = index; this.disX = e.clientX - this.$refs[`li${index}`].offsetLeft; this.disY = e.clientY - this.$refs[`li${index}`].offsetTop; }, // 鼠标抬起 mouseup(e) { this.status = false; }, // 鼠标移动 mousemove(e) { if (this.status) { let left = e.clientX - this.disX; let = e.clientY - this.disY; this.$refs[`li${this.index}`].style.left = `${left}px`; this.$refs[`li${this.index}`].style. = `${}px`; this.coordinates[this.index] = [left, ]; const pointsArr = []; for (let item in this.coordinates) { pointsArr.push( Array.from(this.coordinates[item], (e) => { return e + 5; }) ); } this.points = pointsArr.join(' '); } }, }, };
效果图展示
源码地址
github地址-->
以上就是vue 实现无规则截图的详细内容,更多关于vue 无规则截图的资料请关注狼蚁SEO其它相关文章!
编程语言
- 如何快速学会编程 如何快速学会ug编程
- 免费学编程的app 推荐12个免费学编程的好网站
- 电脑怎么编程:电脑怎么编程网咯游戏菜单图标
- 如何写代码新手教学 如何写代码新手教学手机
- 基础编程入门教程视频 基础编程入门教程视频华
- 编程演示:编程演示浦丰投针过程
- 乐高编程加盟 乐高积木编程加盟
- 跟我学plc编程 plc编程自学入门视频教程
- ug编程成航林总 ug编程实战视频
- 孩子学编程的好处和坏处
- 初学者学编程该从哪里开始 新手学编程从哪里入
- 慢走丝编程 慢走丝编程难学吗
- 国内十强少儿编程机构 中国少儿编程机构十强有
- 成人计算机速成培训班 成人计算机速成培训班办
- 孩子学编程网上课程哪家好 儿童学编程比较好的
- 代码编程教学入门软件 代码编程教程