jquery与google map api结合使用 控件,监听器


Posted in Javascript onMarch 04, 2010

Google Maps JavaScript. API可以让您在自己的网页上使用Google地图.在使用API之前,您应该先申请一
个API key,申请API key请到:http://code.google.com/apis/maps/signup.html。这里假设你获取到的key是:ABQIAA。
关于jquery的获取不再此处累赘,网上有许多关于jquery的介绍。
接着我们就使用JQuery和Google Maps JavaScript. API来结合表现一下google map的有趣的地图效果,进而达到熟悉Google Maps JavaScript. API的目标。
先来个HelloChina:
(1)在html文件中编写html代码:
map.html

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Strict//EN" 
"http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd"> 
<html xmlns="http://www.w3.org/1999/xhtml"> 
<head> 
<meta. http-equiv="content-type" content="text/html; charset=utf-8"/> 
<title>Google Maps 与 JQuery结合使用</title> 
<script. src="http://maps.google.com/maps?file=api&v=2&key=ABQIAA" type="text/javascript"></script> 
<script. type="text/javascript" src="jquery.js"></script> 
<script. type="text/javascript" src="map.js"></script> 
</head> 
<body> 
<div id="map" style="top:100px;left:300px;width: 600px; height: 400px"></div> 
<div id="message"></div> 
</body> 
</html>

(2)在js文件中编写js代码
map.js
$(document).ready(function() 
{ 
//检查浏览器兼容性 
if (GBrowserIsCompatible()) { 
var map = new GMap2(document.getElementById("map")); 
map.setCenter(new GLatLng(36.94, 106.08), 4);//中国的经纬度以及地方放大倍数 
map.setMapType(G_SATELLITE_MAP); 
//document卸载时触发 
$(window).unload(function (){ 
$('.').unbind(); 
GUnload(); 
}); 
}else 
{ 
alert('你使用的浏览器不支持 Google Map!'); 
} 
});

(3)在地址栏输入页面对应的地址(确定key是和你输入地址或域名匹配的),查看效果图,可以看到中国位于地图的中央。
HolloChina的效果图
地图的移动和变换
(1)修改javascript代码如下:
map.js
$(document).ready(function() 
{ 
if (GBrowserIsCompatible()) { 
var map = new GMap2(document.getElementById("map")); 
map.setCenter(new GLatLng(36.94, 106.08), 4); 
//4秒后移动 
window.setTimeout(function() { 
map.panTo(new GLatLng(35.746512259918504,78.90625)); 
}, 4000); 
$(window).unload(function (){ 
$('.').unbind(); 
GUnload(); 
}); 
}else 
{ 
alert('你使用的浏览器不支持 Google Map!'); 
} 
});

(2)输入对应的地址查看,等上4秒钟,就可以看到地图的中心移动到中国的西部(大概的位置):
地图中心移动到中国的西部
添加控件并修改地图类型
修改javascript代码如下:
map.js
$(document).ready(function() 
{ 
if (GBrowserIsCompatible()) { 
var map = new GMap2(document.getElementById("map")); 
//小型伸缩控制器 
map.addControl(new GSmallMapControl()); 
//地图类型控制器 
map.addControl(new GMapTypeControl()); 
map.setCenter(new GLatLng(36.94,106.08),4); 
//将地图设置为卫星地图 
map.setMapType(G_SATELLITE_MAP);//修改地图类型 
$(window).unload(function (){ 
$('.').unbind(); 
GUnload(); 
}); 
}else 
{ 
alert('你使用的浏览器不支持 Google Map!'); 
} 
});

刷新页面,看到的效果是卫星地图的左上角有一个小的伸缩控件,右上角是地图选择的控件
加入控件后的效果图
添加事件监听器并开启滚轮伸缩效果
修改javascript代码:
map.js
$(document).ready(function() 
{ 
if (GBrowserIsCompatible()) { 
var map = new GMap2(document.getElementById("map")); 
map.addControl(new GSmallMapControl()); 
map.addControl(new GMapTypeControl()); 
//开启滚轮伸缩效果--鼠标滚轮向前滚放大地图,反之缩小 
map.enableScrollWheelZoom(); 
//添加moveend事件监听器 
GEvent.addListener(map, "moveend", function() { 
var center = map.getCenter(); 
//在这个DIV中显示地图中心的经纬度 
$('#message').text(center.toString()); 
}); 
map.setCenter(new GLatLng(36.94,106.08),4); 
$(window).unload(function (){ 
$('.').unbind(); 
GUnload(); 
}); 
}else 
{ 
alert('你使用的浏览器不支持 Google Map!'); 
} 
});

此时的地图在滚动滚轮的时候会发生伸缩,而拖动完地图后,地图左侧的坐标信息会跟着变。
Javascript 相关文章推荐
javascript flash下fromCharCode和charCodeAt方法使用说明
Jan 12 Javascript
javascript快速排序算法详解
Sep 17 Javascript
微信JS接口汇总及使用详解
Jan 09 Javascript
JavaScript中判断变量是数组、函数或是对象类型的方法
Feb 25 Javascript
基于jQuery和CSS3制作数字时钟附源码下载(jquery篇)
Nov 24 Javascript
JS常用加密编码与算法实例总结
Dec 22 Javascript
详解vue-Resource(与后端数据交互)
Jan 16 Javascript
vue2.0 与 bootstrap datetimepicker的结合使用实例
May 22 Javascript
bootstrap table使用入门基本用法
May 24 Javascript
js弹性势能动画之抛物线运动实例详解
Jul 27 Javascript
JavaScript学习笔记之数组基本操作示例
Jan 09 Javascript
分享JS表单验证源码(带错误提示及密码等级)
Jan 05 Javascript
jquery 打开窗口返回值实现代码
Mar 04 #Javascript
jQuery入门知识简介
Mar 04 #Javascript
jQuery 获取URL参数的插件
Mar 04 #Javascript
老鱼 浅谈javascript面向对象编程
Mar 04 #Javascript
javascript实现的像java、c#之类的sleep暂停的函数代码
Mar 04 #Javascript
ExtJs之带图片的下拉列表框插件
Mar 04 #Javascript
JavaScript replace(rgExp,fn)正则替换的用法
Mar 04 #Javascript
You might like
discuz的php防止sql注入函数
2011/01/17 PHP
详谈php中 strtr 和 str_replace 的效率问题
2017/05/14 PHP
extjs fckeditor集成代码
2009/05/10 Javascript
JavaScript 三种创建对象的方法
2009/10/16 Javascript
javascript针对DOM的应用分析(四)
2012/04/15 Javascript
javascript学习笔记(十五) js间歇调用和超时调用
2012/06/20 Javascript
jquery form 隐藏的input 选择
2014/04/29 Javascript
js简单的弹出框有关闭按钮
2014/05/05 Javascript
javascript正则表达式中分组详解
2016/07/17 Javascript
轻松实现js弹框显示选项
2016/09/13 Javascript
bootstrapValidator bootstrap-select验证不可用的解决办法
2017/01/11 Javascript
AngularJS 中ui-view传参的实例详解
2017/08/25 Javascript
jquery的 filter()方法使用教程
2018/03/22 jQuery
vue源码学习之Object.defineProperty 对数组监听
2018/05/30 Javascript
基于JS实现带动画效果的流程进度条
2018/06/01 Javascript
基于Bootstrap下拉框插件bootstrap-select使用方法详解
2018/08/07 Javascript
一个因@click.stop引发的bug的解决
2019/01/08 Javascript
layui 关闭open弹出框 刷新table表格页面的方法
2019/09/16 Javascript
weui中的picker使用js进行动态绑定数据问题
2019/11/06 Javascript
Vue实现图片与文字混输效果
2019/12/04 Javascript
Vue中qs插件的使用详解
2020/02/07 Javascript
Bottle框架中的装饰器类和描述符应用详解
2017/10/28 Python
TF-IDF算法解析与Python实现方法详解
2017/11/16 Python
python解析html提取数据,并生成word文档实例解析
2018/01/22 Python
JavaScript实现一维数组转化为二维数组
2018/04/17 Python
Python字典创建 遍历 添加等实用基础操作技巧
2018/09/13 Python
Python enumerate内置库用法解析
2020/02/24 Python
Python操作word文档插入图片和表格的实例演示
2020/10/25 Python
python中翻译功能translate模块实现方法
2020/12/17 Python
新西兰领先的鞋类和靴子网上商城:Merchant 1948
2017/09/08 全球购物
房屋出租协议书
2014/04/10 职场文书
区政府领导班子个人对照检查材料
2014/09/25 职场文书
校车安全管理责任书
2015/05/11 职场文书
文明上网主题班会
2015/08/14 职场文书
初中体育教学随笔
2015/08/15 职场文书
情感电台广播稿
2015/08/18 职场文书