小言_互联网的博客

Android使用高德地图api实现基础定位

266人阅读  评论(0)

关于

这篇主要讲如何使用高德sdk(不是下载的jar包是引用的),高德开发者平台我们注册成为个人开发者后,进入控制台选择新建应用,出现如下图所示,这里我们我们要注意的是一个包名,以及debug版本的SHA1和release版本的SHA1:

会获取SHA1的可自行跳过这一步

关于这两个的获取方法上面也有流程提示,这里我选择的是第二种方法(命令行方法)
(前提啊,你要把你自己的项目生成apk一个debug.apk一个你自己项目名release.apk这两个的生成方法我就不详细介绍了(可以在build中选择Generate Signed Bundle/APK)如下图:)

回到我们刚才说的,第一步打开命令行输入:

.android

如下图,会自动进入到我们androidstudio的.android目录

接着输入keytool -list -v -keystore debug.keystore,然后输入密钥库密码(debug的apk的默认密码是android)输入android得到结果如下:


途中箭头所指的就是调试版本的SHA1啦。我们把它复制到我们先前需要的地方。
接来下同理我们输入keytool -list -v -keystore 你的jks或是keystore后缀名的release签名文件地址 xxx.jks

好啦这样提交我们的数据上去,就可以获得key了。

第二步引用高德sdk

配置步骤可以参考开发文档
第一步,在项目的build.gradle中添加如下:

//高德定位及3D地图
    implementation'com.amap.api:3dmap:latest.integration'
    implementation'com.amap.api:location:latest.integration'

第二步,在androidmanifest.xml中添加如下:

 <!--用于进行网络定位-->
    <uses-permission android:name="android.permission.ACCESS_COARSE_LOCATION"></uses-permission>
    <!--用于访问GPS定位-->
    <uses-permission android:name="android.permission.ACCESS_FINE_LOCATION"></uses-permission>
    <!--用于获取运营商信息,用于支持提供运营商信息相关的接口-->
    <uses-permission android:name="android.permission.ACCESS_NETWORK_STATE"></uses-permission>
    <!--用于访问wifi网络信息,wifi信息会用于进行网络定位-->
    <uses-permission android:name="android.permission.ACCESS_WIFI_STATE"></uses-permission>
    <!--用于获取wifi的获取权限,wifi信息会用来进行网络定位-->
    <uses-permission android:name="android.permission.CHANGE_WIFI_STATE"></uses-permission>
    <!--用于访问网络,网络定位需要上网-->
    <uses-permission android:name="android.permission.INTERNET"></uses-permission>
    <!--用于读取手机当前的状态-->
    <uses-permission android:name="android.permission.READ_PHONE_STATE"></uses-permission>
    <!--用于写入缓存数据到扩展存储卡-->
    <uses-permission android:name="android.permission.WRITE_EXTERNAL_STORAGE"></uses-permission>
    <!--用于申请调用A-GPS模块-->
    <uses-permission android:name="android.permission.ACCESS_LOCATION_EXTRA_COMMANDS"></uses-permission>
    <!--用于申请获取蓝牙信息进行室内定位-->
    <uses-permission android:name="android.permission.BLUETOOTH"></uses-permission>
    <uses-permission android:name="android.permission.BLUETOOTH_ADMIN"></uses-permission>

在androidmanifest.xml文件的application内添加如下:

 <!--在application标签中声明service组件,每个app拥有自己单独的定位service-->
        <service android:name="com.amap.api.location.APSService"></service>
        <meta-data android:name="com.amap.api.v2.apikey" android:value="xxxxxxxxxxxxkey"/>
        //开发者申请的key

第三步修改MainActivity.java

package com.example.weathertest;

import androidx.annotation.NonNull;
import androidx.appcompat.app.AppCompatActivity;
import android.os.Bundle;
import android.util.Log;
import android.view.View;
import android.widget.Button;
import android.widget.ImageView;
import android.widget.TextView;
import android.widget.Toast;
import com.amap.api.location.AMapLocation;
import com.amap.api.location.AMapLocationClient;
import com.amap.api.location.AMapLocationClientOption;
import com.amap.api.location.AMapLocationListener;
import com.google.gson.Gson;
import org.json.JSONArray;
import org.json.JSONException;
import org.json.JSONObject;
import java.io.IOException;
import java.util.List;

public class MainActivity extends AppCompatActivity {
    public AMapLocationClient mLocationClient=null;
    //声明定位回调监听器
    public AMapLocationClientOption mLocationOption=null;
    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);    
        initMap();
    }

    private void initMap() {
        //初始化定位
                mLocationClient=new AMapLocationClient(MainActivity.this);
                //设置定位回调监听
mLocationClient.setLocationListener(mLocationListener);
mLocationOption = new AMapLocationClientOption();
//设置定位模式为高精度模式,AMapLocationMode.Battery_Saving为低功耗模式,AMapLocationMode.Device_Sensors是仅设备模式
mLocationOption.setLocationMode(AMapLocationClientOption.AMapLocationMode.Hight_Accuracy);
mLocationOption.setNeedAddress(true);//设置是否返回地址信息(默认返回地址信息)
mLocationOption.setOnceLocation(false);//设置是否只定位一次,默认为false
mLocationOption.setWifiActiveScan(true);//设置是否强制刷新WIFI,默认为强制刷新
mLocationOption.setMockEnable(false);//设置是否允许模拟位置,默认为false,不允许模拟位置
mLocationOption.setInterval(15000);//设置定位间隔,单位毫秒,默认为2000ms
mLocationOption.setOnceLocation(false);//可选,是否设置单次定位默认为false即持续定位
mLocationOption.setOnceLocationLatest(false); //可选,设置是否等待wifi刷新,默认为false.如果设置为true,会自动变为单次定位,持续定位时不要使用
mLocationOption.setWifiScan(true); //可选,设置是否开启wifi扫描。默认为true,如果设置为false会同时停止主动刷新,停止以后完全依赖于系统刷新,定位位置可能存在误差
mLocationOption.setLocationCacheEnable(true); //可选,设置是否使用缓存定位,默认为true
//给定位客户端对象设置定位参数
mLocationClient.setLocationOption(mLocationOption);
//启动定位
mLocationClient.startLocation();
    }
    public AMapLocationListener mLocationListener=new AMapLocationListener() {
        @Override
        public void onLocationChanged(AMapLocation aMapLocation) {
            if (aMapLocation != null) {
                if (aMapLocation.getErrorCode() == 0) {
                   //定位成功回调信息,设置相关消息
                    aMapLocation.getLocationType();//获取当前定位结果来源,如网络定位结果,详见定位类型表
                   // aMapLocation.getLatitude();//获取纬度
                   // aMapLocation.getLongitude();//获取经度
                    aMapLocation.getAccuracy();//获取精度信息
                    java.text.SimpleDateFormat df = new java.text.SimpleDateFormat("yyyy-MM-dd HH:mm:ss");

                  //  aMapLocation.getAddress();//地址,如果option中设置isNeedAddress为false,则没有此结果,网络定位结果中会有地址信息,GPS定位不返回地址信息。
                  //  aMapLocation.getCountry();//国家信息
                  //  aMapLocation.getProvince();//省信息
                  //  aMapLocation.getCity();//城市信息
                 //   aMapLocation.getDistrict();//城区信息
                //    aMapLocation.getStreet();//街道信息
               //     aMapLocation.getStreetNum();//街道门牌号信息
                //    aMapLocation.getCityCode();//城市编码
               //     aMapLocation.getAdCode();//地区编码  
                   System.out.println("所在城市:"+aMapLocation.getCountry()+aMapLocation.getProvince()+aMapLocation.getCity());
                    mLocationClient.stopLocation();//停止定位
                } else {
                    //显示错误信息ErrCode是错误码,errInfo是错误信息,详见错误码表。
                    Log.e("info", "location Error, ErrCode:"
                            + aMapLocation.getErrorCode() + ", errInfo:"
                            + aMapLocation.getErrorInfo());
                }
            }
        }
    };
      
    @Override
    protected void onDestroy() {
        super.onDestroy();
        //销毁
        if (mLocationClient !=null){
            mLocationClient.onDestroy();
        }
    }
}

运行结果如下:

这篇只是简单的实现定位功能,后面将会组合使用放到本人的简易新闻app上,如果有问题欢迎指正!


转载:https://blog.csdn.net/Tobey_r1/article/details/100985156
查看评论
* 以上用户言论只代表其个人观点,不代表本网站的观点或立场