html5指南-7.geolocation結(jié)合google maps開發(fā)一個小的應(yīng)用

今天我們將把html5的geolocation結(jié)合google maps開發(fā)一個小的應(yīng)用。google maps的api地址:https://developers.google.com/maps/documentation/javascript/?hl=zh-CN。
調(diào)用google maps,實現(xiàn)需要添加js引用<script type="text/javascript" src="http://maps.google.com/maps/api/js?sensor=false"></script>,其中sensor參數(shù)的具體含義:
要使用 Google Maps API,您需要指明自己的應(yīng)用程序在任何 Maps API 庫或服務(wù)請求中是否是使用傳感器(如 GPS)來確定用戶所處位置的。這對移動設(shè)備尤為重要。如果您的 Google Maps API 應(yīng)用程序使用任何形式的傳感器確定訪問您的應(yīng)用程序的設(shè)備的位置,那么您必須通過將 sensor 參數(shù)值設(shè)置為 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方法就是調(diào)用google maps api初始化地圖,他需要設(shè)置options對象,在調(diào)用地圖初始化的時候使用。
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();
}
}
成功獲取位置信息后,調(diào)用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
相關(guān)文章
使用HTML5 Geolocation實現(xiàn)一個距離追蹤器
HTML5 Geolocation(地理定位)用于定位用戶的位置,那么怎么實現(xiàn)一個距離追蹤器呢?下面小編給大家?guī)砹嘶贖TML5 Geolocation實現(xiàn)一個距離追蹤器的實例代碼,感興趣的朋2018-04-09- 這篇文章主要介紹了Html5 Geolocation獲取地理位置信息實例,具有一定的參考價值,有興趣的同學可以了解一下。2016-12-09
HTML5的Geolocation地理位置定位API使用教程
地理位置(Geolocation)是 HTML5 的重要特性之一,提供了確定用戶位置的功能,借助這個特性能夠開發(fā)基于位置信息的應(yīng)用,今天這篇文章就向大家介紹一下HTML5的Geolocation地理2016-05-12html5指南-4.使用Geolocation實現(xiàn)定位功能
今天我們要學習的是使用Geolocation實現(xiàn)定位功能。我們可以通過navigator.geolocation獲取Geolocation對象,感興趣的朋友可以了解下2013-01-07- Geolocation是HTML5標準下的一個Web API,利用它可以獲取設(shè)備的當前位置信息(坐標),本篇文章主要介紹了三個方法,非常具有實用價值,需要的朋友可以參考下2018-12-04