悬浮坐标解决方案:如何在图片获取xy鼠标位置和增加标注信息
创始人
2024-01-13 04:41:31

在这里插入图片描述
悬浮坐标的定义,基于固定分辨率的图片,通过获取该图片x和y坐标确定位置后并添加标注,实现位置展示、对应图片内物品展示的一种标注开发方式。

技术要点

  1. 自动获取图片x和y坐标;
  2. 将多个坐标xy在图片上通过CSS定位的方式予以展示;
  3. 鼠标高亮提示事件;
  4. 鼠标点击事件;

css层叠样式表

  • 由于不同电脑设备的分辨率不同,因此在使用图片悬浮坐标定位的时候,一般需要将图片设置成固定尺寸。基于19201080,16:9分辨率显示器,一般推荐1600900的弹窗展示。
  • 为了避免弹出图片无法覆盖,建议设置对应的背景颜色;
  • 实现原理:基于css层叠样式表各元素利用position: relative和position:absolute,相对定位和绝对定位,分层分级加载展示。
        .container {position: relative;width: 1600px;margin: 0 auto;padding: 0;}.lockImg {position: absolute;cursor: pointer;}

HTML图片容器展示

  • style="left:calc(76px - 16px);top:calc(158px - 36px),因标注icon本身是图片,具有长宽属性,在进行absolute定位时,需要把已经确定的xy坐标进行相对应的offset偏离设置;
  • offset中的16px和36px,具体的值依据icon图片的尺寸大小手动调整,能准确标识对应的图片位置即可。

获取图片xy坐标

在这里插入图片描述

(1)JQ封装函数方式

图片事件

   

获取坐标封装函数

    //获取鼠标点击位置function lockClick(e) {var xPage = (navigator.appName == 'Netscape') ? e.pageX : event.x + document.body.scrollLeft;var yPage = (navigator.appName == 'Netscape') ? e.pageY : event.y + document.body.scrollTop;var imgEl = document.getElementById("imageId");var img_x = locationLeft(imgEl);var img_y = locationTop(imgEl);var xPos = xPage - img_x;var yPos = yPage - img_y;//当前点击位置var hotspot = {x: xPos, y: yPos};/*01.在当前为准展示图片*/addHotspot(hotspot);/*02.通过ajax接口将x、y坐标传入到数据库*/}
  //找到元素的屏幕位置function locationLeft(element) {offsetTotal = element.offsetLeft;scrollTotal = 0; //element.scrollLeft but we dont want to deal with scrolling - already in page coordsif (element.tagName != "BODY") {if (element.offsetParent != null)return offsetTotal + scrollTotal + locationLeft(element.offsetParent);}return offsetTotal + scrollTotal;}//find the screen location of an elementfunction locationTop(element) {offsetTotal = element.offsetTop;scrollTotal = 0; //element.scrollTop but we dont want to deal with scrolling - already in page coordsif (element.tagName != "BODY") {if (element.offsetParent != null)return offsetTotal + scrollTotal + locationTop(element.offsetParent);}return offsetTotal + scrollTotal;}
    // 添加自定义内容function addHotspot(hotspot) {var x = hotspot.x - 16;var y = hotspot.y - 36;var src = 'images/icon.png';var imgEle = '';$('.container').append(imgEle);}

(2)使用php中的POST传参

使用input image类型传参

    

getCoords.php

$cord = $_POST;
echo "
";
echo "x坐标:" . $cord["x"];
echo "
";
echo "y坐标:" . $cord["y"];

@漏刻有时

相关内容

热门资讯

苗族的传统节日 贵州苗族节日有... 【岜沙苗族芦笙节】岜沙,苗语叫“分送”,距从江县城7.5公里,是世界上最崇拜树木并以树为神的枪手部落...
世界上最漂亮的人 世界上最漂亮... 此前在某网上,选出了全球265万颜值姣好的女性。从这些数量庞大的女性群体中,人们投票选出了心目中最美...
猫咪吃了塑料袋怎么办 猫咪误食... 你知道吗?塑料袋放久了会长猫哦!要说猫咪对塑料袋的喜爱程度完完全全可以媲美纸箱家里只要一有塑料袋的响...
长白山自助游攻略 吉林长白山游... 昨天介绍了西坡的景点详细请看链接:一个人的旅行,据说能看到长白山天池全凭运气,您的运气如何?今日介绍...
应用未安装解决办法 平板应用未... ---IT小技术,每天Get一个小技能!一、前言描述苹果IPad2居然不能安装怎么办?与此IPad不...
脚上的穴位图 脚面经络图对应的... 人体穴位作用图解大全更清晰直观的标注了各个人体穴位的作用,包括头部穴位图、胸部穴位图、背部穴位图、胳...
demo什么意思 demo版本... 618快到了,各位的小金库大概也在准备开闸放水了吧。没有小金库的,也该向老婆撒娇卖萌服个软了,一切只...
阿西吧是什么意思 阿西吧相当于... 即使你没有受到过任何外语培训,你也懂四国语言。汉语:你好英语:Shit韩语:阿西吧(아,씨발! )日...
北京的名胜古迹 北京最著名的景... 北京从元代开始,逐渐走上帝国首都的道路,先是成为大辽朝五大首都之一的南京城,随着金灭辽,金代从海陵王...
苗族的传统节日 贵州苗族节日有... 【岜沙苗族芦笙节】岜沙,苗语叫“分送”,距从江县城7.5公里,是世界上最崇拜树木并以树为神的枪手部落...
长白山自助游攻略 吉林长白山游... 昨天介绍了西坡的景点详细请看链接:一个人的旅行,据说能看到长白山天池全凭运气,您的运气如何?今日介绍...
猫咪吃了塑料袋怎么办 猫咪误食... 你知道吗?塑料袋放久了会长猫哦!要说猫咪对塑料袋的喜爱程度完完全全可以媲美纸箱家里只要一有塑料袋的响...
应用未安装解决办法 平板应用未... ---IT小技术,每天Get一个小技能!一、前言描述苹果IPad2居然不能安装怎么办?与此IPad不...
脚上的穴位图 脚面经络图对应的... 人体穴位作用图解大全更清晰直观的标注了各个人体穴位的作用,包括头部穴位图、胸部穴位图、背部穴位图、胳...
阿西吧是什么意思 阿西吧相当于... 即使你没有受到过任何外语培训,你也懂四国语言。汉语:你好英语:Shit韩语:阿西吧(아,씨발! )日...
demo什么意思 demo版本... 618快到了,各位的小金库大概也在准备开闸放水了吧。没有小金库的,也该向老婆撒娇卖萌服个软了,一切只...
世界上最漂亮的人 世界上最漂亮... 此前在某网上,选出了全球265万颜值姣好的女性。从这些数量庞大的女性群体中,人们投票选出了心目中最美...
北京的名胜古迹 北京最著名的景... 北京从元代开始,逐渐走上帝国首都的道路,先是成为大辽朝五大首都之一的南京城,随着金灭辽,金代从海陵王...
北京的名胜古迹 北京最著名的景... 北京从元代开始,逐渐走上帝国首都的道路,先是成为大辽朝五大首都之一的南京城,随着金灭辽,金代从海陵王...
苗族的传统节日 贵州苗族节日有... 【岜沙苗族芦笙节】岜沙,苗语叫“分送”,距从江县城7.5公里,是世界上最崇拜树木并以树为神的枪手部落...