在Android应用开发中,获取用户当前位置是常见需求,使用Java在Android Studio中实现该功能需要遵循权限申请、服务初始化、回调处理的完整流程,下面逐步讲解具体实现方法。

一、添加定位相关权限
首先需要在项目的AndroidManifest.xml文件中声明定位所需权限,定位权限分为普通权限和危险权限,需要在清单文件中提前声明。
<manifest xmlns:android="http://schemas.android.com/apk/res/android"
package="com.example.locationdemo">
<!-- 网络定位权限 -->
<uses-permission android:name="android.permission.ACCESS_COARSE_LOCATION" />
<!-- GPS定位权限 -->
<uses-permission android:name="android.permission.ACCESS_FINE_LOCATION" />
<!-- 如果应用需要后台定位,还需要添加后台定位权限,此处暂不涉及 -->
<application
android:allowBackup="true"
android:icon="@mipmap/ic_launcher"
android:label="@string/app_name"
android:theme="@style/Theme.AppCompat.Light.NoActionBar">
<activity
android:name=".MainActivity"
android:exported="true">
<intent-filter>
<action android:name="android.intent.action.MAIN" />
<category android:name="android.intent.category.LAUNCHER" />
</intent-filter>
</activity>
</application>
</manifest>二、动态申请定位权限
从Android 6.0开始,危险权限需要动态申请,定位权限属于危险权限,因此需要在代码中主动向用户申请授权。
import android.Manifest;
import android.content.pm.PackageManager;
import android.os.Bundle;
import androidx.annotation.NonNull;
import androidx.appcompat.app.AppCompatActivity;
import androidx.core.app.ActivityCompat;
import androidx.core.content.ContextCompat;
import java.util.ArrayList;
import java.util.List;
public class MainActivity extends AppCompatActivity {
// 定位权限请求码
private static final int LOCATION_PERMISSION_REQUEST_CODE = 1001;
// 需要的定位权限列表
private String[] locationPermissions = {
Manifest.permission.ACCESS_COARSE_LOCATION,
Manifest.permission.ACCESS_FINE_LOCATION
};
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
// 检查并申请定位权限
checkAndRequestLocationPermission();
}
/**
* 检查并申请定位权限
*/
private void checkAndRequestLocationPermission() {
List<String> needRequestPermissions = new ArrayList<>();
for (String permission : locationPermissions) {
if (ContextCompat.checkSelfPermission(this, permission) != PackageManager.PERMISSION_GRANTED) {
needRequestPermissions.add(permission);
}
}
// 如果存在未授权的权限,发起动态申请
if (!needRequestPermissions.isEmpty()) {
ActivityCompat.requestPermissions(this,
needRequestPermissions.toArray(new String[0]),
LOCATION_PERMISSION_REQUEST_CODE);
} else {
// 权限已授予,初始化定位服务
initLocationService();
}
}
@Override
public void onRequestPermissionsResult(int requestCode, @NonNull String[] permissions, @NonNull int[] grantResults) {
super.onRequestPermissionsResult(requestCode, permissions, grantResults);
if (requestCode == LOCATION_PERMISSION_REQUEST_CODE) {
boolean allGranted = true;
for (int result : grantResults) {
if (result != PackageManager.PERMISSION_GRANTED) {
allGranted = false;
break;
}
}
if (allGranted) {
// 权限全部授予,初始化定位服务
initLocationService();
} else {
// 权限被拒绝,可提示用户手动开启
// 此处可添加自定义提示逻辑
}
}
}
}三、初始化定位服务获取位置
Android系统提供了LocationManager类来管理定位服务,我们可以通过该类获取不同定位 provider 的位置信息,常用的定位 provider 有GPS和网络定位两种。
| 定位Provider | 精度 | 耗电量 | 适用场景 |
|---|---|---|---|
| GPS_PROVIDER | 高 | 高 | 户外需要高精度定位的场景 |
| NETWORK_PROVIDER | 低 | 低 | 室内或不需要极高精度的场景 |
下面是实现定位的核心代码,包括初始化LocationManager、监听位置变化:
import android.location.Location;
import android.location.LocationListener;
import android.location.LocationManager;
import android.os.Bundle;
import android.widget.TextView;
import androidx.appcompat.app.AppCompatActivity;
public class MainActivity extends AppCompatActivity {
private LocationManager locationManager;
private LocationListener locationListener;
private TextView locationTv;
// 省略之前的权限申请相关代码...
/**
* 初始化定位服务
*/
private void initLocationService() {
locationTv = findViewById(R.id.location_tv);
// 获取LocationManager实例
locationManager = (LocationManager) getSystemService(LOCATION_SERVICE);
// 创建位置监听器
locationListener = new LocationListener() {
@Override
public void onLocationChanged(@NonNull Location location) {
// 位置变化回调,获取最新的经纬度
double latitude = location.getLatitude();
double longitude = location.getLongitude();
locationTv.setText("当前位置:\n纬度:" + latitude + "\n经度:" + longitude);
}
@Override
public void onStatusChanged(String provider, int status, Bundle extras) {
// 定位状态变化回调
}
@Override
public void onProviderEnabled(@NonNull String provider) {
// 定位provider被用户开启
}
@Override
public void onProviderDisabled(@NonNull String provider) {
// 定位provider被用户关闭,可提示用户开启
}
};
// 检查对应的定位provider是否可用
if (locationManager.isProviderEnabled(LocationManager.GPS_PROVIDER)) {
// 优先使用GPS定位,最小时间间隔1000ms,最小距离变化0米
try {
locationManager.requestLocationUpdates(
LocationManager.GPS_PROVIDER,
1000,
0,
locationListener
);
} catch (SecurityException e) {
e.printStackTrace();
}
} else if (locationManager.isProviderEnabled(LocationManager.NETWORK_PROVIDER)) {
// GPS不可用则使用网络定位
try {
locationManager.requestLocationUpdates(
LocationManager.NETWORK_PROVIDER,
1000,
0,
locationListener
);
} catch (SecurityException e) {
e.printStackTrace();
}
}
// 获取最后一次已知位置,避免首次获取位置等待时间过长
try {
Location lastKnownLocation = locationManager.getLastKnownLocation(LocationManager.GPS_PROVIDER);
if (lastKnownLocation == null) {
lastKnownLocation = locationManager.getLastKnownLocation(LocationManager.NETWORK_PROVIDER);
}
if (lastKnownLocation != null) {
double latitude = lastKnownLocation.getLatitude();
double longitude = lastKnownLocation.getLongitude();
locationTv.setText("最后一次已知位置:\n纬度:" + latitude + "\n经度:" + longitude);
}
} catch (SecurityException e) {
e.printStackTrace();
}
}
@Override
protected void onDestroy() {
super.onDestroy();
// 页面销毁时移除定位监听,避免内存泄漏
if (locationManager != null && locationListener != null) {
try {
locationManager.removeUpdates(locationListener);
} catch (SecurityException e) {
e.printStackTrace();
}
}
}
}四、常见问题排查
在实现定位功能时,可能会遇到位置获取失败的情况,可通过以下思路排查:
- 检查权限是否全部授予,包括清单文件声明和动态申请逻辑是否正常执行
- 检查设备的定位功能是否开启,可在系统设置中查看定位服务状态
- 如果在室内测试,优先使用网络定位,GPS在室内信号较弱可能无法获取位置
- 首次获取位置可能需要等待一段时间,可通过获取最后一次已知位置临时展示
- 部分模拟器默认没有定位数据,需要在模拟器设置中手动发送经纬度数据测试
注意:如果需要获取更精确的定位或者减少电量消耗,也可以考虑接入第三方定位SDK,但基础场景使用系统原生LocationManager即可满足需求。按照以上步骤操作,就可以在Android Studio中使用Java成功获取用户的当前位置了,开发者可根据自己的业务需求调整定位的时间间隔和距离阈值,优化定位功能和用户体验。
Android_StudioJava当前位置获取定位权限LocationManager修改时间:2026-06-04 03:28:09