接入百度地图api

news2024/9/28 5:32:57

注册百度账号,进入百度地图百度地图开放平台 | 百度地图API SDK | 地图开发

点击开发文档,比如js开发选择javascript API,然后跟着向下走,官方文档挺详细

先获取账号与密钥

 自用Referer设置 * 即可

 

复制AK密钥导入自己的html文件即可

<script src="http://api.map.baidu.com/api?type=webgl&v=1.0&ak=你的密钥"></script>

点击DEMO详情即可看到详细代码 【复制粘贴】

向地图添加自定义图片【记得去除背景色】

var point = new BMapGL.Point(x, y);   
var myIcon = new BMapGL.Icon('po.png', new BMapGL.Size(20, 30));
var marker = new BMapGL.Marker(point,{icon : myIcon});        // 创建标注   
map.addOverlay(marker);  

 offset的计算是从默认位置向对角计算,默认位置均不相同

map.centerAndZoom(point, 15); 1是世界地图,15可以看到周围的店名,19放到最大

<!DOCTYPE html>
<html lang="en">

<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Document</title>
    <script src="http://api.map.baidu.com/api?type=webgl&v=1.0&ak=你的密钥"></script>
    <style>
        html {
            height: 100%
        }
        body {
            height: 100%;
            margin: 0px;
            padding: 0px
        }

        #container {
            height: 100%
        }
    </style>
</head>
<body>
    <div id="container"></div> 
    <script>
        //导入地图
        var map = new BMapGL.Map("con");
        // 设置经纬度
        var x=108.94752631229176;
        var y=33.1225163540307;
        // 设置地图点
        var point = new BMapGL.Point(x, y);
        // 显示地图,并且点位于地图中心
        map.centerAndZoom(point, 15);

        map.enableScrollWheelZoom(true);     //鼠标滚轮true 缩放 false不缩放

        var opts = {
            offset: new BMapGL.Size(1000, 20)
        }
        map.addControl(new BMapGL.ScaleControl(opts));// 比例尺(左下角)
        map.addControl(new BMapGL.ZoomControl()); // 缩放按钮【右下】
        map.addControl(new BMapGL.LocationControl());// 定位(左下角)
        map.addControl(new BMapGL.CityListControl());// 城市选择【左上角】
        map.addControl(new BMapGL.CopyrightControl());// 版权信息【左下角】

        var point = new BMapGL.Point(x, y);   
        var myIcon = new BMapGL.Icon('po.png', new BMapGL.Size(20, 30));
        var marker = new BMapGL.Marker(point,{icon : myIcon});        // 创建标注   
        map.addOverlay(marker);   
        
        // var polyline = new BMapGL.Polyline([
		// new BMapGL.Point(116.399, 39.910),
		// new BMapGL.Point(116.405, 39.920),
		// new BMapGL.Point(116.425, 39.900)
        //     ], {strokeColor:"blue", strokeWeight:10, strokeOpacity:1});
        // map.addOverlay(polyline);

        // var polygon = new BMapGL.Polygon([
        // new BMapGL.Point(116.387112,39.920977),
        // new BMapGL.Point(116.385243,39.913063),
        // new BMapGL.Point(116.394226,39.917988),
        // new BMapGL.Point(116.401772,39.921364),
        // new BMapGL.Point(116.41248,39.927893)
        //     ], {strokeColor:"blue", strokeWeight:2, strokeOpacity:0.5});
        // map.addOverlay(polygon);

        marker.addEventListener('click',function(){
            alert('点击了标注');
        })
        map.addEventListener('click', function(e) {
            alert('点击的经纬度:' + e.latlng.lng + ', ' + e.latlng.lat);
        });
    </script>
</body>
</html>

也可以向container设置高度宽度

<style>
        body{
            width: 1000px;
            height: 1000px;
        }
        #container {
            height: 50%;
            width: 50%;
            border: 1px solid;
        }
</style>

 定位

<!DOCTYPE html>
<html lang="en">

<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Document</title>
    <script src="http://api.map.baidu.com/api?type=webgl&v=1.0&ak=webgl&ak=你的密钥"></script>
    <style>
        body{
            width: 1000px;
            height: 1000px;
        }
        #con {
            height: 50%;
            width: 50%;
            border: 1px solid;
        }
    </style>
</head>
<body>
    <div id="con"></div> 
    <script>
        var map = new BMapGL.Map("con");
        map.addControl(new BMapGL.LocationControl());
        map.addControl(new BMapGL.ZoomControl());
        var point = new BMapGL.Point(116.331398,39.897445);
        map.centerAndZoom(point,15);
        
        //浏览器定位,不精准
        var geolocation = new BMapGL.Geolocation();
        geolocation.getCurrentPosition(function(r){
            console.log(r.address.city);
            if(this.getStatus() == BMAP_STATUS_SUCCESS){
                var mk = new BMapGL.Marker(r.point);
                map.addOverlay(mk);
                map.panTo(r.point);
                alert('您的位置:' + r.point.lng + ',' + r.point.lat);
            }
            else {
                alert('failed' + this.getStatus());
            }        
        });

        // IP定位
        // function myFun(result){
        //     var cityName = result.name;
        //     map.setCenter(cityName);
        //     alert("当前定位城市:" + cityName);
        // }
        // var myCity = new BMapGL.LocalCity();
        // myCity.get(myFun); 


        // 需要借助安卓软件
        // var geolocation = new BMapGL.Geolocation();
        // // 开启SDK辅助定位
        // geolocation.enableSDKLocation();
        // geolocation.getCurrentPosition(function(r){
        //     if(this.getStatus() == BMAP_STATUS_SUCCESS){
        //         var mk = new BMap.Marker(r.point);
        //         map.addOverlay(mk);
        //         map.panTo(r.point);
        //         alert('您的位置:' + r.point.lng + ',' + r.point.lat);
        //     }
        //     else {
        //         alert('failed' + this.getStatus());
        //     }        
        // });
    </script>
</body>
</html>

路线导航

<!DOCTYPE html>
<html lang="en">

<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Document</title>
    <script src="jquery-3.6.0.min.js"></script>
    <script src="http://api.map.baidu.com/api?type=webgl&v=1.0&ak=webgl&ak=你的密钥
"></script>
    <style>
        body {
            width: 1000px;
            height: 1000px;
        }

        #con {
            height: 50%;
            width: 50%;
            border: 1px solid;
        }
    </style>
</head>

<body>
    <div id="con"></div>
    <div id="result" style="width: 350px;height: 150px;"></div>
    <script>
        var map = new BMapGL.Map("con");
        //步行导航
        map.enableScrollWheelZoom();
        // map.centerAndZoom(new BMapGL.Point(116.404, 39.915), 11);
        // var walking = new BMapGL.WalkingRoute(map, {renderOptions:{map: map, autoViewport: true}});
        // walking.search('西单', '慈云寺');

        //骑行规划
        map.centerAndZoom(new BMapGL.Point(116.404, 39.915), 14);
        var riding = new BMapGL.RidingRoute(map, {
            renderOptions: {
                map: map,
                autoViewport: true
            }
        });
        var start = new BMapGL.Point(116.310791, 40.003419);
        var end = new BMapGL.Point(116.386419, 40.003519);
        riding.search(start,end);

        //公交车导航
        // map.centerAndZoom(new BMapGL.Point(116.404, 39.915), 12);
        // var output = '从上地到西单坐公交需要:';
        // var transit = new BMapGL.TransitRoute(map, {
        //     renderOptions: { map: map },
        //     onSearchComplete: function (results) {
        //         if (transit.getStatus() != BMAP_STATUS_SUCCESS) {
        //             return;
        //         }
        //         var plan = results.getPlan(0);
        //         output += '总时长:' + plan.getDuration(true);  //获取时间
        //         output += '总路程:' + plan.getDistance(true);  //获取距离
        //         $('#result').css('display', 'block');
        //         $('#result').html(output);
        //     },
        // });
        // var start = new BMapGL.Point(116.404844, 39.911836);
        // var end = new BMapGL.Point(116.308102, 40.056057);
        // transit.search(start, end);


        //驾车导航
        // map.centerAndZoom(new BMapGL.Point(116.404, 39.915), 11);
        // var p1 = new BMapGL.Point(116.301934,39.977552);
        // var p2 = new BMapGL.Point(116.508328,39.919141);
        // var driving = new BMapGL.DrivingRoute(map, {renderOptions:{map: map, autoViewport: true}});
        // driving.search(p1, p2);

        // var txtMenuItem = [
        //     {
        //         text: '放大',                             // 定义菜单项的显示文本
        //         callback: function () {                 // 定义菜单项点击触发的回调函数
        //             map.zoomIn();
        //         }
        //     },
        //     {
        //         text: '缩小',
        //         callback: function () {
        //             map.zoomOut();
        //         }
        //     }
        // ];
        // for (var i = 0; i < txtMenuItem.length; i++) {
        //     menu.addItem(new BMapGL.MenuItem(               // 定义菜单项实例
        //         txtMenuItem[i].text,                        // 传入菜单项的显示文本
        //         txtMenuItem[i].callback,                    // 传入菜单项的回调函数
        //         {
        //             width: 300,                             // 指定菜单项的宽度
        //             id: 'menu' + i                          // 指定菜单项dom的id
        //         }
        //     ));
        // }
        // map.addContextMenu(menu);   
    </script>
</body>

</html>

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

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

MVCC(多版本并发控制)

一、什么是MVCC MVCC是为了解决数据库在不加锁的前提下提升并发性和读取效率的一种思想 数据库有已下几种并发情况 读-读&#xff1a;不会产生并发问题读-写&#xff1a;发生隔离性问题&#xff0c;可能导致脏读、幻读、不可重复度写-写&#xff1a;可能存在数据丢失 为了防…

京东科技埋点数据治理和平台建设实践 | 京东云技术团队

导读 本文核心内容聚焦为什么要埋点治理、埋点治理的方法论和实践、奇点一站式埋点管理平台的建设和创新功能。读者可以从全局角度深入了解埋点、埋点治理的整体思路和实践方法&#xff0c;落地的埋点工具和创新功能都有较高的实用参考价值。遵循埋点治理的方法论&#xff0c;…

sd模型测试之又纯又欲的Copax Anime XL动漫大模型

除了各种美女图外&#xff0c;AI绘画大模型中&#xff0c;最受欢迎的是动漫。 动漫又分好几种&#xff0c;幼儿向、热血向、成人向等。 之前我推荐了几个风格不同的动漫大模型&#xff0c;今天推荐一个成人向的动漫大模型&#xff1a;Copax Anime XL。 当然了&#xff0c;成…

One-to-N N-to-One: Two Advanced Backdoor Attacks Against Deep Learning Models

One-to-N & N-to-One: Two Advanced Backdoor Attacks Against Deep Learning Models----《一对N和N对一&#xff1a;针对深度学习模型的两种高级后门攻击》 1对N&#xff1a; 通过控制同一后门的不同强度触发多个后门 N对1&#xff1a; 只有当所有N个后门都满足时才会触发…

【JAVA学习笔记】54 - 集合 - Set类、HashSet类(难点)

项目代码 https://github.com/yinhai1114/Java_Learning_Code/tree/main/IDEA_Chapter14/src/com/yinhai/set_ Set类 一、基本介绍 1.无序(添加和取出的顺序不一致) ,没有索引[后面演示] 2.不允许重复元素&#xff0c;所以最多包含一个null 3.JDK API中Set接口的实现类有: …

SQL BETWEEN运算符

SQL BETWEEN 运算符 BETWEEN运算符用于选取介于两个值之间的数据范围内的值。 BETWEEN运算符选择给定范围内的值。值可以是数字&#xff0c;文本或日期。 BETWEEN运算符是包含性的&#xff1a;包括开始和结束值&#xff0c;且开始值需小于结束值。 SQL BETWEEN 语法 SELECT …

【蓝桥杯选拔赛真题06】C++数字评级 青少年组蓝桥杯C++选拔赛真题 STEMA比赛真题解析

目录 C/C++数字评级 一、题目要求 1、编程实现 2、输入输出 二、算法分析 <

gma 2 教程(三)坐标参考系统:2.基准面/椭球体

安装 gma&#xff1a;pip install gma 地球是一个近似于椭球体的三维物体&#xff0c;而地球上的各种测量和计算都需要一个基准面来进行。基准面是一个虚拟的平面&#xff0c;用于测量和计算地球上的各种物理量。在地球科学中&#xff0c;基准面通常是一个参考椭球体&#xff0…

rabbitmq安装、基本使用

docker run -it --rm --name rabbitmq -p 5672:5672 -p 15672:15672 rabbitmq:3.12-management docker会自己下载&#xff0c;然后运行 进入docker&#xff1a; docker exec -it rabbitmq bash 进入容器&#xff0c;重启rabbitmq&#xff1a;rabbitmq-server restart 感觉所有的…

基于平衡优化器算法的无人机航迹规划-附代码

基于平衡优化器算法的无人机航迹规划 文章目录 基于平衡优化器算法的无人机航迹规划1.平衡优化器搜索算法2.无人机飞行环境建模3.无人机航迹规划建模4.实验结果4.1地图创建4.2 航迹规划 5.参考文献6.Matlab代码 摘要&#xff1a;本文主要介绍利用平衡优化器算法来优化无人机航迹…

前端如何实现多种方式圆形可点击区域

前言 四种方式都可以实现在圆形区域内添加点击事件&#xff0c;选择哪种方式可以根据具体情况选择。其中使用canvas实现的方式可以更好地适用于需要绘制复杂图形的情况下。 方式一&#xff1a;border-radius 使用CSS的border-radius属性创建圆形区域&#xff0c;然后通过绑定点…

Spring Boot 3系列之一(初始化项目)

近期&#xff0c;JDK 21正式发布&#xff0c;而Spring Boot 3也推出已有一段时间。作为这两大技术领域的新一代标杆&#xff0c;它们带来了许多令人振奋的新功能和改进。尽管已有不少博客和文章对此进行了介绍&#xff0c;但对于我们这些身处一线的开发人员来说&#xff0c;有些…

Generalized Zero-Shot Learning With Multi-Channel Gaussian Mixture VAE

L D A _{DA} DA​最大化编码后两种特征分布之间的相似性 辅助信息 作者未提供代码

通过引入插件Grid Masschange实现批量修改交互网格数据

现状描述: 很多时候我们需要对交互式网格进行数据更新&#xff0c;单个或少量的数据还好&#xff0c;一旦数据量过大&#xff0c;APEX现有的原生手动输入就不能满足需求&#xff0c;既浪费人力又浪费时间&#xff0c;白白损失了劳动成本&#xff0c;应对这种情况&#xff0c;有…

flink 反压原理

背景 在flink中由于数据倾斜或者数据处理速率的不匹配&#xff0c;很容易引起反压&#xff0c;本文就看一下flink反压的原理 flink反压原理 flink全流程pineline的反压实现其实依赖于TaskManager之间的反压和TaskManager内部的反压来实现 1.TaskManager之间的反压 2.Task…

Linux指令【上】

目录 目录结构 ls cd stat touch mkdir whoami 查看当前帐号是谁 who 查看当前有哪些人在使用 pwd 当前的工作目录 目录结构 目录结构就是一颗多叉树的样子 路径 我们从 / 目录开始&#xff0c;定位一个叶子文件的…

【Holocubic简化修改版——基于STM32F405+ESP8266-12F:使用FreeRTOS和标准库】

一.简介 第一次看到Holobubic项目是稚晖君视频&#xff1a;【自制】如何制作一个赛博朋克风格的 百大UP奖杯 【软核】 但是稚晖君的项目是基于ESP32PICO-D4&#xff0c;因此我想尝试使用STM32复刻一个。实际上&#xff0c;使用STM32复刻Holocubic在CSDN上已经有一位博主发布了他…

vsCode安装CodeRunner插件输出中文乱码问题

1 vsCode下载 vcCode官网地址&#xff1a;https://code.visualstudio.com/ 2 安装CodeRunner 通过Ctrl Shift P 找到 settings找到code-runner.executorMap&#xff0c;在 settings.json 中加入 "code-runner.executorMap": {....."python": "s…

MSQL系列(十一) Mysql实战-Inner Join算法底层原理及驱动表选择

Mysql实战-Inner Join算法驱动表选择 前面我们讲解了BTree的索引结构&#xff0c;及Mysql的存储引擎MyISAM和InnoDB,也详细讲解下 left Join的底层驱动表 选择, 并且初步了解 Inner join是Mysql 主动选择优化的驱动表&#xff0c;知道索引要建立在被驱动表上 那么对于Inner j…