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图片边框border-image的用法
Jun 30 HTML / CSS
CSS3 选择器 伪类选择器介绍
Jan 21 HTML / CSS
推荐10个CSS3 制作的创意下拉菜单效果
Feb 11 HTML / CSS
纯css3实现鼠标经过图片显示描述的动画效果
Sep 01 HTML / CSS
深入研究HTML5实现图片压缩上传功能
Mar 25 HTML / CSS
html5播放视频且动态截图实现步骤与代码(支持safari其他未测试)
Jan 06 HTML / CSS
HTML5全屏(Fullscreen)API详细介绍
Apr 24 HTML / CSS
一些常用的HTML5模式(pattern) 总结
Jul 14 HTML / CSS
详解如何用HTML5 Canvas API控制图片的缩放变换
Mar 22 HTML / CSS
Html5饼图绘制实现统计图的方法
Aug 05 HTML / CSS
如何使用canvas绘制可移动网格的示例代码
Dec 14 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 array_push 数组函数
2009/12/26 PHP
实例讲解yii2.0在php命令行中运行的步骤
2015/12/01 PHP
PHP判断JSON对象是否存在的方法(推荐)
2016/07/06 PHP
详解yii2实现分库分表的方案与思路
2017/02/03 PHP
Jquery截取中文字符串的实现代码
2010/12/22 Javascript
jQuery 选择表格(table)里的行和列及改变简单样式
2012/12/15 Javascript
动态的创建一个元素createElement及删除一个元素
2014/01/24 Javascript
js数组去重的5种算法实现
2015/11/04 Javascript
javascript鼠标跟随运动3种效果(眼球效果,苹果菜单,方向跟随)
2016/10/27 Javascript
微信小程序 图片加载(本地,网路)实例详解
2017/03/10 Javascript
AngularJS中使用three.js的实例详解
2017/07/21 Javascript
bootstrap switch开关组件使用方法详解
2017/08/22 Javascript
npm 更改默认全局路径以及国内镜像的方法
2018/05/16 Javascript
bootstrap treeview 树形菜单带复选框及级联选择功能
2018/06/08 Javascript
微信小程序基础教程之worker线程的使用方法
2019/07/15 Javascript
layui--select使用以及下拉框实现键盘选择的例子
2019/09/24 Javascript
openlayers4.6.5实现距离量测和面积量测
2020/09/25 Javascript
python连接oracle数据库实例
2014/10/17 Python
python实现类的静态变量用法实例
2015/05/08 Python
举例讲解Python设计模式编程中的访问者与观察者模式
2016/01/26 Python
详解Python的Twisted框架中reactor事件管理器的用法
2016/05/25 Python
python和shell监控linux服务器的详细代码
2018/06/22 Python
使用Numpy读取CSV文件,并进行行列删除的操作方法
2018/07/04 Python
python使用正则筛选信用卡
2019/01/27 Python
使用django和vue进行数据交互的方法步骤
2019/11/11 Python
python实现高斯投影正反算方式
2020/01/17 Python
pandas 数据类型转换的实现
2020/12/29 Python
CSS3结构性伪类选择器九种写法
2012/04/18 HTML / CSS
选购国际女性时装设计师品牌:IFCHIC(支持中文)
2018/04/12 全球购物
会计专业应届生自荐信
2014/02/07 职场文书
安全教育月活动总结
2014/05/05 职场文书
法院干警四风问题自我剖析材料
2014/09/29 职场文书
综合管理员岗位职责
2015/02/11 职场文书
2016感恩父亲节主题广播稿
2015/12/18 职场文书
市直属机关2016年主题党日活动总结
2016/04/05 职场文书
分享一个vue实现的记事本功能案例
2022/04/11 Vue.js