iis服务器助手广告广告
返回顶部
首页 > 资讯 > 精选 >vue怎么使用js对图片进行点击标注圆点并记录它的坐标
  • 271
分享到

vue怎么使用js对图片进行点击标注圆点并记录它的坐标

2023-06-30 11:06:54 271人浏览 薄情痞子
摘要

这篇文章主要介绍“Vue怎么使用js对图片进行点击标注圆点并记录它的坐标”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“vue怎么使用js对图片进行点击标注圆点并记录它的坐标”文章能帮助大家解决问题。

这篇文章主要介绍“Vue怎么使用js对图片进行点击标注圆点并记录它的坐标”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“vue怎么使用js对图片进行点击标注圆点并记录它的坐标”文章能帮助大家解决问题。

功能

  • 点击开始标注按钮后才可以对图片进行标注

  • 在图片区域内单机左键才可进行加点

  • 在标注点上右击删除该点,在图片上右击无效果

  • 完成标注后点击完成标注按钮后,结束标注,此后点击图片不再加点

标注前

vue怎么使用js对图片进行点击标注圆点并记录它的坐标

标注后

vue怎么使用js对图片进行点击标注圆点并记录它的坐标

打印记录坐标点

这个坐标看你自己需求,是相对图片的百分比坐标,还是相对整个窗口的坐标,js都可以实现的

vue怎么使用js对图片进行点击标注圆点并记录它的坐标

代码实现

我先说一说关键功能实现的js代码(里面涉及了date的数据,所以需要看下后面的全部代码实现),后面就是全部代码

判断鼠标是否右击

if(e.button !== 2)       //判断鼠标是否右击

阻止冒泡行为和默认右键菜单事件

document.getElementById('myBiaoZhu').oncontextmenu=((e)=>{        if(e && e.preventDefault) {          //阻止默认浏览器动作(W3C)          e.preventDefault()        } else {          //IE中阻止函数器默认动作的方式          window.event.returnValue = false        }        return false      })      //阻止冒泡行为和默认右键菜单事件

给图片加点击事件

document.getElementById('myBiaoZhu').onmousedown=(e)=>{        e = e || window.event        if(e.button !== 2){       //判断是否右击          if(this.canBiaoZhu){    //判断是否可以进行标注            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)          }        }      }

画点

  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) {        //阻止默认浏览器动作(W3C)        e.preventDefault()      } else {        //IE中阻止函数器默认动作的方式        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="" >    <el-button type="text" @click="startBiaoZhu">开始标注</el-button>    <el-button type="text" @click="endBiaoZhu">标注完成</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:[],           //斑马线的数组        canBiaoZhu:false,  //是否可以进行标注        pointColor:'red',   //点的颜色        pointSize:10,       //点的大小      }    },    methods: {      //开始标注      startBiaoZhu(){        this.canBiaoZhu = true      },      //完成标注      endBiaoZhu(){        this.canBiaoZhu = false      },      //画点      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) {            //阻止默认浏览器动作(W3C)            e.preventDefault()          } else {            //IE中阻止函数器默认动作的方式            window.event.returnValue = false          }          return false        })  //阻止冒泡行为和默认右键菜单事件,删除该点        document.getElementById('myBiaoZhuDiv').appendChild(div)      },    },    watch: {},    computed: {},    created () {    },    mounted () {      document.getElementById('myBiaoZhu').oncontextmenu=((e)=>{        if(e && e.preventDefault) {          //阻止默认浏览器动作(W3C)          e.preventDefault()        } else {          //IE中阻止函数器默认动作的方式          window.event.returnValue = false        }        return false      })      //阻止冒泡行为和默认右键菜单事件      document.getElementById('myBiaoZhu').onmousedown=(e)=>{        e = e || window.event        if(e.button !== 2){       //判断是否右击          if(this.canBiaoZhu){    //判断是否可以进行标注            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>

关于“vue怎么使用js对图片进行点击标注圆点并记录它的坐标”的内容就介绍到这里了,感谢大家的阅读。如果想了解更多行业相关的知识,可以关注编程网精选频道,小编每天都会为大家更新不同的知识点。

--结束END--

本文标题: vue怎么使用js对图片进行点击标注圆点并记录它的坐标

本文链接: https://www.lsjlt.com/news/328369.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • c语言怎么保证除完还是小数
    在 c 语言中,整数除法只能得到整数结果,要得到小数结果,需将操作数显式转换为浮点数:将一个操作数转换为浮点数,如 float result = num1 / (float)num2;将...
    99+
    2024-05-14
    c语言
  • c语言怎么让结尾不输出空行字符
    要阻止 c 语言程序结尾输出空行字符,可以使用以下方法:将 main 函数的返回值类型改为 void;在 main 函数中显式返回 0;调用 fflush(stdout) 函数刷新标准输...
    99+
    2024-05-14
    c语言
  • c语言怎么让结尾不输出空行数据
    在 c 语言中,可通过以下方法抑制 printf() 函数在程序结束时打印末尾空行:调用 fflush() 函数刷新缓冲区,立即输出所有数据;使用 setvbuf() 函数关闭缓冲,使数...
    99+
    2024-05-14
    c语言
  • c语言怎么让结尾无空行
    在 c 中去除结尾空行的方法:使用 fflush() 刷新缓冲区。使用 setvbuf() 将缓冲模式设置为 _ionbf。使用 printf 宏,它默认禁用缓冲。 如何在 C 语言中...
    99+
    2024-05-14
    c语言
  • c语言怎么输入实数赋值
    c语言中使用scanf()函数输入实数并赋值给变量:格式:scanf("%lf", &amp;variable);%lf是格式说明符,指定输入双精度浮点数;&...
    99+
    2024-05-14
    c语言
  • c语言怎么表达负数
    c语言中,负数以减号 (-) 表示,放在数字或变量前。负数运算规则包括:绝对值取正数;加正数或负数,结果取决于绝对值大小;乘或除以正数或负数,结果由符号奇偶性决定。负数的平方始终为正数,...
    99+
    2024-05-14
    c语言
  • c语言怎么输入Jac数列
    jacobi 数列的输入和生成方法分别有:1. 直接输入法:使用 scanf() 函数逐项输入数列。2. 递归生成法:使用递归公式生成数列,需初始化数列的前两项,然后按公式生成后续项。 ...
    99+
    2024-05-14
    c语言
  • c语言怎么把数组变成字符串
    在 c 语言中,将数组转换成字符串的方法包括:使用 sprintf() 将数组格式化为字符串。使用 strcpy() 将数组复制到字符串。使用 strncpy() 将指定长度的数组复制到...
    99+
    2024-05-14
    c语言
  • c语言怎么批量注释
    批量注释 c 语言代码的方法有:使用代码编辑器:使用快捷键或菜单命令自动添加 // 注释符号。使用注释工具:如 doxygen 和 cutter,批量添加行注释、块注释和文档注释。使用脚...
    99+
    2024-05-14
    python sublime c语言
  • c语言怎么把选中的全部注释
    c语言中注释选中内容可通过以下步骤实现:选中要注释的代码。根据使用的编辑器或ide,执行注释操作,例如在visual studio中右键单击并选择“注释所选内容”。添加注释内容。保存更改...
    99+
    2024-05-14
    sublime c语言
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作