MAUI获取GPS地理位置需满足设备支持、用户授权和平台配置三前提;离线可用但首次定位较慢。一、Android需在AndroidManifest.xml添加精确定位权限,iOS需在Info.plist配置NSLocationWhenInUseUsageDescription,Windows/macOS无需额外配置;二、推荐使用带超时和精度控制的Geolocation.Default.GetLocationAsync;三、GetLastKnownLocationAsync可快速获取缓存位置但准确性低;四、真机调试更可靠,注意系统级权限设置。

MAUI 获取 GPS 地理位置,核心是调用 Geolocation.Default,但必须满足三个前提:设备支持 GPS、用户已授予权限、平台配置正确。离线时也能获取(依赖 GPS 模块本身,不依赖网络),但首次定位可能稍慢。
一、先配好平台权限
没权限,代码再对也拿不到坐标。
-
Android:在
Platforms/Android/AndroidManifest.xml中添加: -
iOS:在
Platforms/iOS/Info.plist中加入:NSLocationWhenInUseUsageDescription 需要获取您的位置来提供精准服务 - Windows/macOS:无需额外配置,系统自动处理
二、用 Geolocation.Default 获取实时位置
推荐使用带超时和精度控制的版本,避免卡死或返回低质量坐标。
var request = new GeolocationRequest(GeolocationAccuracy.High, TimeSpan.FromSeconds(30));
try
{
var location = await Geolocation.Default.GetLocationAsync(request);
if (location != null)
{
Console.WriteLine($"纬度:{location.Latitude},经度:{location.Longitude}");
}
}
catch (PermissionException)
{
// 用户拒绝了定位权限
}
catch (FeatureNotEnabledException)
{
// GPS 被关闭(比如飞行模式或手动关定位)
}
三、快速取缓存位置(适合轻量场景)
不触发新定位,直接读设备最近一次记录的位置,快但不一定准。
var lastLoc = await Geolocation.Default.GetLastKnownLocationAsync();
if (lastLoc != null)
{
Console.WriteLine($"缓存坐标:{lastLoc.Latitude}, {lastLoc.Longitude}");
}
注意:有些设备重启后缓存清空,返回 null;部分低端安卓机缓存更新不及时。
四、调试小技巧
- 真机测试才可靠——模拟器通常不模拟 GPS 移动,且 Android 模拟器需手动发送经纬度(通过 Extended Controls → Location)
- 检查手机系统设置里是否对你的 MAUI App 开启了“精确位置”权限(尤其 Android 12+ 和 iOS)
- 首次运行时系统弹窗拒绝后,后续调用会直接抛
PermissionException,需引导用户去系统设置手动开启
基本上就这些。不复杂但容易忽略权限和平台配置,跑通第一步后,后续加地图显示、地理编码都顺了。










