当前位置:网站首页>svg+元素js实现在图片上描点成框,并获取相对图片的坐标位置
svg+元素js实现在图片上描点成框,并获取相对图片的坐标位置
2022-08-10 20:19:00 【SunFlower914】
首先大家需要了解下获取到x轴与y轴坐标有哪些方法:
e.offsetX:鼠标相对于事件源的X方向的距离( firfox 不支持)
e.offsetY:鼠标相对于事件源的Y方向的距离( firfox 不支持)
e.clientX:距离浏览器可视区域X方向的距离
e.clientY:距离浏览器可视区域Y方向的距离
e.pageX:鼠标相对于文档X方向的距离( ie678 不支持)
e.pageY:鼠标相对于文档X方向的距离( ie678 不支持)
e.screenX:鼠标距离屏幕X方向的距离
e.screenY:鼠标距离屏幕Y方向的距离(包含浏览器的地址栏)
svg实现效果:
svg代码:
1.结构上,可以将svg与img保持同样大小,通过absolute定位到img上面
<div class="box">
<img src="./plant-1.png" style="width:100%">
<svg id="svg" width="100%" height="100%">
<polyline id="polygon" points="" marker style="fill:transparent; stroke: #e07cc2; stroke-width:3px;">
</polyline>
</svg>
</div>
<button id="back">回退</button>
<button id="clear">清除</button>2.侦听svg的click事件,通过createSVGPoint方法创建svg坐标对象,计算鼠标点击在svg图片的相对位置,当鼠标点击到第四个点时,通过appendItem将第一个点坐标添加到points中,形成闭合矩形框效果
<script>
const clear = document.getElementById('clear')
const back = document.getElementById('back')
const polygon = document.getElementById('polygon')
let firstPoint = null, index = 0
svg.addEventListener('click', (e) => {
if (index > 4) return;
var point = svg.createSVGPoint();
point.x = e.offsetX;
point.y = e.offsetY;
if (!firstPoint) {
firstPoint = point
}
polygon.points.appendItem(point)
console.log(polygon.points,'polygon.points');
index++
if (index === 4) {
polygon.points.appendItem(firstPoint) && index++
}
console.log(polygon.points, point, 'point');
})
clogging.addEventListener('click', (e) => {
firstPoint && polygon.points.appendItem(firstPoint) && index++
clogging.disabled = true
})
back.addEventListener('click', (e) => {
index-- && polygon.points.removeItem(index)
clogging.disabled = false
})
clear.addEventListener('click', (e) => {
polygon.points.clear()
index = 0
clogging.disabled = false
})
</script>原生js实现效果:

原生代码:
1.以浏览器文档作为对象确认点的定位位置,计算图片到浏览器可视窗口的位置
相对图片位置 = 到浏览器可视窗口位置 - 图片到浏览器可视窗口位置
x = e.clientX - img.getBoundingClientRect().left + 'px'
<style>
* {
margin: 0;
top: 0;
}
#div {
margin-top: 50px;
}
img {
border: 1px dashed red;
margin-top: 50px;
margin-left: 100px;
}
.dot {
width: 5px;
height: 5px;
position: absolute;
border-radius: 5px;
background-color: red;
}
</style>
</head>
<body>
<div id="div"><img src="./plant-1.png" alt="" id="avater"></div>
<script>
var img = document.getElementById('avater')
var div = document.getElementById('div')
let num = 0
img.addEventListener('click', (e) => {
//这里考虑到用户会竖向滚动页面,所以要实时获取图片到可视窗口位置
let x = e.clientX - img.getBoundingClientRect().left + 'px' //相对于图片的X
let y = e.clientY - img.getBoundingClientRect().top + 'px' //相对于图片的Y
console.log(x,y);
// 页面不超过4个点
num++
if(num>4) {
return;
}
// 鼠标到body距离
let dot = document.createElement('div')
dot.className = 'dot'
// 圆点定位到相对于body的位置
dot.style.left = e.pageX +'px'
dot.style.top = e.pageY+'px'
document.body.append(dot)
})
</script>
</body>以上两种方法均可以完成记录相对于图片的坐标位置,同时支持回退操作
边栏推荐
- 【图像分类】2017-MobileNetV1 CVPR
- The 2021 ICPC Asia Shanghai Regional Programming Contest D、E
- C语言详解系列——关于调试那些事
- idea汉化教程[通俗易懂]
- Transferrin-modified osthole long-circulating liposomes/PEG-PLGA nanoparticles loaded with notoginsenoside R1 ([email prot
- UE4 - 河流流体插件Fluid Flux
- 《分布式微服务电商》专题(一)-项目简介
- MySQL数据库的主从复制部署详解
- 史上最全GIS相关软件(CAD、FME、Arcgis、ArcgisPro)
- The servlet mapping path matching resolution
猜你喜欢

测试/开发程序员值这么多钱么?“我“不会愿赌服输......
壁仞推出全球最大算力芯片,号称以7nm超越英伟达4nm最新GPU
[email protected] nanomimetic e"/>Water-soluble alloy quantum dot nanozymes|CuMoS nanozymes|porous silicon-based Pt(Au) nanozymes|[email protected] nanomimetic e

Demis Hassabis:AI 的强大,超乎我们的想象

烟雾、空气质量、温湿度…自己徒手做个环境检测设备

电脑为什么会蓝屏的原因

转铁蛋白(Tf)修饰去氢骆驼蓬碱磁纳米脂质体/香豆素-6脂质体/多柔比星脂质体

一次由groovy引起的fullGC问题排查

(十二) findContours函数的hierarchy详解

电信保温杯笔记——《统计学习方法(第二版)——李航》第17章 潜在语义分析
随机推荐
史上最全GIS相关软件(CAD、FME、Arcgis、ArcgisPro)
【毕业设计】基于STM32的天气预报盒子 - 嵌入式 单片机 物联网
30分钟使用百度EasyDL实现健康码/行程码智能识别
怎么完全卸载赛门铁克_Symantec卸载方法,赛门铁克卸载「建议收藏」
重载和重写
@Autowired annotation --required a single bean, but 2 were found causes and solutions
Demis Hassabis:AI 的强大,超乎我们的想象
铁蛋白-AHLL纳米颗粒|人表皮生长因子-铁蛋白重链亚基纳米粒子(EGF-5Cys-FTH1)|铁蛋白颗粒包载氯霉素Chloramphenicol-Ferritin
苹果字体查找
巧用RoaringBitMap处理海量数据内存diff问题
Echart饼状图标注遮盖解决方案汇总
1D Array Dynamics and Question Answers
转铁蛋白(TF)修饰紫杉醇(PTX)脂质体(TF-PTX-LP)|转铁蛋白(Tf)修饰姜黄素脂质体
论文解读(g-U-Nets)《Graph U-Nets》
【SemiDrive源码分析】【MailBox核间通信】52 - DCF Notify 实现原理分析 及 代码实战
力扣150-逆波兰表达式求值——栈实现
【CMU博士论文】视频多模态学习:探索模型和任务复杂性,152页pdf
【LeetCode】42、接雨水
"POJ 3666" Making the Grade problem solution (two methods)
YOLOv3 SPP source analysis