基于OpenLayers实现导航地图上(起/终)点的交互式图标显示

简介: 基于OpenLayers实现导航地图上(起/终)点的交互式图标显示

目录

1、准备

2、瓦片地图显示

3、增加矢量图层

4、利用click实现鼠标点击效果


在常见的导航软件中,往往都存在标记起/止点的需求。毕竟路径规划中的重要传入参数就是起止点坐标。在常用的不管是移动端还是PC端,导航地图上一般在选择起止点位置会留下图标标记。如下是在PC端百度地图上的截图:

image.png

但是显示方式是右击鼠标选择起点、终点、途径点。如下:

1.png

本文最终获得的效果展示:

3d80c6c79f664dbfae8af304dc180793.png

起止点图标交互式显示


1、准备


基于此,这篇文章则是基于OpenLayers简单地实现导航地图上(起/终)点的交互式图标显示。首先准备的资源包括:ol的库文件css和js,再加上起点/终点图标png文件。

1.png

2、瓦片地图显示


使用瓦片数据作为地图,通过服务的方式加载显示,具体的显示方式参考以前写过的文章:

地图瓦片数据的多种利用形式以及瓦片数据的浏览显示_nanke_yh的博客-CSDN博客_瓦片数据

https://blog.csdn.net/nanke_yh/article/details/125212932


效果:

image.png


3、增加矢量图层



在地图上增加点图标,则需要在地图之上增加一个矢量图层。

    //创建矢量图层
    var vecSource = new ol.source.Vector();
    var vecLayer = new ol.layer.Vector({
        source: vecSource
    });
    vecSource.clear();
    map.addLayer(vecLayer);//添加到map里面


4、利用click实现鼠标点击效果

  //鼠标点击实现地图上显示起止点图标    
    var clickcount = 0;
    $("#map").click(function (e){
        if(clickcount>=2){
          //重置点击次数
            vecSource.clear();
            clickcount = 0;
        }
        var selCoords = map.getEventCoordinate(e);
        var cPoint = new ol.geom.Point([selCoords[0]*1,selCoords[1]*1]);
        if(clickcount == 0){
            //起点
            var startPtFeature = new ol.Feature(cPoint);
            //设置自己的样式:图标形式
            startPtFeature.setStyle(new ol.style.Style({
                image: new ol.style.Icon({
                    src: 'locate_start.png'
                })
            }));
            vecSource.addFeature(startPtFeature);
        }else{
            //终点
            var endPtFeature = new ol.Feature(cPoint);
            //设置自己的样式:图标形式
            endPtFeature.setStyle(new ol.style.Style({
                image: new ol.style.Icon({
                    src: 'locate_end.png'
                })
            }));
        vecSource.addFeature(endPtFeature);
        }
        clickcount++;
    })

最终效果如下:

1.png

目录
相关文章
|
存储 缓存 文件存储
如何保证分布式文件系统的数据一致性
分布式文件系统需要向上层应用提供透明的客户端缓存,从而缓解网络延时现象,更好地支持客户端性能水平扩展,同时也降低对文件服务器的访问压力。当考虑客户端缓存的时候,由于在客户端上引入了多个本地数据副本(Replica),就相应地需要提供客户端对数据访问的全局数据一致性。
32689 78
如何保证分布式文件系统的数据一致性
|
前端开发 容器
HTML5+CSS3前端入门教程---从0开始通过一个商城实例手把手教你学习PC端和移动端页面开发第8章FlexBox布局(上)
HTML5+CSS3前端入门教程---从0开始通过一个商城实例手把手教你学习PC端和移动端页面开发第8章FlexBox布局
17737 19
|
设计模式 存储 监控
设计模式(C++版)
看懂UML类图和时序图30分钟学会UML类图设计原则单一职责原则定义:单一职责原则,所谓职责是指类变化的原因。如果一个类有多于一个的动机被改变,那么这个类就具有多于一个的职责。而单一职责原则就是指一个类或者模块应该有且只有一个改变的原因。bad case:IPhone类承担了协议管理(Dial、HangUp)、数据传送(Chat)。good case:里式替换原则定义:里氏代换原则(Liskov 
36674 19
设计模式(C++版)
|
存储 编译器 C语言
抽丝剥茧C语言(初阶 下)(下)
抽丝剥茧C语言(初阶 下)
|
机器学习/深度学习 人工智能 自然语言处理
带你简单了解Chatgpt背后的秘密:大语言模型所需要条件(数据算法算力)以及其当前阶段的缺点局限性
带你简单了解Chatgpt背后的秘密:大语言模型所需要条件(数据算法算力)以及其当前阶段的缺点局限性
24751 14
|
机器学习/深度学习 弹性计算 监控
重生之---我测阿里云U1实例(通用算力型)
阿里云产品全线降价的一力作,2023年4月阿里云推出新款通用算力型ECS云服务器Universal实例,该款服务器的真实表现如何?让我先测为敬!
36657 15
重生之---我测阿里云U1实例(通用算力型)
|
SQL 存储 弹性计算
Redis性能高30%,阿里云倚天ECS性能摸底和迁移实践
Redis在倚天ECS环境下与同规格的基于 x86 的 ECS 实例相比,Redis 部署在基于 Yitian 710 的 ECS 上可获得高达 30% 的吞吐量优势。成本方面基于倚天710的G8y实例售价比G7实例低23%,总性价比提高50%;按照相同算法,相对G8a,性价比为1.4倍左右。
|
存储 算法 Java
【分布式技术专题】「分布式技术架构」手把手教你如何开发一个属于自己的限流器RateLimiter功能服务
随着互联网的快速发展,越来越多的应用程序需要处理大量的请求。如果没有限制,这些请求可能会导致应用程序崩溃或变得不可用。因此,限流器是一种非常重要的技术,可以帮助应用程序控制请求的数量和速率,以保持稳定和可靠的运行。
29834 52

热门文章

最新文章

下一篇
开通oss服务