vue如何使用js對(duì)圖片進(jìn)行點(diǎn)擊標(biāo)注圓點(diǎn)并記錄它的坐標(biāo)
最近和深度學(xué)習(xí)方面搞個(gè)東西,需要前端對(duì)圖片進(jìn)行標(biāo)注,呃,這個(gè)我上網(wǎng)也沒找到什么好方法,只能自己通過(guò)js來(lái)實(shí)現(xiàn),不過(guò)現(xiàn)在剛初步做出一點(diǎn)效果,樣式?jīng)]留意,挺丑的,嘻嘻。
功能
- 點(diǎn)擊開始標(biāo)注按鈕后才可以對(duì)圖片進(jìn)行標(biāo)注
- 在圖片區(qū)域內(nèi)單機(jī)左鍵才可進(jìn)行加點(diǎn)
- 在標(biāo)注點(diǎn)上右擊刪除該點(diǎn),在圖片上右擊無(wú)效果
- 完成標(biāo)注后點(diǎn)擊完成標(biāo)注按鈕后,結(jié)束標(biāo)注,此后點(diǎn)擊圖片不再加點(diǎn)
標(biāo)注前
標(biāo)注后
打印記錄坐標(biāo)點(diǎn)
這個(gè)坐標(biāo)看你自己需求,是相對(duì)圖片的百分比坐標(biāo),還是相對(duì)整個(gè)窗口的坐標(biāo),js都可以實(shí)現(xiàn)的
代碼實(shí)現(xiàn)
我先說(shuō)一說(shuō)關(guān)鍵功能實(shí)現(xiàn)的js代碼(里面涉及了date的數(shù)據(jù),所以需要看下后面的全部代碼實(shí)現(xiàn)),后面就是全部代碼
判斷鼠標(biāo)是否右擊
if(e.button !== 2) //判斷鼠標(biāo)是否右擊
阻止冒泡行為和默認(rèn)右鍵菜單事件
document.getElementById('myBiaoZhu').oncontextmenu=((e)=>{ if(e && e.preventDefault) { //阻止默認(rèn)瀏覽器動(dòng)作(W3C) e.preventDefault() } else { //IE中阻止函數(shù)器默認(rèn)動(dòng)作的方式 window.event.returnValue = false } return false }) //阻止冒泡行為和默認(rèn)右鍵菜單事件
給圖片加點(diǎn)擊事件
document.getElementById('myBiaoZhu').onmousedown=(e)=>{ e = e || window.event if(e.button !== 2){ //判斷是否右擊 if(this.canBiaoZhu){ //判斷是否可以進(jìn)行標(biāo)注 var x = e.offsetX || e.layerX var y = e.offsetY || e.layerY console.log(x,y) var myImg = document.querySelector("#myBiaoZhu") var currWidth = myImg.clientWidth var currHeight = myImg.clientHeight var ProportionWidthInImg = x/currWidth var ProportionHeightInImg = y/currHeight // console.log("圖片比例高度:"+ProportionHeightInImg) // console.log("圖片比例寬度:"+ProportionWidthInImg) this.banMa.push({ id:this.banMa.length+1, x, y }) this.createMarker(x,y) } } }
畫點(diǎn)
createMarker(x, y) { var div = document.createElement('div') div.className = 'marker' div.id = 'marker'+this.banMa.length y = y + document.getElementById('myBiaoZhu').offsetTop - this.pointSize/2 x = x + document.getElementById('myBiaoZhu').offsetLeft - this.pointSize/2 div.style.width = this.pointSize + 'px' div.style.height = this.pointSize + 'px' div.style.backgroundColor = this.pointColor div.style.left = x + 'px' div.style.top = y + 'px' div.oncontextmenu=((e)=>{ //阻止冒泡行為和默認(rèn)右鍵菜單事件,同時(shí)刪除該點(diǎn) var id = e.target.id document.getElementById('myBiaoZhuDiv').removeChild(div) this.banMa = this.banMa.filter(item=>item.id!= id.slice(6,id.length)) if(e && e.preventDefault) { //阻止默認(rèn)瀏覽器動(dòng)作(W3C) e.preventDefault() } else { //IE中阻止函數(shù)器默認(rèn)動(dòng)作的方式 window.event.returnValue = false } return false }) document.getElementById('myBiaoZhuDiv').appendChild(div) },
html:
<template> <div class="myBiaoZhu" id="myBiaoZhuDiv"> <img id="myBiaoZhu" src="./1.png" alt="" style="height: 400px;width: 400px;"> <el-button type="text" @click="startBiaoZhu">開始標(biāo)注</el-button> <el-button type="text" @click="endBiaoZhu">標(biāo)注完成</el-button> </div> </template>
css:
<style lang="less"> #myBiaoZhuDiv{ position:relative; img{ border:solid 1px #000; display:inline-block; margin:100px 100px; z-index: 1; } .marker{ position:absolute; border-radius: 50%; z-index: 999; } } </style>
js:
<script> export default { name: '', components: {}, data () { return { banMa:[], //斑馬線的數(shù)組 canBiaoZhu:false, //是否可以進(jìn)行標(biāo)注 pointColor:'red', //點(diǎn)的顏色 pointSize:10, //點(diǎn)的大小 } }, methods: { //開始標(biāo)注 startBiaoZhu(){ this.canBiaoZhu = true }, //完成標(biāo)注 endBiaoZhu(){ this.canBiaoZhu = false }, //畫點(diǎn) createMarker(x, y) { var div = document.createElement('div') div.className = 'marker' div.id = 'marker'+this.banMa.length y = y + document.getElementById('myBiaoZhu').offsetTop - this.pointSize/2 x = x + document.getElementById('myBiaoZhu').offsetLeft - this.pointSize/2 div.style.width = this.pointSize + 'px' div.style.height = this.pointSize + 'px' div.style.backgroundColor = this.pointColor div.style.left = x + 'px' div.style.top = y + 'px' div.oncontextmenu=((e)=>{ var id = e.target.id document.getElementById('myBiaoZhuDiv').removeChild(div) this.banMa = this.banMa.filter(item=>item.id!= id.slice(6,id.length)) if(e && e.preventDefault) { //阻止默認(rèn)瀏覽器動(dòng)作(W3C) e.preventDefault() } else { //IE中阻止函數(shù)器默認(rèn)動(dòng)作的方式 window.event.returnValue = false } return false }) //阻止冒泡行為和默認(rèn)右鍵菜單事件,刪除該點(diǎn) document.getElementById('myBiaoZhuDiv').appendChild(div) }, }, watch: {}, computed: {}, created () { }, mounted () { document.getElementById('myBiaoZhu').oncontextmenu=((e)=>{ if(e && e.preventDefault) { //阻止默認(rèn)瀏覽器動(dòng)作(W3C) e.preventDefault() } else { //IE中阻止函數(shù)器默認(rèn)動(dòng)作的方式 window.event.returnValue = false } return false }) //阻止冒泡行為和默認(rèn)右鍵菜單事件 document.getElementById('myBiaoZhu').onmousedown=(e)=>{ e = e || window.event if(e.button !== 2){ //判斷是否右擊 if(this.canBiaoZhu){ //判斷是否可以進(jìn)行標(biāo)注 var x = e.offsetX || e.layerX var y = e.offsetY || e.layerY console.log(x,y) var myImg = document.querySelector("#myBiaoZhu") var currWidth = myImg.clientWidth var currHeight = myImg.clientHeight var ProportionWidthInImg = x/currWidth var ProportionHeightInImg = y/currHeight // console.log("圖片比例高度:"+ProportionHeightInImg) // console.log("圖片比例寬度:"+ProportionWidthInImg) this.banMa.push({ id:this.banMa.length+1, x, y }) this.createMarker(x,y) } } } }, beforeDestroy () { }, destroyed () { }, } </script>
以上為個(gè)人經(jīng)驗(yàn),希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。
- python實(shí)現(xiàn)簡(jiǎn)單圖片物體標(biāo)注工具
- 一款基于jQuery的圖片場(chǎng)景標(biāo)注提示彈窗特效
- 一款簡(jiǎn)單的jQuery圖片標(biāo)注效果附源碼下載
- Python tkinter實(shí)現(xiàn)圖片標(biāo)注功能(完整代碼)
- vue下如何利用canvas實(shí)現(xiàn)在線圖片標(biāo)注
- jquery.picsign圖片標(biāo)注組件實(shí)例詳解
- 在React中用canvas對(duì)圖片標(biāo)注的實(shí)現(xiàn)
- 微信小程序給圖片做動(dòng)態(tài)標(biāo)注的實(shí)例分享
相關(guān)文章
實(shí)例詳解Vue項(xiàng)目使用eslint + prettier規(guī)范代碼風(fēng)格
這篇文章主要介紹了Vue項(xiàng)目使用eslint + prettier規(guī)范代碼風(fēng)格,本文通過(guò)實(shí)例代碼給大家介紹的非常詳細(xì),需要的朋友可以參考下2018-08-08vue實(shí)現(xiàn)導(dǎo)航菜單和編輯文本的示例代碼
這篇文章主要介紹了vue實(shí)現(xiàn)導(dǎo)航菜單和編輯文本功能的方法,文中示例代碼非常詳細(xì),幫助大家更好的參考和學(xué)習(xí),感興趣的朋友可以了解下2020-07-07Vue項(xiàng)目打包到服務(wù)器后請(qǐng)求接口報(bào)錯(cuò)404的解決
這篇文章主要介紹了Vue項(xiàng)目打包到服務(wù)器后請(qǐng)求接口報(bào)錯(cuò)404的解決方案,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2023-05-05