openlayers动态加自定义div图层 并且具有筛选功能 和浮窗效果,代码拿过去就可以用

联系方式:45664741@qq.com
个人博客: flot.top

效果图:

<!DOCTYPE html>
<html lang="en"><head><meta charset="UTF-8" /><meta http-equiv="X-UA-Compatible" content="IE=edge" /><meta name="viewport" content="width=device-width, initial-scale=1.0" /><title>Document</title><linkcrossorigin="anonymous"integrity="sha384-iYkPgcf1wF1oXt3CosKxNMQJgQUC60vjUJM+HANnq9ULJXg8DLX/ywPXMZHto90Q"href="https://lib.baomitu.com/ol3/4.6.5/ol.css"rel="stylesheet"/><scriptcrossorigin="anonymous"integrity="sha384-207r7vJ98mMvHGcgRttnhkJLl6RU+DuD+ttp1G5k4ShCtw03LfZIIDNNWDGU8m2F"src="https://lib.baomitu.com/ol3/4.6.5/ol.js"></script><scriptcrossorigin="anonymous"integrity="sha384-6ePHh72Rl3hKio4HiJ841psfsRJveeS+aLoaEf3BWfS+gTF0XdAqku2ka8VddikM"src="https://lib.baomitu.com/jquery/1.11.3/jquery.min.js"></script><style>#map {width: 1200px;height: 700px;position: absolute;}.my-map-overlay {width: 100px;height: 100px;/* border: 1px solid; */}.my-map-overlay-tag {width: 100px;height: 100px;background: url("")no-repeat;animation: identifier steps(4) 1s infinite;}#map-overlay-info {background: #fff;position: absolute;border-radius: 4px;display: none;padding: 10px;z-index: 1;}#map-overlay-info .info-shape {position: absolute;top: 0.5em;border: 1px solid #fff;height: 0;width: 0;border-left: 4px solid transparent;border-right: 4px solid #fff;border-top: 3px solid transparent;border-bottom: 3px solid #fff;left: -8px;}@keyframes identifier {0% {background-position: 0px 0;}100% {background-position: -400px 0;}}</style></head><body><input type="text" id="myInput" oninput="handleInput()" />根据名称筛选<div id="map"></div><script>var option = {map: null,overlayItem: {},list: [],// 初始化地图initMap() {const osm = new ol.layer.Tile({source: new ol.source.OSM(),});// 切片方式加载地图const tiled = new ol.layer.Tile({// visible: false,source: new ol.source.TileWMS({url: "https://ahocevar.com/geoserver/wms",params: { LAYERS: "topp:states", TILED: true },serverType: "geoserver",// Countries have transparency, so do not fade tiles:transition: 0,}),});const map = new ol.Map({target: "map",layers: [osm, tiled],view: new ol.View({center: [-10997148, 4569099],zoom: 4,}),});this.map = map;},// 新增自定义图层mapAddOverlay() {// 创建div的函数function createDiv({ id, status, statusType }, index) {// 创建一个div元素var elementDiv = document.createElement("div");elementDiv.className = "my-map-overlay";elementDiv.innerHTML = `<div class='my-map-overlay-tag ${formatInfoClass(status)}'><span class='my-map-overlay-status'>${status === "故障" ? statusType : status}${id}</span></div>`;// 设置div元素的cid属性elementDiv.setAttribute("myid", id);return elementDiv;}// 根据状态 加载对应的类名function formatInfoClass(status) {var className = "";switch (status) {case "工作中":className = "green";break;case "未使用":className = "gray";break;case "故障":className = "red";break;}return className;}// 循环创建循环覆盖层this.list.forEach((item, index) => {// 新建一个覆盖层var newMarker = new ol.Overlay({// 设置位置为当前节点的坐标position: [item.lon, item.lat],// 设置覆盖层与位置之间的匹配方式positioning: "bottom-left",// 偏移量  默认值是 [0, 0] 正值分别向右和向下偏移// offset: [-50, 20],// 覆盖层元素element: createDiv(item, index),// 事件传播到地图视点的时候是否应该停止stopEvent: false,});this.map.addOverlay(newMarker);});// 自定义div列表const domlist = document.getElementsByClassName("my-map-overlay");this.mapOverlayOver(domlist);},/** mapRemoveLayer* @function  删除自定义div图层*/mapRemoveOverlays() {this.map.getOverlays().clear();},/*** 监听地图自定义图层的单击/移入/移出事件* @function mapOverlayOver* @param {Array} domlist  元素列表*/mapOverlayOver(domlist) {Array.from(domlist).forEach((item) => {// 鼠标点击事件item.addEventListener("click", (e) => {const ev = e || window.event;const target = ev.path.filter(({ className }) => className === "my-map-overlay")[0];// // 获取在div上设置的myidconst myid = target.getAttribute("myid");this.setMapZoomCenter(myid);});// 鼠标移入事件 创建浮窗item.addEventListener("mouseenter", (e) => {const ev = e || window.event;const target = ev.target || ev.srcElement;// 获取在div上设置的myidconst myid = target.getAttribute("myid");// 在设备列表筛选符合条件的对象赋值const overlayItem = this.list.filter(({ id }) => id === myid);this.overlayItem = overlayItem[0];// getBoundingClientRect用于获取元素相对于视窗的位置集合const { top, left } = target.getBoundingClientRect();this.addTootipDom(top + 30, left + 100);});// 鼠标移出事件 删除浮窗item.addEventListener("mouseleave", (e) => {this.removeTootipDom();// mapOverlayInfo.setAttribute("style", "display: none");});});},/*** 设置地图的中心点和放大倍数* @function setMapZoomCenter* @param {String} ItemId  设备id*/setMapZoomCenter(ItemId) {const overlayItem = this.list.filter(({ id }) => ItemId === id);this.map.getView().animate({center: [overlayItem[0].lon, overlayItem[0].lat],duration: 800,zoom: 6,});},addTootipDom(top, left) {// const mapOverlayInfo = document.getElementById("map-overlay-info");// if (mapOverlayInfo) {//   mapOverlayInfo.parentNode.removeChild(mapOverlayInfo);// }const parentDom = document.getElementById("map");const childDom = document.createElement("div");childDom.setAttribute("id", "map-overlay-info");childDom.innerHTML = `<div class="info-shape"></div><p>名称:${this.overlayItem.stationName}</p><p>状态:${this.overlayItem.status}</p><p>故障名称:${this.overlayItem.statusType}</p>`;childDom.setAttribute("style",`top: ${top}px; left: ${left}px; display: block`);parentDom.appendChild(childDom);},// 删除自 浮窗removeTootipDom() {const mapOverlayInfo = document.getElementById("map-overlay-info");mapOverlayInfo.parentNode.removeChild(mapOverlayInfo);},};// 添加浮窗option.initMap();option.mapAddOverlay();handleInput();// 筛选值发生变化function handleInput() {const val = document.getElementById("myInput").value;const list = [{Type: "客厅",lat: 5925601.900570343,lon: -13109428.402459577,stationName: "598客厅1",id: "kt-1",status: "工作中",},{Type: "客厅",lat: 6024213.9906833647,lon: -11040972.000962155,stationName: "598客厅2",id: "kt-2",status: "工作中",},{Type: "客厅",lat: 5058323.196052412,lon: -13293746.428576976,stationName: "598客厅3",id: "kt-3",status: "工作中",},{Type: "客厅",lat: 4893844.222583916,lon: -13195443.525842169,stationName: "598客厅4",id: "kt-4",status: "工作中",},{Type: "客厅",lat: 5008981.7571222,lon: -10393810.018663468,stationName: "598客厅5",id: "kt-5",status: "未使用",},{Type: "客厅",lat: 3659552.246270453,lon: -10819789.300954165,stationName: "598客厅6",id: "kt-6",status: "未使用",},{Type: "客厅",lat: 4186335.64109729,lon: -12949686.157685628,stationName: "598客厅7",id: "kt-7",status: "故障",statusType: "温度异常",},];option.list = list.filter(({ stationName }) => stationName.indexOf(val) !== -1);option.mapRemoveOverlays() // 清除自定义图层,再重新加载自定义div图层option.mapAddOverlay();}// GIS坐标系  EPSG:4326转EPSG:3857function mercatorTolonlat(mercator) {var lonlat = {x: 0,y: 0,};var x = (mercator.x / 20037508.34) * 180;var y = (mercator.y / 20037508.34) * 180;y =(180 / Math.PI) *(2 * Math.atan(Math.exp((y * Math.PI) / 180)) - Math.PI / 2);lonlat.x = x;lonlat.y = y;return lonlat;}// 经纬度(EPSG:4326)转换EPSG:3857function lonLat2Mercator(lonlat) {var mercator = {x: 0,y: 0,};var earthRad = 6378137.0;mercator.x = ((lonlat.lng * Math.PI) / 180) * earthRad;var a = (lonlat.lat * Math.PI) / 180;mercator.y =(earthRad / 2) * Math.log((1.0 + Math.sin(a)) / (1.0 - Math.sin(a)));return mercator;}console.log(mercatorTolonlat({x:13525596.430109723,y:3663568.4585909187}));console.log(lonLat2Mercator({lng: 121.5025, lat: 31.247015}))</script></body>
</html>

openlayers动态添加自定义div图层 具有筛选功能 和浮窗相关推荐

  1. 基于JSON+JQuery实现的多条件筛选功能(类似京东和淘宝功能)

    首先看一下实现效果: 现在JSON用于数据的封装和管理越来越流行,一直想着通过JSON实现很多的小工具,比如多条件筛选.表格定制化.数据验证.tree树等等,最近没事就用JSON和JQuery实现了类 ...

  2. openlayers绘制自定义点线面样式,带清除功能Vue版

    openlayers绘制自定义点线面样式,带清除功能 初学openlayers 有不足之处还望轻喷,多谢 项目用的是vue,elementUI,以及scss 啊-本来点线面都录制了一个gif图,因为某 ...

  3. phpcms教程:phpcms v9 筛选功能的图文教程

    在本文最后有此文章涉及的相关文件的下载 效果展示: 实现方法: 添加字段: 后台-->内容-->内容相关设置-->模型管理-->文章模型-->字段管理-->添加字段 ...

  4. 基于JavaScript实现前端数据多条件筛选功能

    效果图: 实现方法:默认全部.点击每一项进行不同条件切换,根据后台数据传递参数,实现动态的商品筛选功能. 参考如下: 代码如下:源代码 下载: https://github.com/gaomengpi ...

  5. OpenLayers 动态添加标记(Marker)和信息窗(Popup)

    方式一:使用marker方式 1.在地图上添加标记图层 var markers =newOpenLayers.Layer.Markers("Markers"); map.addLa ...

  6. MEF程序设计指南七:使用目录(Catalog)动态装载xap与目录筛选(Filtered Catalog)...

    如果不使用MEF进行托管扩展处理,只有通过WebClient进行程序包的下载.解析.实际上MEF的动态下载的底层实现一样是使用的WebClient,然后利用AggregateCatalog进行动态组合 ...

  7. 关于动态生成div的认识

    因为之前做了个关于仪表的小demo,用到了动态生成div的方法. 例子:一个事件触发一函数,函数的功能是在body里面生成一个DIV,并在DIV里面追加一个img标签.当然其中可以添加div和img ...

  8. Jquery实现无限级树状结构并动态添加增删改等编辑功能

    点击打开链接 源:http://www.56gee.com/Detail/2012/04/11/8AEB74E423/ <!DOCTYPE html PUBLIC "-//W3C//D ...

  9. 基于Vue实现的多条件筛选功能(类似京东和淘宝功能)

    基于Vue实现的多条件筛选功能(类似京东和淘宝功能),可以支持多选.清空.全选功能,数据源是通过JSon格式的数据封装而成. 实现的效果图: 代码实现如下: html: <div id='app ...

  10. php多条件筛选前台功能,JavaScript前端数据多条件筛选功能实现代码

    有时候也会需要在前端进行数据筛选,增强交互体验.当数据可用的筛选条件较多时,把逻辑写死会给后期维护带来很*烦.下面是我自己写的一个简单的筛选器,筛选条件可以根据数据包含的字段动态设置.本文主要为大家详 ...

最新文章

  1. celery源码分析-worker初始化分析(下)
  2. AAuto解析电话薄 VCF文件ENCODING=QUOTED-PRINTABLE编码解码
  3. 〖Linux〗Kubuntu KDE开机后总是提示“system program problem detected”的解决方法
  4. win11频繁更新,关闭win11恶意软件删除工具补丁更新
  5. docker容器的重启策略:通过--restart来指定
  6. 洛谷3320 SDOI2015寻宝游戏(set+dfs序)(反向迭代器的注意事项!)
  7. PAT-A Sign In and Sign Out
  8. AWS Elasticsearch后模式
  9. Firefox 5 公开测试下载
  10. convert mysql_MySQL的CONVERT()
  11. 9月30号后新版CCNA考试要点
  12. 使用sqljdbc连接mssql数据库,maven生成jar运行后报Exception in thread main java.lang.SecurityException错误...
  13. 【渝粤教育】国家开放大学2019年春季 2633轨道交通信号与通信系统 参考试题
  14. C# winform程序运行在XP
  15. 数据结构与算法JavaScript描述——队列
  16. QT 实现 RTSP 视频流服务器
  17. 搭建一款属于自己的,微信/抖音小程序,通过广告赚钱
  18. Word隐藏回车符技巧
  19. 学习大数据分析要什么基础,零基础入门ok吗?
  20. MD文本编辑工具推荐-matktext

热门文章

  1. STL——标准模板库
  2. 开发服务器 k8s 设置 自定义 dns解析
  3. 记录cesium移动模型绘制轨迹
  4. 【定量分析、量化金融与统计学】R语言方差分析的outliers陷阱
  5. VB中数组的嵌套循环
  6. 中兴olt xpon开局及业务配置以及原理
  7. leach协议c++代码_leach协议.doc
  8. itextpdf生成pdf,指定样式及文字水印
  9. 《游戏人工智能》学习笔记3——7 用脚本写现实世界的行为树
  10. 比尔·盖茨、UNIX之父等全球14位IT大佬,总结的18句编程名言!