第9章位置服務與地圖應用1_第1頁
第9章位置服務與地圖應用1_第2頁
第9章位置服務與地圖應用1_第3頁
第9章位置服務與地圖應用1_第4頁
第9章位置服務與地圖應用1_第5頁
已閱讀5頁,還剩47頁未讀 繼續免費閱讀

下載本文檔

版權說明:本文檔由用戶提供并上傳,收益歸屬內容提供方,若內容存在侵權,請進行舉報或認領

文檔簡介

第9章位置服務與地圖應用本章學習目標:了解位置服務的概念了解地圖密鑰的申請方法掌握獲取位置信息的方法掌握MapView和MapController的使用方法掌握Google地圖覆蓋層的使用方法

9.1位置服務位置服務位置服務(Location-BasedServices,LBS),又稱定位服務或基于位置的服務,融合了GPS定位、移動通信、導航等多種技術,提供了與空間位置相關的綜合應用服務位置服務首先在日本得到商業化的應用2001年7月,DoCoMo發布了第一款具有三角定位功能的手持設備2001年12月,KDDI發布第一款具有GPS功能的手機基于位置的服務發展迅速,已涉及到商務、醫療、工作和生活的各個方面,為用戶提供定位、追蹤和敏感區域警告等一系列服務

9.1位置服務位置服務Android平臺支持提供位置服務的API,在開發過程中主要用到LocationManager和LocationProviders對象LocationManager可以用來獲取當前的位置,追蹤設備的移動路線,或設定敏感區域,在進入或離開敏感區域時設備會發出特定警報LocationProviders是能夠提供定位功能的組件集合,集合中的每種組件以不同的技術提供設備的當前位置,區別在于定位的精度、速度和成本等方面9.1位置服務位置服務提供位置服務,首先需要獲得LocationManager對象獲取LocationManager可以通過調用android.app.Activity.getSystemService()函數實現android.app.Activity.getSystemService()函數代碼如下代碼第1行的Context.LOCATION_SERVICE指明獲取的服務是位置服務代碼第2行的getSystemService()函數,可以根據服務名稱獲取Android提供的系統級服務StringserviceString=Context.LOCATION_SERVICE;LocationManagerLocationManager=(LocationManager)getSystemService(serviceString);9.1位置服務位置服務Android支持的系統級服務表Context類的靜態常量值返回對象說明LOCATION_SERVICElocationLocationManager控制位置等設備的更新WINDOW_SERVICEwindowWindowManager最頂層的窗口管理器LAYOUT_INFLATER_SERVICElayout_inflaterLayoutInflater將XML資源實例化為ViewPOWER_SERVICEpowerPowerManager電源管理ALARM_SERVICEalarmAlarmManager在指定時間接受IntentNOTIFICATION_SERVICEnotificationNotificationManager后臺事件通知KEYGUARD_SERVICEkeyguardKeyguardManager鎖定或解鎖鍵盤SEARCH_SERVICEsearchSearchManager訪問系統的搜索服務VIBRATOR_SERVICEvibratorVibrator訪問支持振動的硬件CONNECTIVITY_SERVICEconnectionConnectivityManager網絡連接管理WIFI_SERVICEwifiWifiManagerWi-Fi連接管理INPUT_METHOD_SERVICEinput_methodInputMethodManager

輸入法管理9.1位置服務位置服務在獲取到LocationManager后,還需要指定LocationManager的定位方法,然后才能夠調用LocationManagergetLastKnowLocation()方法獲取當前位置LocationManager支持的定位方法有兩種GPS定位:可以提供更加精確的位置信息,但定位速度和質量受到衛星數量和環境情況的影響網絡定位:提供的位置信息精度差,但速度較GPS定位快9.1位置服務位置服務LocationManager支持定位方法在指定LocationManager的定位方法后,則可以調用getLastKnowLocation()方法獲取當前的位置信息LocationManager類的靜態常量值說明GPS_PROVIDERgps使用GPS定位,利用衛星提供精確的位置信息,需要android.permissions.ACCESS_FINE_LOCATION用戶權限NETWORK_PROVIDERnetwork使用網絡定位,利用基站或Wi-Fi提供近似的位置信息,需要具有如下權限:android.permission.ACCESS_COARSE_LOCATION或android.permission.ACCESS_FINE_LOCATION.9.1位置服務位置服務以使用GPS定位為例,獲取位置信息的代碼如下代碼第2行返回的Location對象中,包含了可以確定位置的信息,如經度、緯度和速度等通過調用Location中的getLatitude()和getLonggitude()方法可以分別獲取位置信息中的緯度和經度,示例代碼如下Stringprovider=LocationManager.GPS_PROVIDER;Locationlocation=locationManager.getLastKnownLocation(provider);doublelat=location.getLatitude();doublelng=location.getLongitude();9.1位置服務位置服務LocationManager提供了一種便捷、高效的位置監視方法requestLocationUpdates(),可以根據位置的距離變化和時間間隔設定產生位置改變事件的條件,這樣可以避免因微小的距離變化而產生大量的位置改變事件LocationManager中設定監聽位置變化的代碼如下第1個參數是定位的方法,GPS定位或網絡定位第2個參數是產生位置改變事件的時間間隔,單位為微秒第3個參數是距離條件,單位是米第4個參數是回調函數,在滿足條件后的位置改變事件的處理函數locationManager.requestLocationUpdates(provider,2000,10,locationListener);9.1位置服務位置服務代碼將產生位置改變事件的條件設定為距離改變10米,時間間隔為2秒實現locationListener的代碼如下第2行代碼onLocationChanged()在設備的位置改變時被調用LocationListenerlocationListener=newLocationListener(){

publicvoidonLocationChanged(Locationlocation){

}

publicvoidonProviderDisabled(Stringprovider){

}

publicvoidonProviderEnabled(Stringprovider){

}

publicvoidonStatusChanged(Stringprovider,intstatus,Bundleextras){

}};9.1位置服務位置服務第4行的onProviderDisabled()在用戶禁用具有定位功能的硬件時被調用第6行的onProviderEnabled()在用戶啟用具有定位功能的硬件時被調用第8行的onStatusChanged()在提供定位功能的硬件的狀態改變時被調用,如從不可獲取位置信息狀態到可以獲取位置信息的狀態,反之亦然9.1位置服務位置服務為了使GPS定位功能生效,還需要在AndroidManifest.xml文件中加入用戶許可實現代碼如下<uses-permissionandroid:name="android.permission.ACCESS_FINE_LOCATION"/>9.1位置服務位置服務CurrentLocationDemo是一個提供位置服務的基本示例,提供了顯示當前位置新的功能,并能夠監視設備的位置變化9.1位置服務位置服務位置服務一般都需要使用設備上的硬件,最理想的調試方式是將程序上傳到物理設備上運行,但在沒有物理設備的情況下,也可以使用Android模擬器提供的虛擬方式模擬設備的位置變化,調試具有位置服務的應用程序首先打開DDMS中的模擬器控制,在LocationControls中的Longitude和Latitude部分輸入設備當前的經度和緯度,然后點擊Send按鈕,就將虛擬的位置信息發送到Android模擬器中9.1位置服務位置服務在程序運行過程中,可以在模擬器控制器中改變經度和緯度坐標值,程序在檢測到位置的變化后,會將最新的位置信息顯示在界面上但筆者在1.5版本的Android模擬器中進行調試時,發現模擬器控制器只能成功的將虛擬坐標發送到模擬器中2次,超過2次后模擬器對新發送的虛擬坐標不再響應9.1位置服務位置服務下面是CurrentLocationDemo示例中LocationBasedServiceDemo.java文件的完整代碼packageedu.hrbeu.LocationBasedServiceDemo;

importandroid.app.Activity;importandroid.content.Context;importandroid.os.Bundle;importandroid.widget.TextView;importandroid.location.Location;importandroid.location.LocationListener;importandroid.location.LocationManager;

9.1位置服務位置服務publicclassLocationBasedServiceDemoextendsActivity{ @Override publicvoidonCreate(BundlesavedInstanceState){ super.onCreate(savedInstanceState); setContentView(R.layout.main);

StringserviceString=Context.LOCATION_SERVICE; LocationManagerlocationManager=(LocationManager)getSystemService(serviceString); Stringprovider=LocationManager.GPS_PROVIDER; Locationlocation=locationManager.getLastKnownLocation(provider); getLocationInfo(location); locationManager.requestLocationUpdates(provider,2000,0,locationListener); }

9.1位置服務位置服務privatevoidgetLocationInfo(Locationlocation){ StringlatLongInfo; TextViewlocationText=(TextView)findViewById(R.id.txtshow); if(location!=null){ doublelat=location.getLatitude(); doublelng=location.getLongitude(); latLongInfo="Lat:"+lat+"\nLong:"+lng; } else{ latLongInfo="Nolocationfound"; } locationText.setText("YourCurrentPositionis:\n"+latLongInfo); }

privatefinalLocationListenerlocationListener=newLocationListener(){ @Override publicvoidonLocationChanged(Locationlocation){ getLocationInfo(location); }9.1位置服務位置服務@Override publicvoidonProviderDisabled(Stringprovider){ getLocationInfo(null); } @Override publicvoidonProviderEnabled(Stringprovider){ getLocationInfo(null); } @Override publicvoidonStatusChanged(Stringprovider,intstatus,Bundleextras){ } };}9.2

Google地圖應用

9.2.1申請地圖密鑰首先向Google申請一組經過驗證的“地圖密鑰”(MapAPIKey),然后使用MapView(com.google.android.maps.MapView)就可以將Google地圖嵌入到Android應用程序中,才能正常使用Google的地圖服務“地圖密鑰”是訪問Google地圖數據的密鑰,無論是模擬器還是在真實設備中需要使用這個密鑰9.2

Google地圖應用9.2.1申請地圖密鑰注冊“地圖密鑰”的第一步是申請一個Google賬戶,也就是Gmail電子郵箱,申請地址是/accounts/Login找到保存Debug證書的keystore的保存位置,并獲取證書的MD5散列值keystore是一個密碼保護的文件,用來存儲Android提供的用于調試的證書,獲取MD5散列值的主要目的是為下一步申請“地圖密鑰”做準備9.2

Google地圖應用9.2.1申請地圖密鑰獲取證書的保存地址:首先打開Eclipse,通過Window→Preferences打開配置窗體,在Android→Build欄中的Defaultdebugkeystore中可以找到9.2

Google地圖應用9.2.1申請地圖密鑰為了獲取Debug證書MD5散列值的,需要打開命令行工具CMD,然后切換到keystore的目錄,輸入如下命令如果提示無法找到keytool,可以將<JavaSDK>/bin的路徑添加到系統的PATH變量中keytool–list–keystoredebug.keystore9.2

Google地圖應用9.2.1申請地圖密鑰在提示輸入keystore密碼時,輸入缺省密碼android,MD5散列將顯示在最下方。筆者的MD5散列值為68:76:89:C8:A4:24:61:F9:EA:F3:F7:70:CC:FD:C8:159.2

Google地圖應用9.2.1申請地圖密鑰申請“地圖密鑰”的最后一步是打開申請頁面,輸入MD5散列值申請頁面的地址是/intl/zh-CN/android/add-ons/google-apis/maps-api-signup.html9.2

Google地圖應用9.2.1申請地圖密鑰9.2

Google地圖應用9.2.1申請地圖密鑰輸入MD5散列值后,點擊GenerateAPIKey按鈕,將提示用戶輸入Google賬戶,正確輸入Google賬戶后,將產生申請“地圖密鑰”的獲取結果9.2

Google地圖應用9.2.1申請地圖密鑰筆者獲取的“地圖密鑰”是0mVK8GeO6WUz4S2F94z52CIGSSlvlTwnrE4DsiA,在以后使用到MapView的時候都需要輸入這個密鑰但需要注意的是,讀者并不能使用這個密鑰,讀者需要根據自己的Debug證書的MD5散列值,重新到Google網站上申請一個用于調試程序的“地圖密鑰”9.2

Google地圖應用9.2.2使用Google地圖MapView的地圖的顯示控件,可以設置不同的顯示模式,例如衛星模式、街道模式或交通模式MapController則是MapView的控制器,可以控制MapView的顯示中心和縮放級別等功能下面的內容以GoogleMapDemo為例,說明如何在Android系統中開發Google地圖程序這個示例將在程序內部設置一個坐標點,然后在程序啟動時,使用MapView控件在地圖上顯示這個坐標點的位置9.2

Google地圖應用9.2.2使用Google地圖在建立工程時將com.google.android.maps的擴展庫添加到工程中,這樣就可以使用Google地圖的所有功能添加com.google.android.maps擴展庫的方式是在創建工程時,在BuildTarget項中選擇GoogleAPIs創建工程后,修改/res/layout/main.xml文件,在布局中加入一個MapView控件,并設置剛獲取的“地圖密鑰”9.2

Google地圖應用9.2.2使用Google地圖main.xml文件的完整代碼如下<?xmlversion="1.0"encoding="utf-8"?><LinearLayoutxmlns:android="/apk/res/android" android:orientation="vertical" android:layout_width="fill_parent" android:layout_height="fill_parent"> <TextViewandroid:layout_width="fill_parent" android:layout_height="wrap_content" android:text="@string/hello"/>

<com.google.android.maps.MapView android:id="@+id/mapview" android:layout_width="fill_parent" android:layout_height="fill_parent" android:enabled="true" android:clickable="true" android:apiKey="0mVK8GeO6WUz4S94z52CIGSSlvlTwnrE4DsiA"/></LinearLayout>9.2

Google地圖應用9.2.2使用Google地圖僅在布局中添加MapView控件,還不能夠直接在程序中調用這個控件,還需要將程序本身設置成MapActivity(com.google.android.maps.MapActivity)MapActivity類負責處理顯示Google地圖所需的生命周期和后臺服務管理下面先給出整個GoogleMapDemo.java文件的完整代碼packageedu.hrbeu.GoogleMapDemo;

importcom.google.android.maps.GeoPoint;importcom.google.android.maps.MapActivity;importcom.google.android.maps.MapController;importcom.google.android.maps.MapView;

9.2

Google地圖應用9.2.2使用Google地圖importandroid.os.Bundle;

publicclassGoogleMapDemoextendsMapActivity{ privateMapViewmapView; privateMapControllermapController;

@Override publicvoidonCreate(BundlesavedInstanceState){ super.onCreate(savedInstanceState); setContentView(R.layout.main);

mapView=(MapView)findViewById(R.id.mapview); mapController=mapView.getController();

Doublelng=126.676530486*1E6; Doublelat=45.7698895661*1E6; GeoPointpoint=newGeoPoint(Value(),Value());9.2

Google地圖應用9.2.2使用Google地圖25.mapController.setCenter(point); mapController.setZoom(11); mapController.animateTo(point);

mapView.setSatellite(false) }

@Override protectedbooleanisRouteDisplayed(){ //TODOAuto-generatedmethodstub returnfalse; }}9.2

Google地圖應用9.2.2使用Google地圖第20行代碼獲取了MapController第22行和第23行代碼設定的經度為126.676530486*1E6、緯度為45.7698895661*1E6的地理坐標點第26行代碼將這個坐標轉化為GeoPoint再使用第26行代碼設置MapView的“顯示中點”第27行代碼設置放大層級在第28行代碼將MapView顯示區域的中心移動到第26行設置的“顯示中心”第30行代碼是設定MapView的地圖顯示模式是否為衛星模式,設置true則為衛星模式,設置false則為普通模式第34行代碼isRouteDisplayed()方法,是用來統計程序是否顯示在Google地圖中顯示路徑信息,默認為不顯示9.2

Google地圖應用9.2.2使用Google地圖由于獲取Google地圖是需要使用互聯網的,所以在運行前還需要在AndroidManifest.xml文件中,添加允許訪問互聯網的許可AndroidManifest.xml文件的完整代碼如下<?xmlversion="1.0"encoding="utf-8"?><manifestxmlns:android="/apk/res/android" package="edu.hrbeu.GoogleMapDemo" android:versionCode="1" android:versionName="1.0">9.2

Google地圖應用9.2.2使用Google地圖<applicationandroid:icon="@drawable/icon"android:label="@string/app_name"> <activityandroid:name=".GoogleMapDemo“ android:label="@string/app_name"> <intent-filter> <actionandroid:name="ent.action.MAIN"/> <categoryandroid:name="ent.category.LAUNCHER"/> </intent-filter> </activity> <uses-libraryandroid:name="com.google.android.maps"></uses-library></application>

<uses-sdkandroid:minSdkVersion="3"/><uses-permissionandroid:name="android.permission.INTERNET"/></manifest>9.2

Google地圖應用9.2.2使用Google地圖運行結果如圖地圖模式衛星模式9.2

Google地圖應用9.2.3使用Overlay通過在MapView上添加覆蓋層,可以在指定的位置加添加注解、繪制圖像或處理進行鼠標事件等Google地圖上可以加入多個覆蓋層,所有覆蓋層均都在地圖圖層之上,每個覆蓋層均可以對用戶的點擊事件做出響應創建覆蓋層繼承Overlay類的子類,并通過重載draw()方法為指定位置添加注解,重載onTap()方法處理用戶的點擊操作9.2

Google地圖應用9.2.3使用Overlay下面的代碼是創建Overlay的最小代碼集合publicclassTextOverlayextendsOverlay{ @Override publicvoiddraw(Canvascanvas,MapViewmapView,booleanshadow){ if(shadow==false){

} else{ } super.draw(canvas,mapView,shadow); }

@Override publicbooleanonTap(GeoPointp,MapViewmapView){ returnfalse; }}9.2

Google地圖應用9.2.3使用Overlay第3行代碼中draw()方法,shadow變量是用來區分繪制圖層的false表示在覆蓋層上進行繪制true則表示在隱藏層上進行繪制第14行代碼是onTap()方法的返回值返回false表示覆蓋層不處理點擊事件返回true則表示已經處理了點擊事件在覆蓋層繪制圖形或文字需要使用“畫布”(Canvas)來實現,繪制的位置是屏幕坐標,這就需要將地圖上的物理坐標與屏幕坐標進行轉換9.2

Google地圖應用9.2.3使用OverlayProjection類提供了物理坐標和屏幕坐標的轉換功能,可在經度和緯度表示的GeoPoint點和屏幕上Point點進行轉換toPixels()方法將物理坐標轉換為屏幕坐標fromPixels()方法將屏幕坐標轉換為物理坐標兩個方法的具體使用方法可以參考下面的代碼Projectionprojection=mapView.getProjection();

projection.toPixels(geoPoint,point);projection.fromPixels(point.x,point.y);9.2

Google地圖應用9.2.3使用Overlay下面的內容以MapOverlayDemo示例,說明如何在Google地圖上添加覆蓋層,并在預訂的物理坐標上顯示提示信息右圖是MapOverlayDemo示例的運行結果9.2

Google地圖應用9.2.3使用OverlayTextOverlay類是MapOverlayDemo示例的覆蓋層,主要重載了draw()方法,在指定的物理坐標上繪制了標記點和提示文字TextOverlay.java文件的核心代碼如下publicclassTextOverlayextendsOverlay{ privatefinalintmRadius=5;

@Override publicvoiddraw(Canvascanvas,MapViewmapView,booleanshadow){ Projectionprojection=mapView.getProjection();

9.2

Google地圖應用9.2.3使用Overlayif(shadow==false){ Doublelng=126.676530486*1E6; Doublelat=45.7698895661*1E6; GeoPointgeoPoint=newGeoPoint(Value(),Value());

Pointpoint=newPoint(); projection.toPixels(geoPoint,point);

RectFoval=newRectF(point.x-mRadius,point.y-mRadius, point.x+mRadius,point.y+mRadius);

Paintpaint=newPaint(); paint.setARGB(250,250,0,0); paint.setAntiAlias(true); paint.setFakeBoldText(true);

9.2

Google地圖應用9.2.3使用Overlay第2行代碼定義了繪制半徑變量mRadius,供定義繪制范圍使用第14行代碼使用Projection完成了從物理坐標到屏幕坐標的轉換canvas.drawOval(oval,paint); canvas.drawText("標記點",point.x+2*mRadius,point.y,paint); } super.draw(canvas,ma

溫馨提示

  • 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
  • 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯系上傳者。文件的所有權益歸上傳用戶所有。
  • 3. 本站RAR壓縮包中若帶圖紙,網頁內容里面會有圖紙預覽,若沒有圖紙預覽就沒有圖紙。
  • 4. 未經權益所有人同意不得將文件中的內容挪作商業或盈利用途。
  • 5. 人人文庫網僅提供信息存儲空間,僅對用戶上傳內容的表現方式做保護處理,對用戶上傳分享的文檔內容本身不做任何修改或編輯,并不能對任何下載內容負責。
  • 6. 下載文件中如有侵權或不適當內容,請與我們聯系,我們立即糾正。
  • 7. 本站不保證下載資源的準確性、安全性和完整性, 同時也不承擔用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。

評論

0/150

提交評論