1. 功能

bMap.js 可根据地理位置调用出百度地图,采用弹出框形式

2.用法

var city = '青岛市';
var address = '香港中路';
bMap.init({
city : city,
address : address
});

3.依赖

需自行引入jquery以及layer.js(弹出框插件)

4. 局限

各模块之间耦合度过于紧密,插件化程度太低,依赖性太强

5. demo下载

地址 :http://pan.baidu.com/s/1pJAxOnT

6. 源码预览

;!(function(window){
window.bMap = {
//默认配置
config : {
width : '700px',
height : '500px',
city : '北京市',
address : '天安门',
scaleControl : true,
bMapApiUrl : 'http://api.map.baidu.com/api?v=2.0&ak=C474e91657d303114af6e8df1931a392',
bMapGeocoderUrl : 'http://api.map.baidu.com/geocoder/v2/?ak=C474e91657d303114af6e8df1931a392&output=json'
},
//中转方法,异步加载加载百度Api,
initVariable : function(){
if(!window.BMap){
this.loadScript(bMap.config.bMapApiUrl+'&callback=bMap.openMap');
}else{
this.openMap();
}
},
//加载script
loadScript : function(url){
var script = document.createElement('script');
script.setAttribute('type','text/javascript');
script.setAttribute('src',url);
document.body.appendChild(script);
},
//生成地图容器
createMapContainer : function(){
var mapContainer = document.createElement('div');
mapContainer.setAttribute('id','mapContainer');
mapContainer.style.width = this.config.width;
mapContainer.style.height = this.config.height;
document.body.appendChild(mapContainer);
return mapContainer;
},
//确定坐标位置,并去初始化BMap
openMap : function(){
$.getJSON(bMap.config.bMapGeocoderUrl+"&address="+bMap.config.address+"&city="+bMap.config.city+"&callback=?",
function(data){
if(data && data.status==0){
bMap.createBMap && bMap.createBMap(data.result);
}else{
layer.msg(data.msg?data.msg:'请求失败!');
}
});
},
//入口方法
init : function(setings){
this.config = $.extend({} , bMap.config , setings);
this.initVariable();
},
//弹出遮罩层
showLayer : function(domObj){
var mylayer = $.layer({
type: 1,
title: false,
closeBtn : [0 , true],
border : [7, 0.1, '#222', true],
shade : [0.5 , '#222' , true],
offset: ['30px','50%'],
//move: ['.juanmove', false],
area: [this.config.width,'auto'],
page: {
dom: domObj
},
close : function(){
layer.close(mylayer);
domObj.remove();// 移除dom节点,否则多次调用会导致地图显示异常
}
});
},
//调用百度地图api
createBMap : function(initObj){
var mapContainer = document.getElementById('mapContainer');
if(!mapContainer){
mapContainer = this.createMapContainer();
}
var map = new BMap.Map(mapContainer); // 创建Map实例
map.addControl(new BMap.MapTypeControl()); //地图类型组件
map.addControl(new BMap.NavigationControl());
if(this.config.scaleControl){
map.addControl(new BMap.ScaleControl());
}
map.addControl(new BMap.OverviewMapControl());
map.enableScrollWheelZoom(); //缩放
var point = new BMap.Point(initObj.location.lng,initObj.location.lat); // 初始化定位
map.centerAndZoom(point, 16); // 初始化地图,设置中心点坐标和地图级别
map.clearOverlays();
var marker = new BMap.Marker(point); // 创建标注,为要查询的地址对应的经纬度
map.addOverlay(marker);
this.showLayer(mapContainer);
}
}
})(window)

  

调用百度地图Api实现的查看地图功能的小插件的更多相关文章

  1. 调用百度地图API的总结

    因为项目要用到百度地图,所以先摸索了一下,各种功能官方都有文档,点击可查看,文章的话我就直接写我用到的功能例子了,要用可以直接复制粘贴~ 一.主要涉及到的几个接口(先申请密钥): 1.技术一:坐标转换 ...

  2. 【c#】Form调用百度地图api攻略及常见问题

    首先,在Form中调用百度地图api,我们需要使用webbrowser控件,这个在前面的文章中已经讲过了,可以参照(http://blog.csdn.net/buptgshengod/article/ ...

  3. HTML5调用百度地图API获取当前位置并直接导航目的地的方法

    <!DOCTYPE html> <html lang="zh-cmn-Hans">     <meta charset="UTF-8&quo ...

  4. 关于 WebBrowser调用百度地图API 鼠标滚轮缩放地图级别失灵的解决办法

    在桌面程序下 百度地图API的鼠标缩放地图功能可能会失灵无效! 这个原因不是API的问题 小弟试了下在WEB上面是没有问题的 于是考虑可能是WebBrowser的获取焦点问题,于是在主窗体 添加了一个 ...

  5. HTML5 调用百度地图API地理定位

    <!DOCTYPE html> <html> <title>HTML5 HTML5 调用百度地图API地理定位实例</title> <head&g ...

  6. 跨平台移动开发_PhoneGap 使用Geolocation基于所在地理位置坐标调用百度地图API

    使用Geolocation基于所在地理位置坐标调用百度地图API 效果图 示例代码 <!DOCTYPE html> <html> <head> <title& ...

  7. HTML5调用百度地图API进行地理定位实例

    自从HTML5的标准确定以后,越来越多的网站使用HTML5来进行开发.虽然对HTML5支持的浏览器不是很多,但是依然抵挡不了大伙对HTML5开发的热情.今天为大家带来的是使用HTML5调用百度地图AP ...

  8. HTML5页面直接调用百度地图API,获取当前位置,直接导航目的地

    <!DOCTYPE html> <html lang="zh-cmn-Hans"> <meta charset="UTF-8"&g ...

  9. web开发调用百度地图API + AK申请

    web开发调用百度地图API + AK申请 要使用百度地图的API我们首先需要在我们的html页面引入js----`` 如何获取百度地图ak: 1.登陆百度地图开发者平台 2.注册百度开发者账号并登陆 ...

随机推荐

  1. Eclipse安装插件的方式

    Eclipse有两种安装插件的方式,分为在线安装和手动安装,因为受到网络环境限制,推荐采用手动安装的方式,下面我们先来了解一下Eclipse手动安装插件的步骤. Eclipse手动安装插件: 第一种: ...

  2. cubieboard中使用py-kms与dnsmasq搭建局域网内全自动KMS激活环境

    众所周知,KMS激活方式是当前广大网民“试用”windows,office的最广泛的激活方式.几乎可以用于微软的全线产品. 但是在本机使用KMS类的激活工具总是有些不放心,一方面每隔180天都要重新激 ...

  3. 《Java数据结构与算法》笔记-CH5-链表-1单链表

    /** * Link节点 * 有数据项和next指向下一个Link引用 */ class Link { private int iData;//数据 private double dData;//数据 ...

  4. JVM性能优化,提高Java的伸缩性

    很多程序员在解决JVM性能问题的时候,花开了很多时间去调优应用程序级别的性能瓶颈,当你读完这本系列文章之后你会发现我可能更加系统地看待这类的问题.我说过JVM的自身技术限制了Java企业级应用的伸缩性 ...

  5. 第二百一十四天 how can I 坚持

    今天肯定有需要记录的东西. html表格. table tr rd colspan rowspan, 还有呢.没了. 睡觉,明天石洋要来泛华. 睡觉.

  6. 【多线程】JAVA多线程和并发基础面试问答(转载)

    JAVA多线程和并发基础面试问答 原文链接:http://ifeve.com/java-multi-threading-concurrency-interview-questions-with-ans ...

  7. C++11右值引用

    [C++11右值引用] 1.什么是左值?什么是右值? 左值是表达式结束后依然存在的对象:右值是表达式结束时就不再存在的对象. 2.std::move的作用是什么? std::move用于把任意类型转化 ...

  8. hdu 5491 The Next (位运算)

    http://acm.hdu.edu.cn/showproblem.php?pid=5491 题目大意:给定一个数D,它的二进制数中1的个数为L,求比D大的数的最小值x且x的二进制数中1的个数num满 ...

  9. JQuery中attr ,html,text,val,的一些用法

    attr:主要获取元素内部的属性,返回 的是属性值 html:返回当前元素(不包括他自己本身的标签,但是可以返回他自己的)的标签加上内容.仅限于返回第一个. text:和 .html() 方法不同, ...

  10. c++中的array数组和vector数组

    我觉得实验一下会记得比较牢,话不多直接上代码. 下面是array数组,感觉用的不多. //cpp 风格数组 array #include <iostream> #include <a ...