Android編程獲取地理位置的經(jīng)度和緯度實(shí)例
本文實(shí)例講述了Android編程獲取地理位置的經(jīng)度和緯度。分享給大家供大家參考,具體如下:
在Android應(yīng)用程序中,可以使用LocationManager來獲取移動(dòng)設(shè)備所在的地理位置信息??慈缦聦?shí)例:新建android應(yīng)用程序TestLocation。
1、activity_main.xml布局文件
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android" android:layout_width="fill_parent" android:layout_height="fill_parent" > <TextView android:id="@+id/positionView" android:layout_width="wrap_content" android:layout_height="wrap_content" /> </LinearLayout>
用于顯示獲取到的位置信息。
2、MainActivity.java
package com.example.testlocation; import java.util.List; import android.app.Activity; import android.content.Context; import android.location.Location; import android.location.LocationListener; import android.location.LocationManager; import android.os.Bundle; import android.view.Menu; import android.widget.TextView; import android.widget.Toast; public class MainActivity extends Activity { private TextView postionView; private LocationManager locationManager; private String locationProvider; @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.activity_main); //獲取顯示地理位置信息的TextView postionView = (TextView) findViewById(R.id.positionView); //獲取地理位置管理器 locationManager = (LocationManager) getSystemService(Context.LOCATION_SERVICE); //獲取所有可用的位置提供器 List<String> providers = locationManager.getProviders(true); if(providers.contains(LocationManager.GPS_PROVIDER)){ //如果是GPS locationProvider = LocationManager.GPS_PROVIDER; }else if(providers.contains(LocationManager.NETWORK_PROVIDER)){ //如果是Network locationProvider = LocationManager.NETWORK_PROVIDER; }else{ Toast.makeText(this, "沒有可用的位置提供器", Toast.LENGTH_SHORT).show(); return ; } //獲取Location Location location = locationManager.getLastKnownLocation(locationProvider); if(location!=null){ //不為空,顯示地理位置經(jīng)緯度 showLocation(location); } //監(jiān)視地理位置變化 locationManager.requestLocationUpdates(locationProvider, 3000, 1, locationListener); } /** * 顯示地理位置經(jīng)度和緯度信息 * @param location */ private void showLocation(Location location){ String locationStr = "維度:" + location.getLatitude() +"\n" + "經(jīng)度:" + location.getLongitude(); postionView.setText(locationStr); } /** * LocationListern監(jiān)聽器 * 參數(shù):地理位置提供器、監(jiān)聽位置變化的時(shí)間間隔、位置變化的距離間隔、LocationListener監(jiān)聽器 */ LocationListener locationListener = new LocationListener() { @Override public void onStatusChanged(String provider, int status, Bundle arg2) { } @Override public void onProviderEnabled(String provider) { } @Override public void onProviderDisabled(String provider) { } @Override public void onLocationChanged(Location location) { //如果位置發(fā)生變化,重新顯示 showLocation(location); } }; @Override protected void onDestroy() { super.onDestroy(); if(locationManager!=null){ //移除監(jiān)聽器 locationManager.removeUpdates(locationListener); } } @Override public boolean onCreateOptionsMenu(Menu menu) { // Inflate the menu; this adds items to the action bar if it is present. getMenuInflater().inflate(R.menu.main, menu); return true; } }
從上面可以看出,獲取地理位置信息主要分如下步驟:
(1)獲取LocationManager實(shí)例,通過getSystemService方法,傳入Context.LOCATION_SERVICE參數(shù)。
(2)獲取可用的位置提供器,有GPS_PROVIDER、NETWORK_PROVIDER、PASSIVE_PROVIDER三種,前兩種比較常用。
(3)將(2)獲取到的位置提供器傳入LocationManager的方法getLastKnownLocation,即可獲取Location信息。
如果移動(dòng)設(shè)備地理位置不斷發(fā)生變化,則實(shí)時(shí)更新需要進(jìn)行如下步驟:
(4)調(diào)用LocationManager的requestLocationUpdates方法,第一個(gè)參數(shù)是位置提供器,第二個(gè)參數(shù)是監(jiān)聽位置變化的時(shí)間間隔(毫秒),第三個(gè)參數(shù)是監(jiān)聽位置變化的距離間隔(米),第四個(gè)參數(shù)是LocationListener監(jiān)聽器
(5)當(dāng)位置發(fā)生變化后,就會(huì)調(diào)用監(jiān)聽器的onLocationChanged方法。
(6)為了省電,節(jié)約資源,當(dāng)程序關(guān)閉后,調(diào)用LocationManager的removeUpdates方法移除監(jiān)聽器。
3、獲取權(quán)限
修改AndroidManifest.xml,添加如下代碼:
<uses-permission android:name="android.permission.ACCESS_FINE_LOCATION"/> <uses-permission android:name="android.permission.ACCESS_COARSE_LOCATION" /> <uses-permission android:name="android.permission.ACCESS_COARSE_LOCATION"/>
4、效果
使用模擬器進(jìn)行測試:點(diǎn)擊send
可以使用Geocoding API查找具體對應(yīng)的位置。如下:
(1)修改MainActivity.java
package com.example.testlocation; import java.util.List; import org.apache.http.HttpEntity; import org.apache.http.HttpResponse; import org.apache.http.client.HttpClient; import org.apache.http.client.methods.HttpGet; import org.apache.http.impl.client.DefaultHttpClient; import org.apache.http.util.EntityUtils; import org.json.JSONArray; import org.json.JSONObject; import android.app.Activity; import android.content.Context; import android.location.Location; import android.location.LocationListener; import android.location.LocationManager; import android.os.Bundle; import android.os.Handler; import android.os.Message; import android.view.Menu; import android.widget.TextView; import android.widget.Toast; public class MainActivity extends Activity { private TextView postionView; private LocationManager locationManager; private String locationProvider; public static final int SHOW_LOCATION = 0; @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.activity_main); //獲取顯示地理位置信息的TextView postionView = (TextView) findViewById(R.id.positionView); //獲取地理位置管理器 locationManager = (LocationManager) getSystemService(Context.LOCATION_SERVICE); //獲取所有可用的位置提供器 List<String> providers = locationManager.getProviders(true); if(providers.contains(LocationManager.GPS_PROVIDER)){ //如果是GPS locationProvider = LocationManager.GPS_PROVIDER; }else if(providers.contains(LocationManager.NETWORK_PROVIDER)){ //如果是Network locationProvider = LocationManager.NETWORK_PROVIDER; }else{ Toast.makeText(this, "沒有可用的位置提供器", Toast.LENGTH_SHORT).show(); return ; } //獲取Location Location location = locationManager.getLastKnownLocation(locationProvider); if(location!=null){ //不為空,顯示地理位置經(jīng)緯度 showLocation(location); }else{ Toast.makeText(this, "location為空", Toast.LENGTH_SHORT).show(); } //監(jiān)視地理位置變化 locationManager.requestLocationUpdates(locationProvider, 3000, 1, locationListener); } private Handler handler = new Handler(){ public void handleMessage(Message msg){ switch(msg.what){ case SHOW_LOCATION: String position = (String) msg.obj; postionView.setText(position); break; default: break; } } }; /** * 顯示地理位置經(jīng)度和緯度信息 * @param location */ private void showLocation(final Location location){ /*String locationStr = "維度:" + location.getLatitude() +"\n" + "經(jīng)度:" + location.getLongitude(); postionView.setText(locationStr);*/ new Thread(new Runnable() { @Override public void run() { try{ //組裝反向地理編碼的接口位置 StringBuilder url = new StringBuilder(); url.append("http://maps.googleapis.com/maps/api/geocode/json?latlng="); url.append(location.getLatitude()).append(","); url.append(location.getLongitude()); url.append("&sensor=false"); HttpClient client = new DefaultHttpClient(); HttpGet httpGet = new HttpGet(url.toString()); httpGet.addHeader("Accept-Language","zh-CN"); HttpResponse response = client.execute(httpGet); if(response.getStatusLine().getStatusCode() == 200){ HttpEntity entity = response.getEntity(); String res = EntityUtils.toString(entity); //解析 JSONObject jsonObject = new JSONObject(res); //獲取results節(jié)點(diǎn)下的位置信息 JSONArray resultArray = jsonObject.getJSONArray("results"); if(resultArray.length() > 0){ JSONObject obj = resultArray.getJSONObject(0); //取出格式化后的位置數(shù)據(jù) String address = obj.getString("formatted_address"); Message msg = new Message(); msg.what = SHOW_LOCATION; msg.obj = address; handler.sendMessage(msg); } } }catch(Exception e){ e.printStackTrace(); } } }).start(); } /** * LocationListern監(jiān)聽器 * 參數(shù):地理位置提供器、監(jiān)聽位置變化的時(shí)間間隔、位置變化的距離間隔、LocationListener監(jiān)聽器 */ LocationListener locationListener = new LocationListener() { @Override public void onStatusChanged(String provider, int status, Bundle arg2) { } @Override public void onProviderEnabled(String provider) { } @Override public void onProviderDisabled(String provider) { } @Override public void onLocationChanged(Location location) { //如果位置發(fā)生變化,重新顯示 showLocation(location); } }; @Override protected void onDestroy() { super.onDestroy(); if(locationManager!=null){ //移除監(jiān)聽器 locationManager.removeUpdates(locationListener); } } @Override public boolean onCreateOptionsMenu(Menu menu) { // Inflate the menu; this adds items to the action bar if it is present. getMenuInflater().inflate(R.menu.main, menu); return true; } }
(2)修改AndroidManifest.xml
<uses-permission android:name="android.permission.ACCESS_FINE_LOCATION"/> <uses-permission android:name="android.permission.ACCESS_COARSE_LOCATION" /> <uses-permission android:name="android.permission.ACCESS_COARSE_LOCATION"/> <uses-permission android:name="android.permission.INTERNET"/>
希望本文所述對大家Android程序設(shè)計(jì)有所幫助。
- Android 獲取系統(tǒng)語言的實(shí)例(兼容7.0)
- 詳解Android更改APP語言模式的實(shí)現(xiàn)過程
- android 支持的語言列表(匯總)
- Android 各國語言縮寫及簡稱詳細(xì)介紹
- Android實(shí)現(xiàn)系統(tǒng)語言切換功能
- Android app應(yīng)用多語言切換功能實(shí)現(xiàn)
- Android實(shí)現(xiàn)app應(yīng)用多語言切換功能
- Android自定義WheelView地區(qū)選擇三級聯(lián)動(dòng)
- 輕松實(shí)現(xiàn)Android仿淘寶地區(qū)選擇功能
- 用Android Location獲取當(dāng)前地理位置的方法
- Android使用GPS獲取用戶地理位置并監(jiān)聽位置變化的方法
- Android編程實(shí)現(xiàn)獲取當(dāng)前系統(tǒng)語言及地區(qū)并更改語言的方法
相關(guān)文章
android基于SwipeRefreshLayout實(shí)現(xiàn)類QQ的側(cè)滑刪除
本篇文章主要介紹了android基于SwipeRefreshLayout實(shí)現(xiàn)類QQ的側(cè)滑刪除,非常具有實(shí)用價(jià)值,需要的朋友可以參考下2017-10-10Android使用多線程進(jìn)行網(wǎng)絡(luò)聊天室通信
這篇文章主要為大家詳細(xì)介紹了Android使用多線程進(jìn)行網(wǎng)絡(luò)聊天室通信,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2017-10-10Android ListView 滾動(dòng)條的設(shè)置詳解及實(shí)例代碼
這篇文章主要介紹了 ListView等滾動(dòng)條的設(shè)置詳解詳解及實(shí)例代碼的相關(guān)資料,需要的朋友可以參考下2017-02-02EditText監(jiān)聽方法,實(shí)時(shí)的判斷輸入多少字符
在EditText提供了一個(gè)方法addTextChangedListener實(shí)現(xiàn)對輸入文本的監(jiān)控。本文分享了EditText監(jiān)聽方法案例,需要的朋友一起來看下吧2016-12-1220行Android代碼寫一個(gè)CircleImageView
這篇文章主要介紹了20行Android代碼寫一個(gè)CircleImageView,制作圓形頭像,感興趣的小伙伴們可以參考一下2016-08-08Android單一實(shí)例全局可調(diào)用網(wǎng)絡(luò)加載彈窗
這篇文章主要為大家詳細(xì)介紹了Android單一實(shí)例全局可調(diào)用網(wǎng)絡(luò)加載彈窗,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2018-12-12Android實(shí)現(xiàn)仿360桌面懸浮清理內(nèi)存
今天給大家?guī)硪粋€(gè)仿360手機(jī)衛(wèi)士懸浮窗清理內(nèi)存的效果的教程,非常的簡單實(shí)用,需要的小伙伴可以參考下2015-12-12Android利用Sensor(傳感器)實(shí)現(xiàn)水平儀功能
這篇文章主要為大家詳細(xì)介紹了Android利用Sensor傳感器實(shí)現(xiàn)水平儀功能,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2017-02-02Android開發(fā)筆記XML數(shù)據(jù)解析方法及優(yōu)缺點(diǎn)
XML數(shù)據(jù)是一種常見的數(shù)據(jù)格式,Android開發(fā)中需要對其進(jìn)行解析。常用的XML解析方式有DOM、SAX、Pull和Json等,每種方式都有其優(yōu)缺點(diǎn)。開發(fā)者可以根據(jù)具體需求選擇合適的解析方式,提高數(shù)據(jù)解析效率和性能2023-05-05