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美化表单控件全集
Jun 29 HTML / CSS
CSS3 重置iphone浏览器按钮input,select等表单元素的默认样式
Oct 11 HTML / CSS
CSS3解析抖音LOGO制作的方法步骤
Apr 11 HTML / CSS
HTML高亮关键字的实现代码
Oct 22 HTML / CSS
20佳惊艳的HTML5应用程序示例分享
May 03 HTML / CSS
HTML5 声明兼容IE的写法
May 16 HTML / CSS
简单html5代码获取地理位置
Mar 31 HTML / CSS
Application Cache未缓存文件无法访问无法加载问题
May 31 HTML / CSS
html5 div布局与table布局详解
Nov 16 HTML / CSS
使用spring mvc+localResizeIMG实现HTML5端图片压缩上传的功能
Dec 16 HTML / CSS
详解android与HTML混合开发总结
Jun 06 HTML / CSS
el-form每行显示两列底部按钮居中效果的实现
Aug 05 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加密解密函数代码
2013/06/19 PHP
PHP实现显示照片exif信息的方法
2014/07/11 PHP
PHP实现文件上传功能实例代码
2017/05/18 PHP
js 通用订单代码
2013/12/23 Javascript
nodejs实现的一个简单聊天室功能分享
2014/12/06 NodeJs
js实现头像图片切割缩放及无刷新上传图片的方法
2015/07/17 Javascript
深入理解JavaScript程序中内存泄漏
2016/03/17 Javascript
动态设置form表单的action属性的值的简单方法
2016/05/25 Javascript
Angularjs中的页面访问权限怎么设置
2016/11/11 Javascript
JS表格组件神器bootstrap table使用指南详解
2017/04/12 Javascript
利用node.js实现反向代理的方法详解
2017/07/24 Javascript
JavaScript实现省市联动过程中bug的解决方法
2017/12/04 Javascript
vue父组件向子组件(props)传递数据的方法
2018/01/02 Javascript
Vue SSR 组件加载问题
2018/05/02 Javascript
JS如何生成动态列表
2020/09/22 Javascript
JavaScript代码实现简单计算器
2020/12/27 Javascript
[00:23]魔方之谜解锁款式
2018/12/20 DOTA
Python使用PIL库实现验证码图片的方法
2016/03/11 Python
利用Python实现Windows下的鼠标键盘模拟的实例代码
2017/07/13 Python
Python元组操作实例分析【创建、赋值、更新、删除等】
2017/07/24 Python
python用列表生成式写嵌套循环的方法
2018/11/08 Python
Django异步任务之Celery的基本使用
2019/03/23 Python
如何利用Python模拟GitHub登录详解
2019/07/15 Python
如何基于python实现归一化处理
2020/01/20 Python
浅谈在JupyterNotebook下导入自己的模块的问题
2020/04/16 Python
Python 解析库json及jsonpath pickle的实现
2020/08/17 Python
python中实现词云图的示例
2020/12/19 Python
Unineed旗下时尚轻奢网站:FABHunt
2019/05/13 全球购物
校班主任推荐信范文
2013/12/03 职场文书
总经理秘书的岗位职责
2013/12/27 职场文书
促销活动总结模板
2014/07/01 职场文书
食品安全演讲稿
2014/09/01 职场文书
市场营销计划书
2015/01/17 职场文书
新人入职感言
2015/07/31 职场文书
致男子1500米运动员的广播稿
2019/11/08 职场文书
Pycharm连接远程服务器并远程调试的全过程
2021/06/24 Python