当前位置:   article > 正文

Android Studio2021.1.1 高德地图api调用这一篇就够了_didn't find class "com.amap.api.location.amaplocat

didn't find class "com.amap.api.location.amaplocationclient


小唐最近在做安卓移动应用开发,是真的太离谱的,csdn上面的各种教材是真的离谱,孩子要被整吐了,该遇到的,不该遇到的,基本都被我遇到了,搞了足足三四个小时,浅浅写一下,希望以后的孩子可以避坑。。。

一、高德API申请

高德API网址
在我们注册玩开发者账号之后,找到这个界面
在这里插入图片描述
在我们添加的时候,会遇到下面这两个选项,也是我们项目成功的关键
在这里插入图片描述

1.1 SHA1获取

我找的好多教材是叫我们自己去创建APK,然后又是什么什么是重新创建.jks,直接获取不香吗???
C:\Users\twy(你自己的用户名)下会有一个
在这里插入图片描述
进去之后,直接在这个页面输入cmd
在这里插入图片描述
在cmd里面输入

keytool -v -list -keystore debug.keystore      (keystore的名字)
  • 1

在这里插入图片描述
上图的密钥库口令默认的是:android
(注:输入口令是看不见的,输入完成Enter即可)

1.2 Packagename 包名获取

在这里插入图片描述

二、项目内配置

2.1 配置libs

配置好上面的信息之后,我们记得将官方lib包下载来
只需要定位的点击这个下载
Android 地图SDK 相关下载(如有其他需求在这里面找)
下载好之后
在这里插入图片描述
在这里插入图片描述
直接移动到我们
在这里插入图片描述
下载解压放置lis目录中,在这特别注意需要添加进入环境变量
Add As Library
在这里插入图片描述

2.2 配置AndroidManifest.xml

官方调用文档

就是直接在我们AndroidManifest.xml加上两句话

第一句:

   <meta-data android:name="com.amap.api.v2.apikey" android:value="你的key"></meta-data>
        <service android:name="com.amap.api.location.APSService"></service>
  • 1
  • 2

在这里插入图片描述
你的key会有高德生成记得回去看,然后复制上去

第二句:

<uses-permission android:name="android.permission.INTERNET" />
    <!--用于进行网络定位-->
    <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>
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
  • 14
  • 15
  • 16
  • 17
  • 18
  • 19
  • 20
  • 21
  • 22

添加完效果
这里是引用

2.3 编写MainActivity

package com.example.myapplication;

import androidx.appcompat.app.AppCompatActivity;
import android.os.Bundle;

import androidx.appcompat.app.AppCompatActivity;
import android.os.Bundle;
import android.util.Log;

import com.amap.api.location.AMapLocation;
import com.amap.api.location.AMapLocationClient;
import com.amap.api.location.AMapLocationClientOption;
import com.amap.api.location.AMapLocationListener;

public class MainActivity extends AppCompatActivity {
    //声明AMapLocationClient类对象
    public AMapLocationClient mLocationClient = null;
    //声明定位回调监听器
    public AMapLocationListener mLocationListener = new MyAMapLocationListener();
    //声明AMapLocationClientOption对象
    public AMapLocationClientOption mLocationOption = null;


    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);

        init();
    }

    private void init() {
        //初始化定位
        try {
            AMapLocationClient.updatePrivacyShow(this, true, true);
            AMapLocationClient.updatePrivacyAgree(this, true);
            mLocationClient = new AMapLocationClient(getApplicationContext());
        } catch (Exception e) {
            e.printStackTrace();
        }
        //设置定位回调监听
        mLocationClient.setLocationListener(mLocationListener);
        //初始化AMapLocationClientOption对象
        mLocationOption = new AMapLocationClientOption();
        //设置定位模式为AMapLocationMode.Hight_Accuracy,高精度模式。
        mLocationOption.setLocationMode(AMapLocationClientOption.AMapLocationMode.Hight_Accuracy);
        //获取一次定位结果:
        //该方法默认为false。
        mLocationOption.setOnceLocation(false);

        //获取最近3s内精度最高的一次定位结果:
        //设置setOnceLocationLatest(boolean b)接口为true,启动定位时SDK会返回最近3s内精度最高的一次定位结果。如果设置其为true,setOnceLocation(boolean b)接口也会被设置为true,反之不会,默认为false。
        mLocationOption.setOnceLocationLatest(true);
        //设置是否返回地址信息(默认返回地址信息)
        mLocationOption.setNeedAddress(true);
        //设置是否允许模拟位置,默认为false,不允许模拟位置
        mLocationOption.setMockEnable(false);
        //关闭缓存机制
        mLocationOption.setLocationCacheEnable(false);
        //给定位客户端对象设置定位参数
        mLocationClient.setLocationOption(mLocationOption);
        //启动定位
        mLocationClient.startLocation();

    }

    private class MyAMapLocationListener implements AMapLocationListener {

        @Override
        public void onLocationChanged(AMapLocation aMapLocation) {
            if (aMapLocation != null) {
                if (aMapLocation.getErrorCode() == 0) {
                    Log.e("位置:", aMapLocation.getAddress());
                } else {
                    //定位失败时,可通过ErrCode(错误码)信息来确定失败的原因,errInfo是错误信息,详见错误码表。
                    Log.e("AmapError", "location Error, ErrCode:"
                            + aMapLocation.getErrorCode() + ", errInfo:"
                            + aMapLocation.getErrorInfo());
                }
            }
        }
    }
}
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
  • 14
  • 15
  • 16
  • 17
  • 18
  • 19
  • 20
  • 21
  • 22
  • 23
  • 24
  • 25
  • 26
  • 27
  • 28
  • 29
  • 30
  • 31
  • 32
  • 33
  • 34
  • 35
  • 36
  • 37
  • 38
  • 39
  • 40
  • 41
  • 42
  • 43
  • 44
  • 45
  • 46
  • 47
  • 48
  • 49
  • 50
  • 51
  • 52
  • 53
  • 54
  • 55
  • 56
  • 57
  • 58
  • 59
  • 60
  • 61
  • 62
  • 63
  • 64
  • 65
  • 66
  • 67
  • 68
  • 69
  • 70
  • 71
  • 72
  • 73
  • 74
  • 75
  • 76
  • 77
  • 78
  • 79
  • 80
  • 81
  • 82
  • 83

三、实现效果

在这里插入图片描述

四、常见错误汇总及解决方案

1.import android.support.v7.app.AppCompatActivity报错

原因是.support.v7这种方式已经不支持了,换成最新的调用方式

import androidx.appcompat.app.AppCompatActivity;
  • 1

2.errorCode : 555570 使用loc SDK 功能前请设置隐私权政策是否弹窗告知用户

这个是官方给我们的文档,很遗憾,出错了,在最新版本中,我们不仅仅要用try来给这个对象接受返回,还需要在前面加上

AMapLocationClient.updatePrivacyShow(this, true, true);
AMapLocationClient.updatePrivacyAgree(this, true);
  • 1
  • 2

在这里插入图片描述
在这里插入图片描述

3.minSDK(API XX)>devicesdk(API XX) on device XXX

说人话就是,我们支持的最小版本高了,我们直接找到build.gradle
(build.gradle一共是有两个文件,我们打开的是app目录下的build.gradle!!!)
在这里插入图片描述

4. E/AmapError: location Error, ErrCode:4, errInfo:网络连接异常 请到http://lbs.amap.com/api/android-location-sdk/guide/utilities/errorcode/

哥,我们手机没有联网

5.还是说什么什么,我们没有权限,我们直接打开我们手机上面的设置,给我们生成的文件开启权限就可以了

遇到什么问题,欢迎随时来找小唐,其他问题,欢迎补充!!!

声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/我家自动化/article/detail/166178
推荐阅读
相关标签
  

闽ICP备14008679号