基于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

目录
相关文章
|
定位技术
百度地图:监听地图缩放自动显示和隐藏的富文本标签
百度地图:监听地图缩放自动显示和隐藏的富文本标签
197 0
|
3月前
|
开发框架 前端开发 搜索推荐
在WInform开发中实现工具栏/菜单的动态呈现
在WInform开发中实现工具栏/菜单的动态呈现
|
4月前
|
小程序 定位技术 API
uniapp 开发微信小程序 --【地图】打开地图选择位置,打开地图显示位置(可开启导航)
uniapp 开发微信小程序 --【地图】打开地图选择位置,打开地图显示位置(可开启导航)
344 0
|
4月前
|
小程序 API
【微信小程序-原生开发】实用教程07 - Grid 宫格导航,详情页,侧边导航(含自定义页面顶部导航文字)
【微信小程序-原生开发】实用教程07 - Grid 宫格导航,详情页,侧边导航(含自定义页面顶部导航文字)
95 0
|
数据可视化 前端开发 搜索推荐
数据可视化大屏百度地图GPS轨迹位置感知状态开发实战案例解析(百度地图jsAPI,包含缩放控件、点线覆盖物、弹窗、标注图标分类功能)
数据可视化大屏百度地图GPS轨迹位置感知状态开发实战案例解析(百度地图jsAPI,包含缩放控件、点线覆盖物、弹窗、标注图标分类功能)
280 0
|
前端开发 定位技术
Echarts地图高级开发:下钻交互菜单操作按钮(1)
Echarts地图高级开发:下钻交互菜单操作按钮(1)
121 0
|
小程序 JavaScript 定位技术
小程序点击指定地址按钮直接打开地图导航
小程序点击指定地址按钮直接打开地图导航
254 0
|
定位技术 API
Cesium开发:限制地图浏览范围
Cesium开发:限制地图浏览范围
742 1
|
定位技术 API 开发工具
百度地图开发-显示地图默认界面 03
百度地图开发-显示地图默认界面 03
287 1
百度地图开发-显示地图默认界面 03
Qt-网易云音乐界面实现-1 窗口隐藏拖拽移动,自定义标题栏
最近也换了公司,也换了新的工作,工资也象征性的涨了一点点,但是最近心里还是慌慌,不知道为什么,没有那种踏实感,感觉自己随时可以被抛弃的感觉。感觉自己在荒废时间,也感觉自己在浪费生命。
300 0
Qt-网易云音乐界面实现-1 窗口隐藏拖拽移动,自定义标题栏