在图片上进行标记

文章目录

    • 需求
    • 分析

需求

  1. 底图是一张图片,
  2. 要在图上做标记,
  3. 对标记的位置有交互行为
  4. 鼠标滚顶页面,标记位置不发生变化
  5. 页面发生缩放,标记位置不发生变化

分析

在这里插入图片描述

在这里插入图片描述

<template>
  <div
    v-loading="loading"
    class="point-map"
    element-loading-text="加载中..."
    element-loading-background="rgba(0, 0, 0, 0.5)"
    element-loading-spinner="el-icon-loading"
  >
    <div
      id="mapBox"
      class="map"
    >
      <el-tooltip
        v-for="(item,index) in layInfo.layoutPointList"
        :key="item.id"
        effect="dark"
        placement="top"
      >
        <!-- 内容 -->
        <div slot="content">
          <div
            v-for="(pointName, index) in item.info"
            :key="index"
          >
            <div v-if="index ==0">
              {{ item.name }}
            </div>
            {{ pointName || 暂无 }}
          </div>
        </div>

        <!-- 点 -->
        <div
          v-if="index < 8"
          class="point-box-lay"
          :style="{
            top: pointPosition[index].y,
            left: pointPosition[index].x,
          }"
          @click="handelClickPoint"
        >
          <div
            class="point"
            :style="{ background: '#23dd10'}"
          />
        </div>
      </el-tooltip></div>
  </div>
</template>
<script>
import { createRandomId } from '@/utils/myFunction'
export default {
  name: '',
  components: {},
  props: {
    layInfo: {
      type: Object,
      default: () => {
        return {}
      }
    }
  },
  data() {
    return {
      // layInfo: {
      //   layoutPointList: [{
      //     fontColor: '#fff',
      //     id: '1695966252142428162',
      //     x: '73.40%',
      //     y: '11.2%',
      //     nameList: ['key1:value1', 'key2:value2', 'key3:value3'] // 实时获取数据
      //   },
      //   {
      //     fontColor: '#fff',
      //     id: '1695966252142428162',
      //     nameList: ['CK002-ΔN', 'CK002-ΔE', 'CK002-ΔH'], // 实时获取数据
      //     x: '73.40%',
      //     y: '17.3%'
      //   }]
      // },
      rightMenu: false,
      loading: false,
      visible: false,

      defaultPointStyle: {
        x: '0%',
        y: '0%',
        placement: 'column',
        bgColor: '#1e90ff',
        fontColor: '#fff'
      },
      preview: '/api/fileEntity/common/preview?id=',
      createRandomId,
      srcList: [

      ],
      pointPosition: [
        {
          x: '73.40%',
          y: '17.3%'
        },
        {
          x: '73.40%',
          y: '11.2%'
        },
        {
          x: '31.40%',
          y: '13.3%'
        },
        {
          x: '26.40%',
          y: '11.2%'
        },
        {
          x: '13.40%',
          y: '18.3%'
        },
        {
          x: '43.40%',
          y: '14.2%'
        },
        {
          x: '31.40%',
          y: '17.3%'
        },
        {
          x: '76.40%',
          y: '11.2%'
        }
      ]
    }
  },
  computed: {
  },
  watch: {

  },
  created() { },
  mounted() {
    console.log(1001, this.layInfo)
  },
  beforeDestroy() { },
  methods: {
    // 点位点击
    handelClickPoint() {
      console.log(121312)
    }
  }
}
</script>
<style lang ="scss"  scoped>
#mapBox{
  background: url(1.png) 0% 0% / 100% 100% no-repeat;
}
.point-map {
  position: relative;
  width: 100%;
  height: 100%;
  overflow: auto;
  > .map {
    height: 100%;
    position: relative;
    > .point-box-lay {
      transform: scale(0.8);
      transition: transform 0.2s;
      user-select: none;
      position: absolute;
      display: flex;
      flex-direction: column;
      align-items: center;
      &:hover {
        cursor: pointer;
        transform: scale(1);
      }
      > .el-image {
        height: 50px;
        width: 30px;
      }
      > .point {
        border-radius: 50%;
        height: 14px;
        width: 14px;
        background: #0580e4;
      }
      > .data-box {
        font-weight: bold !important;
        letter-spacing: 1px;
        font-size: 12px;
        padding: 2px 4px;
        margin: 5px;
        line-height: 1.2em;
        border-radius: 4px;
        /* word-break: break-all; */
        word-wrap: break-word;
        background: #0580e4;
        color: white;
        > div {
          font-weight: bold !important;
        }
      }
    }
  }
}
.data-box-nodata {
  background: red !important;
  color: white !important;
  letter-spacing: 2px;
}
</style>

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:/a/452789.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

什么是智慧公厕?对公共厕所智能实时监测管理控制,城市管理更高效智能

公共厕所一直以来都是城市管理的难题之一&#xff0c;但随着智慧科技的发展和应用&#xff0c;智慧公厕成为了解决这一问题的利器。智慧公厕是一种信息化的新型公共厕所&#xff0c;通过全面感知平台实时监测公共厕所的使用状态&#xff0c;并将数据转化为可视、可算、可管的数…

读取txt文件并统计每行最长的单词以及长度

读取txt文件并统计每行最长的单词以及长度 题目 在 D:\\documant.txt 文本中,文件中有若干行英文文本,每行英文文本中有若干个单词&#xff0c;每个单词不会跨行出现每行至多包含100个字符,要求编写一个程序,处理文件,分析各行中的单词,找到每行中的最长单词&#xff0c;分别…

互联网剧本杀小程序,如何创新发展提高收益

近年来&#xff0c;剧本杀深受年轻人的喜欢&#xff0c;一度成为了大众的社交方式&#xff0c;剧本杀为年轻人提供了一个全新的娱乐游戏和社交为一体的模式。 不过随着剧本杀市场入局的人越来越多&#xff0c;市场的发展也迎来了“拐点”&#xff0c;剧本杀逐渐趋向高质量发展…

190基于matlab的tfrSTFT时频分布图

基于matlab的tfrSTFT时频分布图&#xff0c;计算时间序列的STFT时频分布图&#xff0c;得到瞬时频率。通过GUI可以调节图像的展示样式。程序已调通&#xff0c;可直接运行。 190 STFT时频分布图 瞬时频率 能量谱 (xiaohongshu.com)

openGauss使用BenchmarkSQL进行性能测试(上)

一、前言 本文提供openGauss使用BenchmarkSQL进行性能测试的方法和测试数据报告。 BenchmarkSQL&#xff0c;一个JDBC基准测试工具&#xff0c;内嵌了TPC-C测试脚本&#xff0c;支持很多数据库&#xff0c;如PostgreSQL、Oracle和Mysql等。 TPC-C是专门针对联机交易处理系统…

软考高项总结:第16章采购管理(一)

一、管理基础 1、项目采购管理包括从项目团队外部采购或获取所需产品、服务或成果的各个过程。例如合同、订购单、协议备忘录(MOA)和服务水平协议(SLA)。被授权采购项目所需货物、服务的人员可以是项目团队、管理层或组织采购部的成员。 2、协议可以是合同、服务水平协议(SL…

基于AM62X+FPGA/MCU的B码对时定制化整机解决方案

什么是IRIG-B码对时 IRIG-B(inter-range instrumentationgroup-B)码是一种时间同步标准&#xff0c;通常用于精确的时间测量和数据同步&#xff0c;广泛应用于电力、通信、航空等领域。 IRIG-B码为每秒一帧的时间串码&#xff0c;一帧串码中包含100个码元&#xff0c;频率为1K…

git svn混用

背景 项目代码管理初始使用的svn, 由于svn代码操作&#xff0c;无法在本地暂存&#xff0c;有诸多不便&#xff0c;另外本人习惯使用git. 所以决定迁移至git管理 迁移要求&#xff1a; 保留历史提交记录 迁移流程 代码检出 git svn svn_project_url git代码提交 修改本…

可回馈式直流电子负载原理是怎样的

可回馈式直流电子负载可以将电能回馈到电网中&#xff0c;从而实现对电源系统的测试和分析。其工作原理主要包括以下几个方面&#xff1a; 1. 能量转换&#xff1a;可回馈式直流电子负载通过内部的功率开关管将输入的直流电转换为交流电&#xff0c;然后通过变压器将电压升高或…

【阿里云系列】-部署ACK集群的POD应用日志如何集成到日志服务(SLS)中

介绍 我们在实际部署应用到阿里云的ACK集群后&#xff0c;由于后期应用服务的持续维护诉求可能需要跟踪排查问题&#xff0c;此时就要具备将应用的历史日志存档便于后期排查问题 处理方式 为了解决以上的普遍需求&#xff0c;需要将ACK中的应用日志采集到SLS的Logstore中,然…

SpringBoot实战项目——博客笔记项目

提示&#xff1a;文章写完后&#xff0c;目录可以自动生成&#xff0c;如何生成可参考右边的帮助文档 文章目录 前言一、项目介绍二、项目的整体框架 2.1 数据库模块 2.2 前端模块 2.3 后端模块三、项目图片展示四、项目的实现 4.1 准备工作 4.…

HarmonyOS-页面跳转Router实例演示

本文将以APP的登录和修改昵称为例演示官网的几种页面跳转、返回以及这些流程携带参数&#xff0c;实例的形式记录学习HarmonyOS的页面跳转。 “页面路由指在应用程序中实现不同页面之间的跳转和数据传递。HarmonyOS提供了Router模块&#xff0c;通过不同的url地址&#xff0c;…

47、C++/引用,函数重载,类相关学习20240312

一、自己封装一个矩形类(Rect)&#xff0c;拥有私有属性:宽度(width)、高度(height)&#xff0c; 定义公有成员函数: 初始化函数:void init(int w, int h) 更改宽度的函数:set_w(int w) 更改高度的函数:set_h(int h) 输出该矩形的周长和面积函数:void show()。 代码&…

在 Rust 中使用 Serde 处理json

在 Rust 中使用 Serde 处理json 在本文中&#xff0c;我们将讨论 Serde、如何在 Rust 应用程序中使用它以及一些更高级的提示和技巧。 什么是serde&#xff1f; Rust中的serde crate用于高效地序列化和反序列化多种格式的数据。它通过提供两个可以使用的traits来实现这一点&a…

数字孪生+工业互联网标识解析,打造智能工厂新标杆!

当前&#xff0c;工业4.0浪潮愈发澎湃&#xff0c;加快数字化、网络化、智能化发展成为了制造业转型升级的必然要求。 51WORLD基于数字孪生技术与工业互联网标识解析体系&#xff0c;打造了一个集协同化供应、个性化定制、智能化生产于一体的全连接产线孪生平台&#xff08;以…

AndroidStudio设计登录页源码(音悦app)

目录 一、代码 二、效果 一、代码 1.在activity_main.xml里的代码 <?xml version"1.0" encoding"utf-8"?> <LinearLayout xmlns:android"http://schemas.android.com/apk/res/android"android:layout_width"match_parent&quo…

(一)RabbitMQ实战——rabbitmq的核心组件及其工作原理介绍

前言 RabbitMQ是一个开源的消息代理软件&#xff0c;它实现了高级消息队列协议&#xff08;AMQP&#xff09;标准&#xff0c;提供可靠的消息传递机制。RabbitMQ可以用于在应用程序之间传递消息&#xff0c;实现不同应用系统之间的解耦和通信。它支持多种编程语言&#xff0c;…

11.Java---语法总结之一个小项目

图书管理系统 Java学习了很久了,今天将运用之前学习的所有东西整理做个小小的小项目. 1.首先是各种包和操作方法建好 2.然后是项目的大框架搭好 3.然后就开始实现各个部分了 看看最后的运行结果吧! 管理员测试 1.登录&显示图书的运行结果 2.查找&新增图书的运行结…

C goto 语句

C 语言中的 goto 语句允许把控制无条件转移到同一函数内的被标记的语句。 注意&#xff1a;在任何编程语言中&#xff0c;都不建议使用 goto 语句。因为它使得程序的控制流难以跟踪&#xff0c;使程序难以理解和难以修改。任何使用 goto 语句的程序可以改写成不需要使用 goto 语…

安卓逆向 安装frida

1,准备工作 安装adb环境,python最高支持到3.8 2,下载雷电模拟器5.0(安卓是7.0)要64位的 雷电安卓模拟器-手游模拟器安卓版_android手机模拟器电脑版_雷电模拟器官网 3,下载frida服务端(版本要与安卓版本匹配;与客户端版本要一致) 在模拟器查看架构 adb shell getprop ro.pr…