Mapbox Android SDK官方教程(一)——Mapbox Maps SDK for Android

开始mapbox的学习,额,最近好像铺的太广,leaflet、openLayer、Qgis,其实还在学Cesium,最近看这么多,主要还是因为最近项目需要,很想把这几个都过一遍,熟悉熟悉,本来打算用leaflet做的,但是后来发现leaflet内嵌到android,JS和android交互麻烦,那就还不如直接用mapbox 的android SDK,所以又开始搞一下mapbox,最近已经搞了不少了,翻译记录下来。

mapbox android SDK是用来在安卓平台上展示地图的开源工具集。mapbox demo app中包含许多案例,可以在google play store中找到。本文档中很多demo也可以在该app找到。

Install the Maps SDK

在开始用map SDK开发你的应用之前,需要将SDK添加依赖,你可以在MavenCentral依赖中找到下面需要的依赖,下面提供的是通过gradle安装SDK,我们也提供对fabric的支持。

 如果你的应用有方法数量限制,你可以通过许可proguard来缓解这个问题。

一. Add the dependency

    1、打开android studio

    2、打开你application的build.gradle

    3、确保你工程的最小sdk版本在API14以上

    4、添加最新的mapbox-android-sdk的构建到依赖下

    5、点击sync同步工程


二、Get an access token

如果你没有mapbox的账号,去官方主页去注册获取token。当你将maps SDK添加到你的android工程后,打开String.xml文件,创建一个新的token的string。你将要在oncreate方法中用到此token。


三、Setup permissions

从5.0开始,权限只要加入如下:


四、Add a map

打开java文件activity加入下面代码到其中:

打开acivities布局文件,将下面mapView添加到布局:


五、生命周期方法

mapview的生命周期方法包含在android的opengl生命周期中。为了在app中正确调用mapview的生命周期方法,你需要在android的生命周期中重写如下方法:

以下生命周期方法都需要重写:


Attribution

Telemetry opt out

mapbox telemetry是内置在SDK中的一个很有用的位置分析平台。默认情况下,匿名位置和用户数据被发送到mapbox

MapView XML attributes


  • 1
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
以下是mapbox for android教程: 1. 安装Mapbox SDK 在项目的build.gradle文件中添加以下依赖项: ```gradle implementation 'com.mapbox.mapboxsdk:mapbox-android-sdk:9.6.1' ``` 2. 在布局文件中添加MapView ```xml <com.mapbox.mapboxsdk.maps.MapView android:id="@+id/mapView" android:layout_width="match_parent" android:layout_height="match_parent" mapbox:mapbox_cameraTargetLat="40.73581" mapbox:mapbox_cameraTargetLng="-73.99155" mapbox:mapbox_cameraZoom="11"/> ``` 3. 在Activity中初始化MapView ```java public class MainActivity extends AppCompatActivity implements OnMapReadyCallback { private MapView mapView; @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); Mapbox.getInstance(this, "YOUR_MAPBOX_ACCESS_TOKEN"); setContentView(R.layout.activity_main); mapView = findViewById(R.id.mapView); mapView.onCreate(savedInstanceState); mapView.getMapAsync(this); } @Override public void onMapReady(@NonNull MapboxMap mapboxMap) { // 在这里可以对地图进行操作 } @Override protected void onStart() { super.onStart(); mapView.onStart(); } @Override protected void onResume() { super.onResume(); mapView.onResume(); } @Override protected void onPause() { super.onPause(); mapView.onPause(); } @Override protected void onStop() { super.onStop(); mapView.onStop(); } @Override protected void onSaveInstanceState(Bundle outState) { super.onSaveInstanceState(outState); mapView.onSaveInstanceState(outState); } @Override protected void onRestoreInstanceState(Bundle savedInstanceState) { super.onRestoreInstanceState(savedInstanceState); mapView.onRestoreInstanceState(savedInstanceState); } @Override protected void onDestroy() { super.onDestroy(); mapView.onDestroy(); } } ``` 4. 在Activity中对地图进行操作 ```java // 获取地图对象 MapboxMap mapboxMap = mapView.getMapAsync(this); // 移动地图到指定位置 CameraPosition position = new CameraPosition.Builder() .target(new LatLng(40.73581, -73.99155)) .zoom(11) .build(); mapboxMap.animateCamera(CameraUpdateFactory.newCameraPosition(position), 1000); // 添加标记 MarkerOptions markerOptions = new MarkerOptions() .position(new LatLng(40.73581, -73.99155)) .title("Marker Title") .snippet("Marker Description"); mapboxMap.addMarker(markerOptions); // 添加线 List<LatLng> points = new ArrayList<>(); points.add(new LatLng(40.73581, -73.99155)); points.add(new LatLng(40.748817, -73.985428)); LineOptions lineOptions = new LineOptions() .addAll(points) .color(Color.parseColor("#3bb2d0")) .width(2); mapboxMap.addPolyline(lineOptions); // 添加面 List<LatLng> polygonPoints = new ArrayList<>(); polygonPoints.add(new LatLng(40.73581, -73.99155)); polygonPoints.add(new LatLng(40.748817, -73.985428)); polygonPoints.add(new LatLng(40.718217, -73.998284)); polygonPoints.add(new LatLng(40.73581, -73.99155)); FillOptions fillOptions = new FillOptions() .addAll(polygonPoints) .alpha(0.4f) .fillColor(Color.parseColor("#3bb2d0")); mapboxMap.addPolygon(fillOptions); ```

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值