当前位置: 首页 > news >正文

vue3+openLayers点击标记事件

<template><!--地图--><div class="distributeMap" id="distributeMap"></div>
</template>
<script lang="ts" setup>
import { onMounted, reactive } from "vue";
import { Feature, Map, View } from "ol";
import OSM from "ol/source/OSM";
import "ol/ol.css";
import TileLayer from "ol/layer/Tile";
import XYZ from "ol/source/XYZ";
import { fromLonLat } from "ol/proj";
import { Point } from "ol/geom";
import CircleStyle from "ol/style/Circle";
import { Fill, Icon, Style } from "ol/style";
import VectorSource from "ol/source/Vector";
import VectorLayer from "ol/layer/Vector";const state = reactive({map: null as any,
});
/*** 模块名:初始化地图* 代码描述:* 作者:Fant* 创建时间:2024/07/19 16:03:21*/
const getMap = () => {let layer = new TileLayer({source: new XYZ({url: 'http://t4.tianditu.com/DataServer?T=vec_w&tk=4a76fd399e76e3e984e82953755c3410&x={x}&y={y}&l={z}',}),});state.map = new Map({target: 'olmap',layers: [layer],view: new View({projection: 'EPSG:4326', //使用WGS 84坐标系center: [114.31, 30.62048],zoom: 12,}),});
};
/*** 模块名:添加点标记* 代码描述:* 作者:Fant* 创建时间:2024/07/20 15:59:48*/
const mapPoint = () => {// 创建点特征const pointFeature = new Feature({name: "点位",id: 1,geometry: new Point([114.31, 30.62048]),});//创建stylepointFeature.setStyle(new Style({image: new Icon({src: "https://smart-garden-manage.oss-cn-chengdu.aliyuncs.com/shexiangtou.png",scale: 0.3, //图片大小比例}),}));// 创建矢量图层const vectorSource = new VectorSource({features: [pointFeature], // 添加点特征到图层});const vectorLayer = new VectorLayer({source: vectorSource,});state.map.addLayer(vectorLayer);
};
/*** 模块名:点击icon事件* 代码描述:* 作者:Fant* 创建时间:2024/07/23 20:15:50*/
const iconClick = () => {state.map.on("singleclick", (e: any) => {console.log(e);let point = state.map.forEachFeatureAtPixel(e.pixel,(feature: any) => feature) as any;//如果没有点击到标记 这里会打印出undefinedconsole.log(point);if (point) {let params = point.getProperties();console.log("当前标点参数", params);}});
};
onMounted(() => {getMap();mapPoint();iconClick();
});
</script>
<style lang="scss" scoped>
@import url("./style.scss");
</style>

在这里插入图片描述
在这里插入图片描述

http://www.lryc.cn/news/406471.html

相关文章:

  • 深入分析 Android ContentProvider (三)
  • 养宠浮毛异味双困扰?性价比高的宠物空气净化器推荐
  • maven项目容器化运行之3-优雅的利用Jenkins和maven使用docker插件调用远程docker构建服务并在1Panel中运行
  • docker 打包orbbec
  • 无涯·问知财报解读,辅助更加明智的决策
  • 【Apache Doris】数据副本问题排查指南
  • 【HarmonyOS】关于鸿蒙消息推送的心得体会(二)
  • 零基础入门:创建一个简单的Python爬虫管理系统
  • 【Node.js基础04】node.js模块化
  • 数据库——单表查询
  • dsa加训
  • SpringBoot源码(1)ApplicationContext和BeanFactory
  • CANoe编程实例--TCP/IP通信
  • Neuron协议网关的北向应用插件开发
  • 【BUG】已解决:You are using pip version 10.0.1, however version 21.3.1 is available.
  • electron-builder打包vue2项目不显示element-ui图标
  • controller层-请求格式为json-请求方法为get
  • 【Linux】网络通信基础:应用层协议、HTTP、序列化与会话管理
  • @NotNull、@NotEmpty 和 @NotBlank 区别
  • 大模型应用—大模型赋能网络爬虫
  • 在 Qt 中获取 MouseMove 事件
  • 自动驾驶系列—智能巡航辅助功能中的路口通行功能介绍
  • 如何为WordPress网站设置多语言站点
  • 【RHCE】综合真机实验(shell完成)
  • 【Python】成功解决conda创建虚拟环境时出现的CondaHTTPError: HTTP 000 CONNECTION FAILED错误
  • 苹果笔记本电脑如何优化系统 苹果电脑系统优化软件哪个好 cleanmymac x怎么用
  • Vue数组操作之sort详解
  • 解决 Android 应用安装错误:INSTALL_FAILED_BAD_PERMISSION_GROUP
  • 浅谈断言之JSON断言
  • 【学习笔记】无人机系统(UAS)的连接、识别和跟踪(四)-无人机认证与授权