前端百度地图添加点并跳转到百度地图进行导航

目录

一、需求

二、展示地图

三、添加点覆盖物

四、添加信息窗口(需展示地址名称) 

五、唤起百度地图

六、完整代码


一、需求

前端有时候需要做地图展示,我一般用的地图是天地图和百度地图,大家可以通过官网来制作地图。

1.天地图:天地图API

可根据类参考或者代码示例来制作地图。

2。百度地图:jspopularGL | 百度地图API SDK

申请秘钥、 展示地图、demo参考来制作地图。

前端需要展示地图,添加地址的点位(获取经纬度,把点添加到地图上),点击点跳转到app或者是官网上,这里用到的是百度地图,天地图暂时不提供导航服务。

下面我们对这一需求进行实现。

二、展示地图

html代码:

<div class="map" id="map">

</div>

其中map是放地图的容器,一定要给这个div设置宽和高,不然不显示。

css代码:

.map{
   width: 100%;
   height: 100vh;
}
.map .anchorBL {
   display: none;
}

其中.anchorBL是百度地图的水印。这里将水印隐藏,水印长这样:

js代码:

	getMap();
	var map;
	//展示地图
	function getMap(){
	
	    map = new BMapGL.Map('map');
	    var center = new BMapGL.Point(106.639958,26.645316);
	    map.centerAndZoom(center, 13);
	    map.enableScrollWheelZoom(true); //开启鼠标滚轮缩放
	    map.enableScrollWheelZoom(true);
	    map.setMapType(BMAP_SATELLITE_MAP);//设置地图类型为普通卫星地图模式
	
	    var scaleCtrl = new BMapGL.ScaleControl(); // 添加比例尺控件
	    var zoomCtrl = new BMapGL.ZoomControl(); // 添加缩放控件
	    map.addControl(scaleCtrl);

	}

需要注意的是:map.setMapType(BMAP_SATELLITE_MAP);//设置地图类型为普通卫星地图模式

运行结果:

三、添加点覆盖物

	let address = [
	    {
	        name:'地址一',
	        lng:106.641252,
	        lat:26.652775
	    },
	    {
	        name:'地址二',
	        lng:106.629753,
	        lat:26.637856
	    }
	];
	
	//添加位置标识
	address.forEach((v,k)=>{
	    addMaker1(v,v.name,-100,-60,'button')
	})
	
	function addMaker1(point,name,x,y,button) {
	    // 创建图标
	    var myIcon = new BMapGL.Icon("image/pointer.png", new BMapGL.Size(30, 39));
	
	    var pointer = new BMapGL.Point(point.lng,point.lat);
	    var marker = new BMapGL.Marker(pointer, {
	        icon: myIcon
	    });
	    map.addOverlay(marker);
	}
	

运行结果:

四、添加信息窗口(需展示地址名称) 

	function addMaker1(point,name,x,y,button) {
        //...添加点
	    var opts = {
	        position: new BMapGL.Point(point.lng,point.lat), // 指定文本标注所在的地理位置
	        offset: new BMapGL.Size(x,y) // 设置文本偏移量
	    };
	    // 创建文本标注对象
	    let string = `<div style="display: flex;align-items: center">${name}<img class="${button}" style="width: 30px;margin-left: 10px"  src="image/logo.png"/></div>`
	
	    var label = new BMapGL.Label(string, opts);
	    // 自定义文本标注样式
	    label.setStyle({
	        color: 'black',
	        borderRadius: '5px',
	        borderColor: '#ccc',
	        padding: '5px',
	        fontSize: '14px',
	        height: '30px',
	        lineHeight: '30px',
	        fontFamily: '微软雅黑'
	    });
	    map.addOverlay(label)
	
	    var opts = {
	        width: 100,     // 信息窗口宽度
	        height: 24,     // 信息窗口高度
	        // title: "故宫博物院", // 信息窗口标题
	    }

	    label.addEventListener("click",function () {
	            let lngNum ;
	            let latNum ;
	
	            function myFun(result){
                    //获取当前所在市的信息,主要为了pc端和ios系统获取不到精准位置用的
	                console.log(result)
	                lngNum = result.center.lng;
	                latNum = result.center.lat;
	                openBaiduMap(point.lng,point.lat,name,latNum,lngNum);//调起百度地图
	
	            }
	            var myCity = new BMapGL.LocalCity();
	            myCity.get(myFun);
	            console.log(latNum)
	            console.log(lngNum)
	
	
	        }
	    )
	
	
	
	}

其中,点击信息窗口,唤起百度地图。

由于pc端和ios系统获取不到精准位置,所以需要通过var myCity = new BMapGL.LocalCity();
myCity.get(myFun);来实现获取位置,只不过这个位置是大概范围(当前所在城市),result的打印内容如下:

运行结果:

 

五、唤起百度地图

	//唤起百度地图
	function openBaiduMap(lng, lat, address,lat11,lng11) {
	    var geolocation = new BMap.Geolocation();
	    // 开启定位控件
	    geolocation.enableSDKLocation();
	    geolocation.getCurrentPosition(function (result) {
	
	        var queryString;
	        if (this.getStatus() == BMAP_STATUS_SUCCESS) {
	            console.log('11')
	            queryString = `origin=latlng:${result.point.lat},${result.point.lng}|name:我的位置&destination=latlng:${lat},${lng}|name:${address}&mode=driving&coord_type=bd09ll&src=com.mzwu.www`;
	        } else {
	            console.log('22')
	
	            queryString = `origin=latlng:${lat11},${lng11}|name:我的位置&destination=latlng:${lat},${lng}|name:${address}&mode=driving&coord_type=bd09ll&src=com.mzwu.www`;
	
	            // var queryString = `origin=latlng:28.238681,116.608768|name:我的位置&destination=latlng:${lat},${lng}|name:${address}&mode=driving&coord_type=bd09ll&src=com.mzwu.www`;
	
	        }
	        var app_url = `baidumap://map/direction?${queryString}`;
	        var web_url = `http://api.map.baidu.com/direction?${queryString}&region=中国&output=html`;
	        // https://map.baidu.com/dir/%E6%88%91%E7%9A%84%E4%BD%8D%E7%BD%AE/%E5%9C%B0%E5%9D%80%E4%B8%80/@11599509.985,3557925.135,7z?querytype=nav&sn=1$$$$12127997.03,4051196.53$$%E6%88%91%E7%9A%84%E4%BD%8D%E7%BD%AE$$$$$$&en=1$$$$11871379.04,3060815.7$$%E5%9C%B0%E5%9D%80%E4%B8%80$$$$$$&c=233&version=4&route_traffic=1&mrs=1&da_src=shareurl
	        //尝试唤起百度地图App
	        window.location.href = app_url;
	
	
	        //唤起失败打开Web版百度地图
	        var startTime = Date.now();
	        var count = 0;
	
	        var t = setInterval(function () {
	            if (++count < 30) {
	                return;
	            }
	            if (Date.now() - startTime > 800) {
	                clearInterval(t);
	            }
	            if (!(document.hidden || document.webkitHidden)) {
	                window.location.href = web_url;
	                // window.open(web_url,'_bank')//浏览器会拦截
	
	            }
	        }, 20);
	
	        window.onblur = function () {
	            clearInterval(t);
	        };
	    });
	}
	
	

 this.getStatus()在安卓系统中是BMAP_STATUS_SUCCESS,其他pc和ios获取不到精准位置。

百度地图会打开,并从当前位置到所选位置进行导航,如图所示:

1.pc端:打开导航,位置不精准,但可以用鼠标拖动来更改路线。

 2.安卓:网页当前位置精准,打开百度地图app同样的。

3.ios:网页当前位置只能获取市,但打开百度地图app是精准的。

六、完整代码

记得申请秘钥哦!!!!

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title></title>
    <meta name="viewport" content="width=device-width, initial-scale=1">
    <style>
        .map{
            width: 100%;
            height: 100vh;
        }
        .map .anchorBL {
            display: none;
        }
    </style>

</head>
<body>
<div>
    <div class="map" id="map">

    </div>
</div>
<script type="text/javascript" src="jquery.min.js"></script>
<script src="http://api.map.baidu.com/api?v=3.0&ak=您的秘钥"></script>
<script src="http://api.map.baidu.com/api?type=webgl&v=1.0&ak=您的秘钥"></script>

<script type="text/javascript"src="http://developer.baidu.com/map/jsdemo/demo/convertor.js"></script>

   


<script type="text/javascript">
	getMap();
	var map;
	//展示地图
	function getMap(){
	
	    map = new BMapGL.Map('map');
	    var center = new BMapGL.Point(106.639958,26.645316);
	    map.centerAndZoom(center, 13);
	    map.enableScrollWheelZoom(true); //开启鼠标滚轮缩放
	    map.enableScrollWheelZoom(true);
	    map.setMapType(BMAP_SATELLITE_MAP);//设置地图类型为普通卫星地图模式
	
	    var scaleCtrl = new BMapGL.ScaleControl(); // 添加比例尺控件
	    var zoomCtrl = new BMapGL.ZoomControl(); // 添加缩放控件
	    map.addControl(scaleCtrl);

	}
	
	let address = [
	    {
	        name:'地址一',
	        lng:106.641252,
	        lat:26.652775
	    },
	    {
	        name:'地址二',
	        lng:106.629753,
	        lat:26.637856
	    }
	];
	
	//添加位置标识
	address.forEach((v,k)=>{
	    addMaker1(v,v.name,-100,-60,'button')
	})
	
	function addMaker1(point,name,x,y,button) {
	    // 创建图标
	    var myIcon = new BMapGL.Icon("image/pointer.png", new BMapGL.Size(30, 39));
	
	    var pointer = new BMapGL.Point(point.lng,point.lat);
	    var marker = new BMapGL.Marker(pointer, {
	        icon: myIcon
	    });
	    map.addOverlay(marker);
	
	    var opts = {
	        position: new BMapGL.Point(point.lng,point.lat), // 指定文本标注所在的地理位置
	        offset: new BMapGL.Size(x,y) // 设置文本偏移量
	    };
	    // 创建文本标注对象
	    let string = `<div style="display: flex;align-items: center">${name}<img class="${button}" style="width: 30px;margin-left: 10px"  src="image/logo.png"/></div>`
	
	    var label = new BMapGL.Label(string, opts);
	    // 自定义文本标注样式
	    label.setStyle({
	        color: 'black',
	        borderRadius: '5px',
	        borderColor: '#ccc',
	        padding: '5px',
	        fontSize: '14px',
	        height: '30px',
	        lineHeight: '30px',
	        fontFamily: '微软雅黑'
	    });
	    map.addOverlay(label)
	
	    var opts = {
	        width: 100,     // 信息窗口宽度
	        height: 24,     // 信息窗口高度
	        // title: "故宫博物院", // 信息窗口标题
	    }

	    label.addEventListener("click",function () {
	            let lngNum ;
	            let latNum ;
	
	            function myFun(result){
	                console.log(result)//获取当前所在市的信息,主要为了pc端和ios系统获取不到精准位置用的
	                lngNum = result.center.lng;
	                latNum = result.center.lat;
	                openBaiduMap(point.lng,point.lat,name,latNum,lngNum);//调起百度地图
	
	            }
	            var myCity = new BMapGL.LocalCity();
	            myCity.get(myFun);
	
	        }
	    )
	}
	
	//唤起百度地图
	function openBaiduMap(lng, lat, address,lat11,lng11) {
	    var geolocation = new BMap.Geolocation();
	    // 开启定位控件
	    geolocation.enableSDKLocation();
	    geolocation.getCurrentPosition(function (result) {
	
	        var queryString;
	        if (this.getStatus() == BMAP_STATUS_SUCCESS) {
	            console.log('11')
	            queryString = `origin=latlng:${result.point.lat},${result.point.lng}|name:我的位置&destination=latlng:${lat},${lng}|name:${address}&mode=driving&coord_type=bd09ll&src=com.mzwu.www`;
	        } else {
	            console.log('22')
	
	            queryString = `origin=latlng:${lat11},${lng11}|name:我的位置&destination=latlng:${lat},${lng}|name:${address}&mode=driving&coord_type=bd09ll&src=com.mzwu.www`;
	
	            // var queryString = `origin=latlng:28.238681,116.608768|name:我的位置&destination=latlng:${lat},${lng}|name:${address}&mode=driving&coord_type=bd09ll&src=com.mzwu.www`;
	
	        }
	        var app_url = `baidumap://map/direction?${queryString}`;
	        var web_url = `http://api.map.baidu.com/direction?${queryString}&region=中国&output=html`;
	        // https://map.baidu.com/dir/%E6%88%91%E7%9A%84%E4%BD%8D%E7%BD%AE/%E5%9C%B0%E5%9D%80%E4%B8%80/@11599509.985,3557925.135,7z?querytype=nav&sn=1$$$$12127997.03,4051196.53$$%E6%88%91%E7%9A%84%E4%BD%8D%E7%BD%AE$$$$$$&en=1$$$$11871379.04,3060815.7$$%E5%9C%B0%E5%9D%80%E4%B8%80$$$$$$&c=233&version=4&route_traffic=1&mrs=1&da_src=shareurl
	        //尝试唤起百度地图App
	        window.location.href = app_url;
	
	
	        //唤起失败打开Web版百度地图
	        var startTime = Date.now();
	        var count = 0;
	
	        var t = setInterval(function () {
	            if (++count < 30) {
	                return;
	            }
	            if (Date.now() - startTime > 800) {
	                clearInterval(t);
	            }
	            if (!(document.hidden || document.webkitHidden)) {
	                window.location.href = web_url;
	                // window.open(web_url,'_bank')//浏览器会拦截
	
	            }
	        }, 20);
	
	        window.onblur = function () {
	            clearInterval(t);
	        };
	    });
	}
</script>
</body>
</html>

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

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

相关文章

Mysql-根据字段名查询字段在哪些表里

SELECT * FROM information_schema.COLUMNS WHERE COLUMN_NAMElabel_name;

爬虫案例:有道翻译python逆向

pip install pip install requestspip install base64pip install pycrytodome tools 浏览器的开发者工具&#xff0c;重点使用断点&#xff0c;和调用堆栈 工具网站&#xff1a;https://curlconverter.com/ 简便请求发送信息 flow 根据网站信息&#xff0c;preview,respon…

【MATLAB源码-第213期】基于matlab的16QAM调制解调系统软硬判决对比仿真,输出误码率曲线对比图。

操作环境&#xff1a; MATLAB 2022a 1、算法描述 一、16QAM调制原理 在16QAM&#xff08;16 Quadrature Amplitude Modulation&#xff09;调制中&#xff0c;一个符号表示4个比特的数据。这种调制方式结合了幅度调制和相位调制&#xff0c;能够在相同的频谱资源下传输更多…

kotlinx.coroutines.debug.AgentPremain

大家好 我是苏麟 . 项目引入AI大模型 debug 出现报错 设置 勾选

2024最新私有化部署AI大模型,让每个人都有属于自己的AI助理

让每个人都拥有一个属于自己的本地大模型 下载Ollama 下载地址 ​ https://ollama.com/download ​ Ollama支持MacOS、Linux、Windows 解压 下载完成后&#xff0c;会得到一个Ollama-darwin.zip文件&#xff0c;解压后&#xff0c;以Mac为例是一个可运行文件&#xff1a;O…

失业潮中如何突围?优秀PPT案例助你职场逆袭

在这个变幻莫测的时代&#xff0c;失业潮像一场突如其来的暴风雨&#xff0c;许多人在职场的大海中迷失方向。但别担心&#xff0c;即使风浪再大&#xff0c;总有勇敢的航海者能够乘风破浪&#xff0c;找到属于自己的那片新大陆。 今天&#xff0c;我们就来聊聊&#xff0c;在…

leedcode【209】. 长度最小的子数组——Java解法

Problem: 209. 长度最小的子数组 题目思路解题方法复杂度Code效果 题目 给定一个含有 n 个正整数的数组和一个正整数 target 。 找出该数组中满足其总和大于等于 target 的长度最小的 连续 子数组 [numsl, numsl1, ..., numsr-1, numsr] &#xff0c;并返回其长度。如果不存…

pyside6下没有designer.exe、pyside6-uic.exe等

使用conda安装的pyside6&#xff08;conda install pyside6&#xff09;&#xff0c;发现pyside6目录下没有designer.exe、pyside6-uic.exe等&#xff1b;designer.exe在Miniconda3/Library/bin下 pyside6-uic.exe、pyside6-rcc.exe在Miniconda3\Scripts下 但是 使用pip安装…

边框渐变样式

实现样式&#xff1a; 对应代码&#xff1a; div {min-height: 40vh;border: 10px solid transparent;background-image: linear-gradient(#222, #222), var(--gradient);background-origin: border-box;background-clip: padding-box, border-box;border-radius: 10px;positi…

Mysql之InnoDB索引

1.索引简介 官网介绍:MySQL :: MySQL 8.0 Reference Manual :: 10.3.1 How MySQL Uses Indexes 索引用于快速查找具有特定列值的行。如果没有索引&#xff0c; MySQL 必须从第一行开始&#xff0c;然后读取整个表以找到相关的行。表越大&#xff0c;花费就越多。如果表中有相关…

ES基础概念

本文不介绍如何使用ES&#xff08;使用ES见&#xff1a;&#xff09; 1.ES生态圈 ES&#xff1a; Logstash&#xff1a;数据处理服务程序&#xff0c;解析转换加工数据&#xff1b; Kibana&#xff1a;数据展示、集群管理&#xff0c;数据可视化、ES管理与监控、报表等&#xf…

推荐一个快速开发接私活神器

文章目录 前言一、项目介绍二、项目地址三、功能介绍四、页面显示登录页面菜单管理图表展示定时任务管理用户管理代码生成 五、视频讲解总结 前言 大家好&#xff01;我是智航云科技&#xff0c;今天为大家分享一个快速开发接私活神器。 一、项目介绍 人人开源是一个提供多种…

Java反射角度简单理解spring IOC容器

概述 Java反射&#xff08;Reflection&#xff09;是Java编程语言的一个特性&#xff0c;它允许在运行时对类、接口、字段和方法进行动态查询和操作。反射提供了一种在运行时查看和修改程序行为的能力&#xff0c;这通常用于实现一些高级功能&#xff0c;如框架(Spring)、ORM&…

Git简介以及下载安装和配置

Git介绍 什么是版本控制?什么是Git?什么是集中式版本控制(了解)分布式版本控制工作流程 Git的安装与配置注册邮箱以及用户名(方便远程使用)初始化项目Git在ideal上的使用(本地) 什么是版本控制? ​ 版本控制是指对软件开发过程中各种程序代码,控制文件及说明文档等文件变更…

《计算机网络微课堂》1-3 三种交换方式

本节课我们介绍三种交换方式&#xff0c;分别是电路交换&#xff08;Circuit Switching&#xff09;&#xff0c;分组交换&#xff08;Packet Switching&#xff09;以及报文&#xff08;Message Switching&#xff09;交换。 我们首先来看电路交换&#xff0c;在电话问世后不…

设计模式8——原型模式

写文章的初心主要是用来帮助自己快速的回忆这个模式该怎么用&#xff0c;主要是下面的UML图可以起到大作用&#xff0c;在你学习过一遍以后可能会遗忘&#xff0c;忘记了不要紧&#xff0c;只要看一眼UML图就能想起来了。同时也请大家多多指教。 原型模式&#xff08;Prototyp…

MiniCPM-Llama3-V-2_5-int4

MiniCPM-Llama3-V-2_5-int4大模型部署使用环境&#xff1a; python3.8cuda11.8其它要求&#xff0c;按照安装文档要求下载即可 我是在算力平台用4090跑的&#xff0c; GPU 显存&#xff08;8GB&#xff09;可以部署推理 int4 量化版本&#xff0c;如果推理非量化版本需要更高显…

开视频号小店要花哪些钱?这些费用大家要知道

大家好&#xff0c;我是喷火龙。 目前&#xff0c;视频号小店从推出到现在已经快两年的时间了&#xff0c;视频号小店虽然门槛高&#xff0c;但是单价也高&#xff0c;利润也高&#xff0c;市场环境也好&#xff0c;算是一个不错的项目。 接下来给大家讲讲开视频号小店要花哪…

推荐五个线上兼职,在家也能轻松日入百元,适合上班族和全职宝妈

在这个瞬息万变的时代&#xff0c;你是否也曾考虑过在繁忙的工作之外&#xff0c;寻找一份兼职副业来补贴家用&#xff0c;同时保持生活的多样性&#xff1f;别急&#xff0c;现在就让我为你揭秘五个可靠的日结线上兼职岗位&#xff0c;助你轻松迈向财务自由之路&#xff01; 一…

VBA批量合并带有图片、表格与文本框的Word

本文介绍基于VBA语言&#xff0c;对大量含有图片、文本框与表格的Word文档加以批量自动合并&#xff0c;并在每一次合并时添加分页符的方法。 在我们之前的文章基于Python中docx与docxcompose批量合并多个Word文档文件并逐一添加分页符&#xff08;https://blog.csdn.net/zhebu…