【GT-安卓应用开发之获取经纬度(非三方)】

本文深入探讨了安卓设备中获取地理位置的两种主要方法:基于GPS和基于网络的位置服务。通过代码示例,展示了如何请求必要的权限,以及如何实现位置监听和更新。同时,文章对比了集成第三方SDK与使用原生API的优缺点。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

前言:基于地理位置的服务目前十分火爆,因此在工作中经常会涉及到地理位置的获取。就我的了解,是有三种方式获取位置信息,分别是基于GPS和基于网络以及利用第三方获取位置信息。我个人习惯使用第三方,如百度地图、高德地图,因为其可以获取到详细的信息,而不仅仅是经纬度,更甚的是还可以获取天气情况~

  但是,今天记录的并不是集成第三方SDK,而是前两种方式。前两种方式一般来说是需要结合使用的,毕竟并不所有的手机都支持GPS。与集成第三方相比,前两种方式不需要增加项目体积。

  安卓提供了许多的服务,位置服务也是其中之一,我们正是借助该服务获取当前的经纬度,接下来便贴上相关代码:

  所需权限,需要注意的是6.0以上需要动态申请

<uses-permission android:name="android.permission.INTERNET"/>
<uses-permission android:name="android.permission.ACCESS_COARSE_LOCATION"/>
<uses-permission android:name="android.permission.ACCESS_FINE_LOCATION"/>
private static final int REQUEST_EXTERNAL_STORAGE = 1;
private static String[] PERMISSIONS_STORAGE = {
        Manifest.permission.INTERNET,
        Manifest.permission.ACCESS_COARSE_LOCATION,
        Manifest.permission.ACCESS_FINE_LOCATION
};
public static void verifyStoragePermissions(Activity activity) {
    // 检查权限是否已经申请
    int permission = ActivityCompat.checkSelfPermission(activity, Manifest.permission.WRITE_EXTERNAL_STORAGE);

    if (permission != PackageManager.PERMISSION_GRANTED) {
        // 申请权限
        ActivityCompat.requestPermissions(
                activity,
                PERMISSIONS_STORAGE,
                REQUEST_EXTERNAL_STORAGE
        );
    }
}

  根据网络获取位置信息

public String getLocationByNet() {
    double latitude = 0.0;
    double longitude = 0.0;
    LocationManager locationManager = (LocationManager) getSystemService(Context.LOCATION_SERVICE);
    locationManager.requestLocationUpdates(LocationManager.NETWORK_PROVIDER, 1000, 0, listener);
    Location location = locationManager.getLastKnownLocation(LocationManager.NETWORK_PROVIDER);
    if (location != null) {
        latitude = location.getLatitude();
        longitude = location.getLongitude();
    }else{
        return "error";//获取失败
    }
    return longitude + "," + latitude;
}
LocationListener listener = new LocationListener() {

    // Provider的状态在可用、暂时不可用和无服务三个状态直接切换时触发此函数
    @Override
    public void onStatusChanged(String provider, int status, Bundle extras) {

    }

    // Provider被enable时触发此函数,比如GPS被打开
    @Override
    public void onProviderEnabled(String provider) {

    }

    // Provider被disable时触发此函数,比如GPS被关闭
    @Override
    public void onProviderDisabled(String provider) {

    }

    //当坐标改变时触发此函数,如果Provider传进相同的坐标,它就不会被触发
    @Override
    public void onLocationChanged(Location location) {
    }

  基于GPS获取经纬度,如果信号弱或者直接不支持GPS的调用基于网络获取的方法获取

private String getLocationByGps(Context context) {
    double latitude = 0.0;
    double longitude = 0.0;
    LocationManager locationManager = (LocationManager) context.getSystemService(Context.LOCATION_SERVICE);
    if (locationManager.isProviderEnabled(LocationManager.GPS_PROVIDER)) {  //从gps获取经纬度
        Location location = locationManager.getLastKnownLocation(LocationManager.GPS_PROVIDER);
        if (location != null) {
            latitude = location.getLatitude();
            longitude = location.getLongitude();
        } else {
            //GPS信号弱,位置信息可能获取失败
            return getLocationByNet();
        }
    } else {
        //网络获取经纬度
        return getLocationByNet();
    }
    return longitude + "," + latitude;
}

完整代码

 

### 获取第三方应用布局中的控件ID 在安卓开发中,直接访问其他应用程序的视图层次结构受到严格的安全性和隐私保护机制限制。通常情况下,无法通过常规API直接获取并操作另一个应用程序内的具体UI组件或其ID。 对于同一应用内部而言,在使用像`GifImageView`这样的第三方库时,可以通过定义明确的资源ID来引用这些组件[^1]: ```xml <pl.droidsonroids.gif.GifImageView android:id="@+id/gifImageViewCircular" android:layout_width="225dp" android:layout_height="225dp" android:layout_gravity="center_horizontal" android:layout_marginTop="5dp"/&gt; ``` 然而针对不同应用间的交互需求,则需依赖于官方提供的接口或者遵循AIDL (Android Interface Definition Language)等方式实现跨进程通信(IPC),而不能直接读取或修改对方APP界面元素的信息。 如果目标是在自己项目的范围内处理来自外部源(比如网络加载)的内容,并且该内容包含了HTML或其他形式描述的UI结构,可以考虑解析相应文档对象模型(DOM),但这并不适用于原生安卓应用之间的控件识别与控制。 当涉及到集成如XBanner这类用于展示轮播效果的第三方库时,开发者同样应该按照所提供的指南完成初始化配置工作,而不是试图绕过正常渠道去抓取不属于本程序空间下的任何属性值[^2]。 #### 使用反射尝试获取公开字段(不推荐) 尽管存在技术上可能的方法——例如利用Java反射机制强行访问私有成员变量,但在实际项目里这样做是常不可取的行为。这不仅违反了软件设计原则,还可能导致兼容性问题以及安全风险增加等问题发生。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值