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 相关文章推荐
如何利用CSS3制作3D效果文字具体实现样式
May 02 HTML / CSS
CSS3 Media Queries详细介绍和使用实例
May 08 HTML / CSS
使用css3实现的tab选项卡代码分享
Dec 09 HTML / CSS
css3media响应式布局实例
Jul 08 HTML / CSS
利用CSS3的3D效果制作正方体
Mar 10 HTML / CSS
CSS3 实现的火焰动画
Dec 07 HTML / CSS
HTML5中canvas中的beginPath()和closePath()的重要性
Aug 24 HTML / CSS
举例详解HTML5中使用JSON格式提交表单
Jun 16 HTML / CSS
H5 canvas实现贪吃蛇小游戏
Jul 28 HTML / CSS
基于Html5实现的语音搜索功能
May 13 HTML / CSS
CSS3常见动画的实现方式
Apr 14 HTML / CSS
CSS实现九宫格布局(自适应)的示例代码
Feb 12 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
Ajax PHP分页演示
2007/01/02 PHP
PHP 创建文件(文件夹)以及目录操作代码
2010/03/04 PHP
php中利用str_pad函数生成数字递增形式的产品编号
2013/09/30 PHP
twig模板常用语句实例小结
2016/02/04 PHP
php处理带有中文URL的方法
2016/07/11 PHP
JS实现切换标签页效果实例代码
2013/11/01 Javascript
js判断ie版本号的简单实现代码
2014/03/05 Javascript
利用JavaScript检测CPU使用率自己写的
2014/03/22 Javascript
JavaScript实现强制重定向至HTTPS页面
2015/06/10 Javascript
浅谈jQuery中ajaxPrefilter的应用
2016/08/01 Javascript
微信小程序中的swiper组件详解
2017/04/14 Javascript
Node.js学习之查询字符串解析querystring详解
2017/09/28 Javascript
vue中添加mp3音频文件的方法
2018/03/02 Javascript
微信小程序template模版的使用方法
2019/04/13 Javascript
javascript开发实现贪吃蛇游戏
2020/07/31 Javascript
python读写ini文件示例(python读写文件)
2014/03/25 Python
Python类属性与实例属性用法分析
2015/05/09 Python
Python守护线程用法实例
2017/06/23 Python
基于Python os模块常用命令介绍
2017/11/03 Python
python list是否包含另一个list所有元素的实例
2018/05/04 Python
使用PIL(Python-Imaging)反转图像的颜色方法
2019/01/24 Python
python+selenium实现简历自动刷新的示例代码
2019/05/20 Python
pyqt5让图片自适应QLabel大小上以及移除已显示的图片方法
2019/06/21 Python
Django中间件基础用法详解
2019/07/18 Python
Python: 传递列表副本方式
2019/12/19 Python
Tensorflow 定义变量,函数,数值计算等名字的更新方式
2020/02/10 Python
Django中文件上传和文件访问微项目的方法
2020/04/27 Python
Keras 在fit_generator训练方式中加入图像random_crop操作
2020/07/03 Python
python实现图片,视频人脸识别(opencv版)
2020/11/18 Python
一级方程式赛车官方网上商店:F1 Store(支持中文)
2018/01/12 全球购物
机工车间主任岗位职责
2014/03/05 职场文书
事业单位考察材料范文
2014/12/25 职场文书
三年级学生评语大全
2014/12/26 职场文书
文体活动总结
2015/02/04 职场文书
休假证明书
2015/06/24 职场文书
《去年的树》教学反思
2016/02/18 职场文书