网页百度地图api,支持位置偏移
网页百度地图api,支持位置偏移
需加载 jq
<style type="text/css">
#allmap {width:100%; height:100%; border:#ccc solid 1px; box-sizing:border-box; position:relative; z-index:1;}
.mapbox {width:100%; height:420px; margin-top:15px; position:relative;}
.mapbox.on {height:100%; margin-top:0; position:fixed; top:0; left:0; z-index:1000;}
.mapbox .zw {width:100%; height:100%; position:absolute; top:0; left:0; z-index:2; display:none;}
.anchorBL, .BMap_cpyCtrl {display:none;}
.BMap_pop {transform:translateY(-15px);}
.mapbigest {width:26px; height:26px; position:absolute; top:10px; right:10px; z-index:10; cursor:pointer; background-size:100% 100%; background-repeat:no-repeat; background-image:url('');}
@media (max-width: 640px) {
.BMap_scaleCtrl {display:none;}
.mapbox .zw {display:block;}
}
</style> <script type="text/javascript" src="https://api.map.baidu.com/api?v=2.0&ak=【你的密匙】"></script> <div class="mapbox"><div class="mapbigest"></div><div class="zw"></div><div id="allmap"></div></div>
<script type="text/javascript">
//手机版点击才可拖动
$(document).on("click",".mapbox .zw",function(){
$(this).hide();
}); //地图最大化
$(document).on("click",".mapbigest",function(){
if($(this).parent(".mapbox").hasClass("on")){
$(this).parent(".mapbox").find(".zw").show();
}else{
$(this).parent(".mapbox").find(".zw").hide();
}
$(this).parent(".mapbox").toggleClass("on");
baidu_map();
}); //键盘Esc退出全屏
var isPiss = 0;
document.onkeydown = function(event) {
var e = event || window.event || arguments.callee.caller.arguments[0];
if(e.keyCode == 27){
if($(".mapbox").hasClass("on")){
$(".mapbox").removeClass("on");
baidu_map();
}
}
}; function pix(p)
{
p = p/100000;
return p;
} function poi_move(x,y,type)
{
//x: +往右偏移 -往偏左移
//y: +往上偏移 -往偏下移
arr = type.split(",");
xarr = xpoi = new Array();
if(type){
if(arr){
for(i=0;i<arr.length;i++)
{
xarr.push(arr[i].split(":"));
}
}
if(xarr){
for(i=0;i<xarr.length;i++)
{
if(xarr[i][0]=="left"){
x = x+pix(xarr[i][1]);
}else if(xarr[i][0]=="right"){
x = x-pix(xarr[i][1]);
}else if(xarr[i][0]=="top"){
y = y-pix(xarr[i][1]);
}else if(xarr[i][0]=="bottom"){
y = y+pix(xarr[i][1]);
}
console.log(xarr[i])
}
}
}
xpoi["x"] = x;
xpoi["y"] = y;
return xpoi;
} function baidu_map()
{
//公司名称
var my_company = '公司名称';
//公司地址
var my_address = '地址:公司地址';
//坐标
var my_poix = 113.3404460125;
var my_poiy = 22.9967992377;
//地图位置偏移
var move_type = "left:15,top:15"; // 往左偏移15像素,往上偏移15像素 poi_arr = poi_move(my_poix,my_poiy,move_type);
my_poix_p = poi_arr["x"];
my_poiy_p = poi_arr["y"]; // 百度地图API功能
var map = new BMap.Map("allmap");
var point = new BMap.Point(my_poix,my_poiy)
var point_p = new BMap.Point(my_poix_p,my_poiy_p);
var myIcon = new BMap.Icon("", new BMap.Size(19,33)); //自定义图标
var marker = new BMap.Marker(point,{icon:myIcon});
map.addOverlay(marker); // 将标注添加到地图中
//marker.setAnimation(BMAP_ANIMATION_BOUNCE); // 跳动的动画
map.centerAndZoom(point_p, 18);
var opts = {
width : 200, // 信息窗口宽度
height: 60, // 信息窗口高度
//title : "" , // 信息窗口标题
//enableMessage:true,//设置允许信息窗发送短息
//message:""
}
var infoWindow = new BMap.InfoWindow('<strong style="color:#d55522;font-size:14px;padding-bottom:10px;">'+my_company+'</strong><p>'+my_address+'</p>', opts); // 创建信息窗口对象 var top_left_control = new BMap.ScaleControl({anchor: BMAP_ANCHOR_TOP_LEFT});// 左上角,添加比例尺
var top_left_navigation = new BMap.NavigationControl(); //左上角,添加默认缩放平移控件 map.addControl(top_left_control);
map.addControl(top_left_navigation); map.openInfoWindow(infoWindow,point); //开启信息窗口
marker.addEventListener("click", function(){
map.openInfoWindow(infoWindow,point); //开启信息窗口
});
}
baidu_map();
</script>
网页百度地图api,支持位置偏移的更多相关文章
- Python 读取照片的信息:拍摄时间、拍摄设备、经纬度等,以及根据经纬度通过百度地图API获取位置
通过第三方库exifread读取照片信息.exifread官网:https://pypi.org/project/ExifRead/ 一.安装exifreadpip install exifread ...
- 网页百度地图API相关资料
百度地图API——网页URI接口.手机网页点击直接导航:js生成一个地图网页 或 直接跳转到百度导航界面 http://developer.baidu.com/map/index.php?title= ...
- 百度地图分布图(百度地图api司机位置实时定位分布图)
就类似于我们使用共享单车app的时候,可以看到我们周围的空闲单车分布.e代驾在后台管理系统需求里也有此功能,目的是为了实时看到目标城市下的所有司机状态. 一.controller //controll ...
- 百度地图API位置偏移的校准算法
转自极客人原文 百度地图API位置偏移的校准算法 在开始使用百度地图API进行开发时可能会遇到一件相当奇怪的事情,使用百度定位的经纬度在地图上显示相当不准确,这一问题我在微信开发和安卓开始时都遇到过. ...
- 通过百度地图API实现搜索地址--第三方开源--百度地图(三)
搜索地址功能是建立在能够通过百度地图API获取位置的基础上 通过百度地图定位获取位置详情:http://www.cnblogs.com/zzw1994/p/5008134.html package c ...
- 【百度地图API】建立全国银行位置查询系统(二)——怎样为地图添加控件
原文:[百度地图API]建立全国银行位置查询系统(二)--怎样为地图添加控件 <摘要>你将在第二章中学会以下知识: 使用手写代码的利器——notepad++: 如何为地图添加控件——鱼骨. ...
- 【百度地图API】建立全国银行位置查询系统(一)——如何创建地图
原文:[百度地图API]建立全国银行位置查询系统(一)--如何创建地图 <摘要>你将在第一章中学会以下知识: 如何创建一个网页文件 怎样利用百度地图API建立一张2D地图,以及3D地图 如 ...
- 如何在网页中调用百度地图api
我想在木有提供地图接口的年代,前端工程师门要么只写上企业的具体地址,要么就是用一张标有自己位置的地图图片.但是现在不一样啦!为了增强用户体验,谷歌,甚至百度都很开放了,你可以在他们的网站上找到地图接口 ...
- 网页嵌入百度地图和使用百度地图api自定义地图的详细步骤
在网页中插入百度地图 如果想在自己的网页上面加入百度地图的话,可以用百度地图的api.具体使用方法如下: 第一步:进入百度创建地图的网站http://api.map.baidu.com/lbsapi/ ...
随机推荐
- chrony软件
chrony简介 Chrony是一个开源的自由软件,它能保持系统时钟与时钟服务器(NTP)同步,让时间保持精确. 它由两个程序组成:chronyd和chronyc. chronyd是一个后台运行的守护 ...
- day13_7.15 迭代器和生成器
1.迭代器 迭代就是一个更新换代的过程,每次迭代都必须基于上一次的结果. 迭代器就是迭代取值的工具.举个例子: while True: print('循环输出') 此代码会无限循环输出文字,是个死循环 ...
- 04-人脸识别-triplets loss 的解释(转载)
转载至: https://blog.csdn.net/tangwei2014/article/details/46788025 下面是内容: [前言] 最近,learning to rank 的思想逐 ...
- Tkinter 鼠标键盘事件(一)
一: 鼠标事件 <Button-1> 鼠标左键单击 ...
- Graph Embedding Review:Graph Neural Network(GNN)综述
作者简介: 吴天龙 香侬科技researcher 公众号(suanfarensheng) 导言 图(graph)是一个非常常用的数据结构,现实世界中很多很多任务可以描述为图问题,比如社交网络,蛋白体 ...
- LeetCode 241. Different Ways to Add Parentheses为运算表达式设计优先级 (C++)
题目: Given a string of numbers and operators, return all possible results from computing all the diff ...
- Mysql 时间和日期函数
参考文章 1 时间函数 当前日期和时间 select now(); 2 得到昨天的日期 CURDATE() 当前日期 select CURDATE()-1; -- curdate 3 添加时间间隔 当 ...
- 区块链自问自答 day2
区块链自问自答 day2 区块链的自治性是如何达成的?为什么能够在去信任的环境下自由安全地交换数据? 区块链中有众多的节点,包含了恶意节点.故障节点.正常节点,想要这些节点共同做出一致的决定就需要 ...
- __str__与__repr__的触发顺序总结
1.__str__是个内置的方法,无需使用者去调用,其会在满足某一条件时自动触发.那么要触发它运行都有哪些条件呢? 有三种条件,分别为:print , str , %s 2.__repr__同样是个内 ...
- [LeetCode] 46. Permutations 全排列
Given a collection of distinct integers, return all possible permutations. Example: Input: [1,2,3] O ...