佳木斯湛栽影视文化发展公司

主頁(yè) > 知識(shí)庫(kù) > html5指南-7.geolocation結(jié)合google maps開發(fā)一個(gè)小的應(yīng)用

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

熱門標(biāo)簽:檢查注冊(cè)表項(xiàng) 百度競(jìng)價(jià)點(diǎn)擊價(jià)格的計(jì)算公式 硅谷的囚徒呼叫中心 使用U盤裝系統(tǒng) 美圖手機(jī) 網(wǎng)站建設(shè) 阿里云 智能手機(jī)
今天我們將把html5的geolocation結(jié)合google maps開發(fā)一個(gè)小的應(yīng)用。google maps的api地址:https://developers.google.com/maps/documentation/javascript/?hl=zh-CN。
調(diào)用google maps,實(shí)現(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 庫(kù)或服務(wù)請(qǐng)求中是否是使用傳感器(如 GPS 定位器)來確定用戶所處位置的。這對(duì)移動(dòng)設(shè)備尤為重要。如果您的 Google Maps API 應(yīng)用程序使用任何形式的傳感器確定訪問您的應(yīng)用程序的設(shè)備的位置,那么您必須通過將 sensor 參數(shù)值設(shè)置為 true 以聲明這一點(diǎn)。
html部分比較簡(jiǎn)單,只需要準(zhǔn)備一個(gè)div就可

復(fù)制代碼
代碼如下:

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

js代碼的框架如下

復(fù)制代碼
代碼如下:

<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對(duì)象,在調(diào)用地圖初始化的時(shí)候使用。

復(fù)制代碼
代碼如下:

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方法獲取定位信息。

復(fù)制代碼
代碼如下:

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上。

復(fù)制代碼
代碼如下:

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

標(biāo)簽:煙臺(tái) 黃山 賀州 懷化 湘潭 山南 湖北 通遼

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《html5指南-7.geolocation結(jié)合google maps開發(fā)一個(gè)小的應(yīng)用》,本文關(guān)鍵詞  ;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問題,煩請(qǐng)?zhí)峁┫嚓P(guān)信息告之我們,我們將及時(shí)溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無關(guān)。
  • 相關(guān)文章
  • 收縮
    • 微信客服
    • 微信二維碼
    • 電話咨詢

    • 400-1100-266
    汉寿县| 麻江县| 泽州县| 德庆县| 汉阴县| 涿州市| 威海市| 赤水市| 宁津县| 阜新市| 祥云县| 台北市| 郴州市| 苏尼特左旗| 余江县| 浦东新区| 聂拉木县| 开鲁县| 东海县| 色达县| 宜阳县| 修文县| 奉节县| 馆陶县| 东乌| 车致| 兰坪| 玛曲县| 黑山县| 东城区| 乌苏市| 信丰县| 双江| 龙里县| 团风县| 大洼县| 库尔勒市| 板桥市| 通山县| 福海县| 务川|