html5指南-7.geolocation结合google maps开发一个小的应用


Posted in HTML / CSS onJanuary 07, 2013

今天我们将把html5的geolocation结合google maps开发一个小的应用。google maps的api地址:https://developers.google.com/maps/documentation/javascript/?hl=zh-CN。
调用google maps,实现需要添加js引用<script type="text/javascript" src="http://maps.google.com/maps/api/js?sensor=false"></script>,其中sensor参数的具体含义:
要使用 Google Maps API,您需要指明自己的应用程序在任何 Maps API 库或服务请求中是否是使用传感器(如 GPS 定位器)来确定用户所处位置的。这对移动设备尤为重要。如果您的 Google Maps API 应用程序使用任何形式的传感器确定访问您的应用程序的设备的位置,那么您必须通过将 sensor 参数值设置为 true 以声明这一点。
html部分比较简单,只需要准备一个div就可

复制代码
代码如下:

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

js代码的框架如下
复制代码
代码如下:

<script type="text/javascript">
var map;
var browserSupport = false;
var attempts = 0;
$(document).ready(function () {
//初始化地图

InitMap();
//定位
getLocation();

//定位跟踪
watchLocation();
});
function InitMap() {
/* Set all of the options for the map */
var options = {
};
/* Create a new Map for the application */
map = new google.maps.Map($('#map')[0], options);
}
/*
* If the W3C Geolocation object is available then get the current
* location, otherwise report the problem
*/
function getLocation() {
}
function watchLocation() {
}
/* Plot the location on the map and zoom to it */
function plotLocation(position) {
}
/* Report any errors using this function */
function reportProblem(e) {
}
</script>


InitMap方法就是调用google maps api初始化地图,他需要设置options对象,在调用地图初始化的时候使用。
复制代码
代码如下:

function InitMap() {
/* Set all of the options for the map */
var options = {
zoom: 4,
center: new google.maps.LatLng(38.6201, -90.2003),
mapTypeId: google.maps.MapTypeId.ROADMAP,
mapTypeControl: true,
mapTypeControlOptions: {
style: google.maps.MapTypeControlStyle.HORIZONTAL_BAR,
position: google.maps.ControlPosition.BOTTOM_CENTER
},
panControl: true,
panControlOptions: {
position: google.maps.ControlPosition.TOP_RIGHT
},
zoomControl: true,
zoomControlOptions: {
style: google.maps.ZoomControlStyle.LARGE,
position: google.maps.ControlPosition.LEFT_CENTER
},
scaleControl: true,
scaleControlOptions: {
position: google.maps.ControlPosition.BOTTOM_LEFT
},
streetViewControl: true,
streetViewControlOptions: {
position: google.maps.ControlPosition.LEFT_TOP
}
};
/* Create a new Map for the application */
map = new google.maps.Map($('#map')[0], options);
}

getLocation和watchLocation方法获取定位信息。
复制代码
代码如下:

function getLocation() {
/* Check if the browser supports the W3C Geolocation API */
if (navigator.geolocation) {
browserSupport = true;
navigator.geolocation.getCurrentPosition(plotLocation, reportProblem, { timeout: 45000 });
} else {
reportProblem();
}
}
function watchLocation() {
/* Check if the browser supports the W3C Geolocation API */
if (navigator.geolocation) {
browserSupport = true;
navigator.geolocation.watchPosition(plotLocation, reportProblem, { timeout: 45000 });
} else {
reportProblem();
}
}

成功获取位置信息后,调用plotLocation方法把位置显示在google maps上。
复制代码
代码如下:

function plotLocation(position) {
attempts = 0;
var point = new google.maps.LatLng(position.coords.latitude, position.coords.longitude);
var marker = new google.maps.Marker({
position: point
});
marker.setMap(map);
map.setCenter(point);
map.setZoom(15);
}

demo下载地址:googleMapGeolocation.rar
HTML / CSS 相关文章推荐
详解CSS的border边框属性及其在CSS3中的新特性
May 10 HTML / CSS
时尚的CSS3进度条效果
Feb 22 HTML / CSS
CSS3实现的闪烁跳跃进度条示例(附源码)
Aug 19 HTML / CSS
详解CSS3选择器的使用方法汇总
Nov 24 HTML / CSS
html5 的a标签 Href 拨电话的写法
Nov 04 HTML / CSS
HTML5的download属性详细介绍和使用实例
Apr 23 HTML / CSS
使用html5 canvas创建太空游戏的示例
May 08 HTML / CSS
借助HTML5 Canvas API制作一个简单的猜字游戏
Mar 25 HTML / CSS
canvas绘制视频封面的方法
Feb 05 HTML / CSS
HTML5 视频播放(video),JavaScript控制视频的实例代码
Oct 08 HTML / CSS
前后端结合实现amazeUI分页效果
Aug 21 HTML / CSS
CSS中实现动画效果-附案例
Feb 28 HTML / CSS
在html5的Canvas上绘制椭圆的几种方法总结
Jan 07 #HTML / CSS
html5构建触屏网站之touch事件介绍
Jan 07 #HTML / CSS
html5构建触屏网站之网站尺寸探讨
Jan 07 #HTML / CSS
使用css创建三角形 使用CSS3创建3d四面体原理及代码(html5实践)
Jan 06 #HTML / CSS
html5中canvas学习笔记2-判断浏览器是否支持canvas
Jan 06 #HTML / CSS
html5中canvas学习笔记1-画板的尺寸与实际显示尺寸
Jan 06 #HTML / CSS
HTML5本地存储之Database Storage应用介绍
Jan 06 #HTML / CSS
You might like
通过PHP修改Linux或Unix口令的方法分享
2012/01/30 PHP
php对象工厂类完整示例
2018/08/09 PHP
JScript中使用ADODB.Stream判断文件编码的代码
2008/06/09 Javascript
JavaScript 封装Ajax传递的数据代码
2009/06/05 Javascript
js注意img图片的onerror事件的分析
2011/01/01 Javascript
给Flash加一个超链接(推荐使用透明层)兼容主流浏览器
2013/06/09 Javascript
复制js对象方法(详解)
2013/07/08 Javascript
Jquery焦点与失去焦点示例应用
2014/06/10 Javascript
js闭包的用途详解
2014/11/09 Javascript
详解基于electron制作一个node压缩图片的桌面应用
2019/01/29 Javascript
Vue组件之高德地图地址选择功能的实例代码
2019/06/21 Javascript
解决小程序无法触发SESSION问题
2020/02/03 Javascript
Node.js API详解之 net模块实例分析
2020/05/18 Javascript
在vue中实现清除echarts上次保留的数据(亲测有效)
2020/09/09 Javascript
Python闭包实现计数器的方法
2015/05/05 Python
Python使用CMD模块更优雅的运行脚本
2015/05/11 Python
详解Python的Django框架中inclusion_tag的使用
2015/07/21 Python
python制作爬虫爬取京东商品评论教程
2016/12/16 Python
Python正则表达式非贪婪、多行匹配功能示例
2017/08/08 Python
python flask中静态文件的管理方法
2018/03/20 Python
Python之循环结构
2019/01/15 Python
Python之qq自动发消息的示例代码
2021/02/18 Python
Booking.com美国:全球酒店预订网站
2017/04/18 全球购物
瑞典时尚服装购物网站:Miinto.se
2017/10/30 全球购物
LODI女鞋在线商店:阿利坎特的鞋类品牌
2019/02/15 全球购物
什么是TCP/IP
2014/07/27 面试题
C# Debug和Testing相关面试题
2015/10/25 面试题
WebSphere面试题:在WebSphere里面如何部署一个应用
2015/08/02 面试题
生物技术专业毕业生求职信范文
2013/12/14 职场文书
国际商务专业职业生涯规划书范文
2014/01/17 职场文书
静心口服夜广告词
2014/03/20 职场文书
求职信范文怎么写
2015/03/19 职场文书
2016师德师风学习心得体会
2016/01/12 职场文书
2016年世界人口日宣传活动总结
2016/04/05 职场文书
MySQL系列之二 多实例配置
2021/07/02 MySQL
如何利用golang运用mysql数据库
2022/03/13 Golang