07. Web大前端時代之:HTML5+CSS3入門系列~H5 地理位置

来源:http://www.cnblogs.com/dunitian/archive/2016/01/26/5161606.html
-Advertisement-
Play Games

Web大前端時代之:HTML5+CSS3入門系列:http://www.cnblogs.com/dunitian/p/5121725.html 定位類型 IP 定位 優點 任何位置都可用 在伺服器端處理 缺點 不精確,一般精確到城市 運算代價大,可能出錯 代理的時候就可能定位出錯了 GPS定位 優點...


Web大前端時代之:HTML5+CSS3入門系列:http://www.cnblogs.com/dunitian/p/5121725.html

定位類型

IP 定位

優點

任何位置都可用

在伺服器端處理

缺點

不精確,一般精確到城市

運算代價大,可能出錯

代理的時候就可能定位出錯了

GPS定位

優點

定位精準

缺點

定位時間長,耗電量大

室內效果不好

需要硬體設備支持

Wi-Fi定位

優點

定位精準

簡單快捷定位

可以在室內使用

缺點

適合大城市,WIFI接入點少的地方效果差

手機定位

優點

定位精準

簡單快捷定位

可以在室內使用

缺點

在基站較少的偏遠地區效果不好

自定義定位

編程計算位置

用戶自定義輸入

相容檢測

navigator.geolocation

<script type="text/javascript">

if (window.navigator.geolocation) {

alert('支持H5 Geolocation');

} else {

alert('不支持H5 Geolocation');

}

</script>

地理定位

navigator.geolocation.getCurrentPositionsuccessFun,errorFun,Options

參數概述

successFun

成功回調函數

eg:function(position){

//內容

}

參數

position.coords

coords.longitude

經度

十進位數

coords.latitude

緯度

十進位數

coords.accuracy

獲取到的緯度或精度的位置精度

單位:米

coords.altitude

海拔,海平面以上以米計

coords.altitudeAccuracy

位置的海拔精度

單位:米

coords.heading

方向,從正北開始以度計

coords.speed

速度,以米/每秒

timestamp

響應的日期/時間

errorFun

失敗回調函數

eg:function(error){

//內容

}

參數

error.code

1

位置信息服務被拒絕

2

獲取不到位置信息

3

獲取信息超時

message

詳細錯誤信息

很多都是英文提示。。

驗證

Options

可選參數

1秒鐘=1000毫秒

1分鐘=60000毫秒

timeout

對地理位置設置一個超時限制

單位:毫秒

maximumAge

緩存有效時間

單位:毫秒

enableHighAccuracy

高精度定位

一般不使用它

定位案例

完整案例

<div id="xyMsg"></div>

<script type="text/javascript">

if (window.navigator.geolocation) {

//定位

navigator.geolocation.getCurrentPosition(function (position) {

//成功回調函數

var cords = position.coords;

$('#xyMsg').html('經度:' + cords.longitude + ' 緯度:' + cords.latitude);

}, function (error) {

//錯誤回調函數

var errorMsg = { 1: '位置服務被拒絕', 2: '獲取不到位置信息', 3: '獲取信息超時' };

alert(errorMsg[error.code] + ":" + error.message);

}, { timeout: 4000, maximumAge: 60 * 1000 * 2 });

} else {

alert('不支持H5 Geolocation');

}

</script>

註意點

js數組的下標從1開始

綜合實戰

百度地圖定位

瞭解百度地圖

http://developer.baidu.com/map/jsdemo.htm

http://lbsyun.baidu.com/index.php?title=webapi

體驗:

http://dnt.dkill.net/DNT/HTML5/demo/map.html

定位的運用

體驗:

http://dnt.dkill.net/DNT/HTML5/demo/position.html

第三方定位

推薦使用

http://developer.baidu.com/map/jsdemo.htm#i8_1

http://developer.baidu.com/map/jsdemo.htm#i8_2

http://developer.baidu.com/map/jsdemo.htm#i8_3

http://developer.baidu.com/map/jsdemo.htm#i8_4

體驗:

http://dnt.dkill.net/DNT/HTML5/demo/baidumap.html

註意

坐標轉換問題

http://developer.baidu.com/map/jsdemo.htm#a5_2

感觸

自帶的一些東西真的很弱,不如百度,高德等API來的方便


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 步驟:1、解決方案資源管理器視窗->右擊項目屬性2、屬性視窗->應用程式->輸出類型(U)->類庫
  • 大家知道,.NET控制系統垃圾回收(一種自動回收未使用記憶體的服務)是自動的。可有時候需要手動強制進行即時垃圾回收。代碼如下:GC.Collect();
  • 之前一直覺得定時程式好神秘,後來,當我自己真正寫了一個小的定時程式時,發現其實沒有想象中的那麼難。下麵,我分享一下我自己的操作過程,希望能對大家有幫助。1)在我們的項目中添加引用文件:TaskSchedulerEngine.dll(dll定義了一個ITask介面,定義了兩個方法Initialize和...
  • 問題:在MSSQLServer中定義的存儲過程可以直接返回一個數據集,如:create procedure sp_getAllEmployeesasSELECT * FROM [NORTHWND].[dbo].[Employees]在Oracle資料庫中這樣定義是錯誤的,怎麼解決?辦法:Oracle...
  • 12-5. 自動刪除相關聯實體問題當一個實體被刪除時,你想自動刪除它相關聯的實體解決方案假設你有一個表結構由一個course (科目), course 的classes (課程),以及enrollment (登記學生選課),如 Figure 12-5所示:.Figure 12-5. The Cour...
  • 需求:工廠類根據參數生成對應類的實例。示例:RoomParts.csnamespace ReflectionFactory{ /// /// 屋子產品的零件 /// public enum RoomParts { Roof, Window...
  • Control:1 public ActionResult GetPositionName(int parentid) //發佈新職位頁面中的根據職位類別,獲取職位名稱2 {3 List categorylist2 = categorymanage.G...
  • 實現反射的類型大多數都定義在System.Reflection命名空間之下。Assembly 定義一個Assembly,它是可重用、無版本衝突並且可自我描述的公共語言運行庫應用程式構造塊。AssemblyName 完整描述程式集的唯一標識EventInfo 發現事件的屬性(Attribute)...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...