前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >Android高德之旅(1)基础地图

Android高德之旅(1)基础地图

作者头像
大公爵
发布2018-09-05 17:23:53
8360
发布2018-09-05 17:23:53
举报
文章被收录于专栏:葬爱家族葬爱家族

废话1

这个系列之前在CSDN上就发了,不过刚开始就因为公司项目忙搁置了,现在转移阵地到简书,希望这次能坚持把这个系列做完。

废话2

两三年前只有少数o2o软件、导航、交通软件会集成LBS,而现在是个软件都要集成LBS,所以作为开发的我们终于不能忍了,来搞搞LBS吧,目前用的最多的是百度地图和高德地图,百度地图定位精准、路线规划科学、图层显示清晰,嗯,那就选高德地图吧。

从今天开始,我们来一场说走就走的旅行,。探索基于高德SDK的LBS开发,筒子们,老司机要开车了,上车吧。

1、AndroidStudio新建工程

这步就不说了,这个都不会的,请出门左转,不过我看到高德官网文档上有这么一段:

哈哈,连新建工程都说的这么详细,真的要赞一下高德写文档的人,真是够耐心的。

2、导入jar、so包

去官网下载最新的开发包,或者下载官方demo,把它们的包拷贝出来。 (http://lbs.amap.com/api/android-sdk/download/

可以选择一键下载或者开发包定制下载,我这里选择的是定制下载,因为一键下载里面是没有定位包的。

开发包分两部分,jar包和so库,jar包直接全部拷贝到app/libs中,如下图:

(PS:因为我之前下载SDK选择的定制包下载,把所有的jar包合并成一个jar包了,所以这里只有一个)

so库直接拷贝进去是不行的,官方提供了两种方法: 方法一 使用默认配置,不需要修改build.gradle。在 main 目录下创建文件夹 jniLibs,将下载文件的 armeabi 文件夹复制到这个目录下即可,如下图:

方法二 使用自定义配置,将下载文件的 armeabi 文件夹复制到 libs 目录,然后打开build.gradle,找到 asourceSets 标签,在里面增加一项配置,如下图:

这里写图片描述

3、基础地图

准备工作已经做好了,下面就开始coding,写一个最简单的demo,展示最基本的地图

(1)布局文件中添加MapView

代码语言:javascript
复制
<com.amap.api.maps.MapView
        android:id="@+id/map_view"
        android:layout_width="match_parent"
        android:layout_height="match_parent" />

(2)Activity中使用MapView

代码语言:javascript
复制
public class MainActivity extends AppCompatActivity {

    private MapView mapView;

    private AMap aMap;

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

        mapView = (MapView) findViewById(R.id.map_view);
        mapView.onCreate(savedInstanceState); //此方法必须重写
        init();
    }

    private void init() {
        if (aMap == null) {
            aMap = mapView.getMap();
        }
        // TODO
    }

    /**
     * 方法必须重写
     */
    @Override
    protected void onResume() {
        super.onResume();
        mapView.onResume();
    }

    /**
     * 方法必须重写
     */
    @Override
    protected void onPause() {
        super.onPause();
        mapView.onPause();
    }

    /**
     * 方法必须重写
     */
    @Override
    protected void onSaveInstanceState(Bundle outState) {
        super.onSaveInstanceState(outState);
        mapView.onSaveInstanceState(outState);
    }

    /**
     * 方法必须重写
     */
    @Override
    protected void onDestroy() {
        super.onDestroy();
        mapView.onDestroy();
    }
}

(3)配置混淆

代码语言:javascript
复制
#3D 地图 V5.0.0之前:
-keep   class com.amap.api.maps.**{*;}
-keep   class com.autonavi.amap.mapcore.*{*;}
-keep   class com.amap.api.trace.**{*;}

#3D 地图 V5.0.0之后:
-keep   class com.amap.api.maps.**{*;}
-keep   class com.autonavi.**{*;}
-keep   class com.amap.api.trace.**{*;}

#定位
-keep class com.amap.api.location.**{*;}
-keep class com.amap.api.fence.**{*;}
-keep class com.autonavi.aps.amapapi.model.**{*;}

#搜索
-keep   class com.amap.api.services.**{*;}

#2D地图
-keep class com.amap.api.maps2d.**{*;}
-keep class com.amap.api.mapcore2d.**{*;}

#导航
-keep class com.amap.api.navi.**{*;}
-keep class com.autonavi.**{*;}

(4)权限配置

代码语言:javascript
复制
<!--允许程序打开网络套接字-->
<uses-permission android:name="android.permission.INTERNET" />
<!--允许程序设置内置sd卡的写权限-->
<uses-permission android:name="android.permission.WRITE_EXTERNAL_STORAGE" />
<!--允许程序获取网络状态-->
<uses-permission android:name="android.permission.ACCESS_NETWORK_STATE" />
<!--允许程序访问WiFi网络信息-->
<uses-permission android:name="android.permission.ACCESS_WIFI_STATE" />
<!--允许程序读写手机状态和身份-->
<uses-permission android:name="android.permission.READ_PHONE_STATE" />
<!--允许程序访问CellID或WiFi热点来获取粗略的位置-->
<uses-permission android:name="android.permission.ACCESS_COARSE_LOCATION" />

(5)apikey配置

代码语言:javascript
复制
<meta-data android:name="com.amap.api.v2.apikey"
       android:value="62d228e5c2****************a6262c1a31">
</meta-data>

value后面这串就是你在高德开发者平台注册的appKey,简单讲下这个注册。

(6)账号注册

a)、注册高德开发者账号 b)、申请成为开发者 c)、进入后台新建应用:名称需要符合命名规范,类型只能选已有类型

d)、配置应用信息

安全码SHA1的生成方法,请看我CSDN博客 http://blog.csdn.net/u011002668/article/details/53335264

(7)展示

至此,最简单的界面已经完成,运行后可以看到手机展示一个地图,有缩放、旋转等操作。

(8)小效果

最后我们来添加一个小效果:点击屏幕,地图旋转90度,同时视角倾斜60度

代码语言:javascript
复制
private void init() {
  if (aMap == null) {
        aMap = mapView.getMap();
    }
    aMap.setOnMapClickListener(this);
}

@Override
public void onMapClick(LatLng latLng) {
    aMap.animateCamera(
                CameraUpdateFactory.newCameraPosition(new CameraPosition(
                        new LatLng(39.92463, 116.389139), //经纬度
                        16, //缩放级别 3 -19 3:最大,看到全中国,19:最小,看到细节
                        60, //视角从垂直于地面,向下倾斜60度,此时与地面夹角是30度
                        90) //地图顺时针旋转90度
                ),
                1500,
                new AMap.CancelableCallback() {
                    @Override
                    public void onFinish() {
                        //TODO
                    }

                    @Override
                    public void onCancel() {
                        //TODO
                    }
                }
        );
}

总结

千里之行,始于足下,第一步终于迈出去了,下一篇来摸索下高德地图中的地图类型,感谢大家收看本期节目,我们下期再见~

本文参与 腾讯云自媒体分享计划,分享自作者个人站点/博客。
原始发表:2017.10.26 ,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 废话1
  • 废话2
  • 1、AndroidStudio新建工程
  • 2、导入jar、so包
  • 3、基础地图
    • (1)布局文件中添加MapView
      • (2)Activity中使用MapView
        • (3)配置混淆
          • (4)权限配置
            • (5)apikey配置
              • (6)账号注册
                • (7)展示
                  • (8)小效果
                  • 总结
                  领券
                  问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档