在做一個大創的程序中真是遇到很多坎坷,但是硬著頭皮上的識訓也很多,
經過大量的查找學習,終于完成一個Android6.0以上的手機可以使用的原生GPS定位,
感謝:10.14 Android GPS初涉
Android 6.0權限管理以及動態申請,以定位權限為例
LocationManager
我的Android studio版本如圖:

涉及到知識點
- 獲取定位資訊的三個程序
- Android6.0以上動態定位權限申請
第一點
了解Android原生GPS定位程序
10.14 Android GPS初涉
LocationManager
1.獲取系統的 LocationManager 物件
LocationManager lm = (LocationManager) getSystemService(Context.LOCATION_SERVICE);
2.選擇位置提供器,通過該LocationProvider獲取定位資訊,定位資訊由Location物件表示
Location location = lm.getLastKnownLocation(LocationManager.GPS_PROVIDER);
此處未進行判斷哪些Provider可用,直接獲取了GPS_PROVIDER,
如需判斷可參考下代碼
List<String> providerList = locationManager.getProviders(true);
// 傳入 true 就表示只有啟用的位置提供器才會被回傳,
if (providerList.contains(LocationManager.GPS_PROVIDER)) {
provider = LocationManager.GPS_PROVIDER;//GPS定位
} else if (providerList.contains(LocationManager.NETWORK_PROVIDER)) {
provider = LocationManager.NETWORK_PROVIDER;//網路定位
}
- 從Location物件獲取定位資訊
location.getLongitude();//經度
location.getLatitude();//緯度
location.getAltitude();//高度
第二點
Android 6.0權限管理以及動態申請,以定位權限為例
首先判斷定位服務是否開啟,否的話要跳轉到開啟界面讓用戶手動開啟
lm = (LocationManager) getSystemService(Context.LOCATION_SERVICE);
if (!isGpsAble(lm)) {
Toast.makeText(LocationActivity.this, "請打開GPS", Toast.LENGTH_SHORT).show();
openGPS2();
}
//……………………………………………………………………………………………………………………………………………………
//判斷GPS服務是否開啟
private boolean isGpsAble(LocationManager lm) {
return lm.isProviderEnabled(android.location.LocationManager.GPS_PROVIDER) ? true : false;
}
//打開設定頁面讓用戶自己設定
private void openGPS2() {
Intent intent = new Intent(Settings.ACTION_LOCATION_SOURCE_SETTINGS);
startActivityForResult(intent, 0);
}
其次判斷權限是否開啟,如果已經開啟,那么就執行startLocation方法,沒有開啟的話我們就要提示用戶去開啟
if(ContextCompat.checkSelfPermission(MainActivity.this, Manifest.permission.ACCESS_FINE_LOCATION)
!= PackageManager.PERMISSION_GRANTED){//未開啟定位權限
//開啟定位權限,200是標識碼
ActivityCompat.requestPermissions(MainActivity.this,new String[]{Manifest.permission.ACCESS_FINE_LOCATION},200);
}else{
startLocaion();//開始定位
Toast.makeText(MainActivity.this,"已開啟定位權限",Toast.LENGTH_LONG).show();
}
接著寫一個回呼方法——onRequestPermissionsResult,在我們需要申請權限的時候就會執行這個回呼
@Override
public void onRequestPermissionsResult(int requestCode, @NonNull String[] permissions, @NonNull int[] grantResults) {
super.onRequestPermissionsResult(requestCode, permissions, grantResults);
switch (requestCode){
case 200://剛才的識別碼
if(grantResults[0] == PackageManager.PERMISSION_GRANTED){//用戶同意權限,執行我們的操作
startLocaion();//開始定位
}else{//用戶拒絕之后,當然我們也可以彈出一個視窗,直接跳轉到系統設定頁面
Toast.makeText(MainActivity.this,"未開啟定位權限,請手動到設定去開啟權限",Toast.LENGTH_LONG).show();
}
break;
default:break;
}
}
這是有關回呼函式的通俗易懂理解
Java/Android中的函式呼叫&回呼函式&自定義回呼函式
下面是全部代碼
LocationACtivity.java
package com.example.mygps3;
import android.Manifest;
import android.annotation.SuppressLint;
import android.content.Context;
import android.content.Intent;
import android.content.pm.PackageManager;
import android.location.Location;
import android.location.LocationListener;
import android.location.LocationManager;
import android.os.Build;
import android.os.Bundle;
import android.provider.Settings;
import android.widget.TextView;
import android.widget.Toast;
import androidx.annotation.NonNull;
import androidx.annotation.RequiresApi;
import androidx.appcompat.app.AppCompatActivity;
import androidx.core.app.ActivityCompat;
import androidx.core.content.ContextCompat;
/**
* Created by Ferry on 2021/2/19
*/
public class LocationActivity extends AppCompatActivity {
private LocationManager lm;
private TextView tv_show;
@SuppressLint("MissingPermission")
@RequiresApi(api = Build.VERSION_CODES.M)
@Override
public void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_location);
tv_show = findViewById(R.id.tv_show);
lm = (LocationManager) getSystemService(Context.LOCATION_SERVICE);
if (!isGpsAble(lm)) {
Toast.makeText(LocationActivity.this, "請打開GPS", Toast.LENGTH_SHORT).show();
openGPS2();
}
if (ContextCompat.checkSelfPermission(LocationActivity.this, Manifest.permission.ACCESS_FINE_LOCATION)
!= PackageManager.PERMISSION_GRANTED) {//未開啟定位權限
//開啟定位權限,200是標識碼
ActivityCompat.requestPermissions(LocationActivity.this, new String[]{Manifest.permission.ACCESS_FINE_LOCATION}, 200);
} else {
startLocation();
Toast.makeText(LocationActivity.this, "已開啟定位權限", Toast.LENGTH_LONG).show();
}
}
@Override
public void onRequestPermissionsResult(int requestCode, @NonNull String[] permissions, @NonNull int[] grantResults) {
super.onRequestPermissionsResult(requestCode, permissions, grantResults);
switch (requestCode){
case 200://剛才的識別碼
if(grantResults[0] == PackageManager.PERMISSION_GRANTED){//用戶同意權限,執行我們的操作
startLocation();//開始定位
}else{//用戶拒絕之后,當然我們也可以彈出一個視窗,直接跳轉到系統設定頁面
Toast.makeText(LocationActivity.this,"未開啟定位權限,請手動到設定去開啟權限",Toast.LENGTH_LONG).show();
}
break;
default:break;
}
}
//定義一個更新顯示的方法
private void updateShow(Location location) {
if (location != null) {
StringBuilder sb = new StringBuilder();
sb.append("當前的位置資訊:\n");
sb.append("經度:" + location.getLongitude() + "\n");
sb.append("緯度:" + location.getLatitude() + "\n");
sb.append("高度:" + location.getAltitude() + "\n");
sb.append("速度:" + location.getSpeed() + "\n");
sb.append("方向:" + location.getBearing() + "\n");
sb.append("定位精度:" + location.getAccuracy() + "\n");
tv_show.setText(sb.toString());
} else tv_show.setText("");
}
@SuppressLint("MissingPermission")
private void startLocation(){
//從GPS獲取最近的定位資訊
Location lc = lm.getLastKnownLocation(LocationManager.GPS_PROVIDER);
updateShow(lc);
//設定間隔兩秒獲得一次GPS定位資訊
lm.requestLocationUpdates(LocationManager.GPS_PROVIDER, 2000, 8, new LocationListener() {
@Override
public void onLocationChanged(Location location) {
// 當GPS定位資訊發生改變時,更新定位
updateShow(location);
}
@Override
public void onStatusChanged(String provider, int status, Bundle extras) {
}
@Override
public void onProviderEnabled(String provider) {
// 當GPS LocationProvider可用時,更新定位
updateShow(lm.getLastKnownLocation(provider));
}
@Override
public void onProviderDisabled(String provider) {
updateShow(null);
}
});
}
private boolean isGpsAble(LocationManager lm) {
return lm.isProviderEnabled(android.location.LocationManager.GPS_PROVIDER) ? true : false;
}
//打開設定頁面讓用戶自己設定
private void openGPS2() {
Intent intent = new Intent(Settings.ACTION_LOCATION_SOURCE_SETTINGS);
startActivityForResult(intent, 0);
}
}
AndroidManifest.xml
<?xml version="1.0" encoding="UTF-8"?>
<manifest package="com.example.mygps3" xmlns:android="http://schemas.android.com/apk/res/android">
<uses-permission android:name="android.permission.ACCESS_FINE_LOCATION"/>
<uses-permission android:name="android.permission.ACCESS_COARSE_LOCATION"/>
<application android:theme="@style/AppTheme"
android:label="@string/app_name"
android:icon="@mipmap/ic_launcher"
android:allowBackup="true">
<activity android:name=".LocationActivity">
<intent-filter>
<action android:name="android.intent.action.MAIN"/>
<category android:name="android.intent.category.LAUNCHER"/>
</intent-filter>
</activity>
</application>
</manifest>
activity_location.xml
<?xml version="1.0" encoding="UTF-8"?>
<LinearLayout android:orientation="vertical"
android:layout_height="match_parent"
android:layout_width="match_parent"
xmlns:android="http://schemas.android.com/apk/res/android">
<TextView android:layout_height="match_parent"
android:layout_width="match_parent"
android:textStyle="bold"
android:textSize="20sp"
android:padding="5dp"
android:id="@+id/tv_show"/>
</LinearLayout>
這是效果

轉載請註明出處,本文鏈接:https://www.uj5u.com/yidong/261759.html
標籤:其他
