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