安卓智能地图开发与实施十七:使用天地图 - ArcGIS Runtime SDK for Android(Version 100.1.0)

本文介绍如何在ArcGIS Runtime SDK for Android环境中使用天地图服务,并提供详细的参数配置与服务类型的枚举定义,包括墨卡托投影与国家2000坐标系下的地图、影像及地形服务。

WebTiledLayer

100.1的新版本最大的亮点是三维,同时新加入了图层类型和可扩展的切片图层WebTiledLayer。继承自ServiceImageTiledLayer。BingMapsLayer和OpenStreetMapLayer继承自ServiceImageTiledLayer。通过设置WebTiledLayer参数便可以在ArcGIS Runtime SDK for Android的环境中使用天地图服务。

这里写图片描述

天地图相关参数

对天地图和ArcGIS参数不太清楚的可以参考:
http://blog.csdn.net/arcgis_all/article/details/8848120?utm_source=tuicool&utm_medium=referral

这里写图片描述

定义天地图相关参数

    private static final List<String> SubDomain = Arrays.asList(new String [] {"t0", "t1", "t2", "t3", "t4", "t5", "t6", "t7"});
    private static final String URL_VECTOR_2000 = "http://{subDomain}.tianditu.com/DataServer?T=vec_c&x={col}&y={row}&l={level}";
    private static final String URL_VECTOR_ANNOTATION_CHINESE_2000 = "http://{subDomain}.tianditu.com/DataServer?T=cva_c&x={col}&y={row}&l={level}";
    private static final String URL_VECTOR_ANNOTATION_ENGLISH_2000 = "http://{subDomain}.tianditu.com/DataServer?T=eva_c&x={col}&y={row}&l={level}";
    private static final String URL_IMAGE_2000 = "http://{subDomain}.tianditu.com/DataServer?T=img_c&x={col}&y={row}&l={level}";
    private static final String URL_IMAGE_ANNOTATION_CHINESE_2000 = "http://{subDomain}.tianditu.com/DataServer?T=cia_c&x={col}&y={row}&l={level}";
    private static final String URL_IMAGE_ANNOTATION_ENGLISH_2000 = "http://{subDomain}.tianditu.com/DataServer?T=eia_c&x={col}&y={row}&l={level}";
    private static final String URL_TERRAIN_2000 = "http://{subDomain}.tianditu.com/DataServer?T=ter_c&x={col}&y={row}&l={level}";
    private static final String URL_TERRAIN_ANNOTATION_CHINESE_2000 = "http://{subDomain}.tianditu.com/DataServer?T=cta_c&x={col}&y={row}&l={level}";

    private static final String URL_VECTOR_MERCATOR = "http://{subDomain}.tianditu.com/DataServer?T=vec_w&x={col}&y={row}&l={level}";
    private static final String URL_VECTOR_ANNOTATION_CHINESE_MERCATOR = "http://{subDomain}.tianditu.com/DataServer?T=cva_w&x={col}&y={row}&l={level}";
    private static final String URL_VECTOR_ANNOTATION_ENGLISH_MERCATOR = "http://{subDomain}.tianditu.com/DataServer?T=eva_w&x={col}&y={row}&l={level}";
    private static final String URL_IMAGE_MERCATOR = "http://{subDomain}.tianditu.com/DataServer?T=img_w&x={col}&y={row}&l={level}";
    private static final String URL_IMAGE_ANNOTATION_CHINESE_MERCATOR = "http://{subDomain}.tianditu.com/DataServer?T=cia_w&x={col}&y={row}&l={level}";
    private static final String URL_IMAGE_ANNOTATION_ENGLISH_MERCATOR = "http://{subDomain}.tianditu.com/DataServer?T=eia_w&x={col}&y={row}&l={level}";
    private static final String URL_TERRAIN_MERCATOR = "http://{subDomain}.tianditu.com/DataServer?T=ter_w&x={col}&y={row}&l={level}";
    private static final String URL_TERRAIN_ANNOTATION_CHINESE_MERCATOR = "http://{subDomain}.tianditu.com/DataServer?T=cta_w&x={col}&y={row}&l={level}";

    private static final int DPI = 96;
    private static final int minZoomLevel = 1;
    private static final int maxZoomLevel = 18;
    private static final int tileWidth = 256;
    private static final int tileHeight = 256;
    private static final String LAYER_NAME_VECTOR = "vec";
    private static final String LAYER_NAME_VECTOR_ANNOTATION_CHINESE = "cva";
    private static final String LAYER_NAME_VECTOR_ANNOTATION_ENGLISH = "eva";
    private static final String LAYER_NAME_IMAGE = "img";
    private static final String LAYER_NAME_IMAGE_ANNOTATION_CHINESE = "cia";
    private static final String LAYER_NAME_IMAGE_ANNOTATION_ENGLISH = "eia";
    private static final String LAYER_NAME_TERRAIN = "ter";
    private static final String LAYER_NAME_TERRAIN_ANNOTATION_CHINESE = "cta";

    private static final SpatialReference SRID_2000 = SpatialReference.create(4490);
    private static final SpatialReference SRID_MERCATOR = SpatialReference.create(102100);
    private static final double X_MIN_2000 = -180;
    private static final double Y_MIN_2000 = -90;
    private static final double X_MAX_2000 = 180;
    private static final double Y_MAX_2000 = 90;

    private static final double X_MIN_MERCATOR = -20037508.3427892;
    private static final double Y_MIN_MERCATOR = -20037508.3427892;
    private static final double X_MAX_MERCATOR = 20037508.3427892;
    private static final double Y_MAX_MERCATOR = 20037508.3427892;
    private static final Point ORIGIN_2000 = new Point(-180, 90,SRID_2000);
    private static final Point ORIGIN_MERCATOR = new Point(-20037508.3427892,20037508.3427892,SRID_MERCATOR);
    private static final Envelope ENVELOPE_2000 = new Envelope(X_MIN_2000,Y_MIN_2000,X_MAX_2000,Y_MAX_2000,SRID_2000);
    private static final Envelope ENVELOPE_MERCATOR = new Envelope(X_MIN_MERCATOR,Y_MIN_MERCATOR,X_MAX_MERCATOR,Y_MAX_MERCATOR,SRID_MERCATOR);

    private static final double[] SCALES = {
            2.958293554545656E8,1.479146777272828E8,
            7.39573388636414E7, 3.69786694318207E7,
            1.848933471591035E7, 9244667.357955175,
            4622333.678977588,2311166.839488794,
            1155583.419744397, 577791.7098721985,
            288895.85493609926, 144447.92746804963,
            72223.96373402482,36111.98186701241,
            18055.990933506204, 9027.995466753102,
            4513.997733376551, 2256.998866688275,
            1128.4994333441375
    };
    private static final double[] RESOLUTIONS_MERCATOR = {
            78271.51696402048, 39135.75848201024,
            19567.87924100512, 9783.93962050256,
            4891.96981025128, 2445.98490512564,
            1222.99245256282, 611.49622628141,
            305.748113140705, 152.8740565703525,
            76.43702828517625, 38.21851414258813,
            19.109257071294063, 9.554628535647032,
            4.777314267823516, 2.388657133911758,
            1.194328566955879, 0.5971642834779395,
            0.298582141738970};

    private static final double[] RESOLUTIONS_2000 = {
            0.7031249999891485,0.35156249999999994,
            0.17578124999999997, 0.08789062500000014,
            0.04394531250000007, 0.021972656250000007,
            0.01098632812500002,0.00549316406250001,
            0.0027465820312500017, 0.0013732910156250009,
            0.000686645507812499, 0.0003433227539062495,
            0.00017166137695312503, 0.00008583068847656251,
            0.000042915344238281406, 0.000021457672119140645,
            0.000010728836059570307, 0.000005364418029785169};

定义天地图可用服务类型枚举

public enum LayerType {
        /**
         * 天地图矢量墨卡托投影地图服务
         */
        TIANDITU_VECTOR_MERCATOR,
        /**
         * 天地图矢量墨卡托中文标注
         */
        TIANDITU_VECTOR_ANNOTATION_CHINESE_MERCATOR,
        /**
         * 天地图矢量墨卡托英文标注
         */
        TIANDITU_VECTOR_ANNOTATION_ENGLISH_MERCATOR,
        /**
         * 天地图影像墨卡托投影地图服务
         */
        TIANDITU_IMAGE_MERCATOR,
        /**
         * 天地图影像墨卡托投影中文标注
         */
        TIANDITU_IMAGE_ANNOTATION_CHINESE_MERCATOR,
        /**
         * 天地图影像墨卡托投影英文标注
         */
        TIANDITU_IMAGE_ANNOTATION_ENGLISH_MERCATOR,
        /**
         * 天地图地形墨卡托投影地图服务
         */
        TIANDITU_TERRAIN_MERCATOR,
        /**
         * 天地图地形墨卡托投影中文标注
         */
        TIANDITU_TERRAIN_ANNOTATION_CHINESE_MERCATOR,
        /**
         * 天地图矢量国家2000坐标系地图服务
         */
        TIANDITU_VECTOR_2000,
        /**
         * 天地图矢量国家2000坐标系中文标注
         */
        TIANDITU_VECTOR_ANNOTATION_CHINESE_2000,
        /**
         * 天地图矢量国家2000坐标系英文标注
         */
        TIANDITU_VECTOR_ANNOTATION_ENGLISH_2000,
        /**
         * 天地图影像国家2000坐标系地图服务
         */
        TIANDITU_IMAGE_2000,
        /**
         * 天地图影像国家2000坐标系中文标注
         */
        TIANDITU_IMAGE_ANNOTATION_CHINESE_2000,
        /**
         * 天地图影像国家2000坐标系英文标注
         */
        TIANDITU_IMAGE_ANNOTATION_ENGLISH_2000,
        /**
         * 天地图地形国家2000坐标系地图服务
         */
        TIANDITU_TERRAIN_2000,
        /**
         * 天地图地形国家2000坐标系中文标注
         */
        TIANDITU_TERRAIN_ANNOTATION_CHINESE_2000

    }

通过天地图枚举类型获取WebTiledLayer

    public static WebTiledLayer CreateTianDiTuTiledLayer(LayerType layerType)
    {
        WebTiledLayer webTiledLayer = null;
        String mainUrl = "";
        String mainName = "";
        TileInfo mainTileInfo = null;
        Envelope mainEnvelope = null;
        boolean mainIs2000 = false;
        try {
            switch (layerType) {
                case TIANDITU_VECTOR_2000:
                    mainUrl = URL_VECTOR_2000;
                    mainName = LAYER_NAME_VECTOR;
                    mainIs2000 = true;
                    break;
                case TIANDITU_VECTOR_MERCATOR:
                    mainUrl = URL_VECTOR_MERCATOR;
                    mainName = LAYER_NAME_VECTOR;
                    break;
                case TIANDITU_IMAGE_2000:
                    mainUrl = URL_IMAGE_2000;
                    mainName = LAYER_NAME_IMAGE;
                    mainIs2000 = true;
                    break;
                case TIANDITU_IMAGE_ANNOTATION_CHINESE_2000:
                    mainUrl = URL_IMAGE_ANNOTATION_CHINESE_2000;
                    mainName = LAYER_NAME_IMAGE_ANNOTATION_CHINESE;
                    mainIs2000 = true;
                    break;
                case TIANDITU_IMAGE_ANNOTATION_ENGLISH_2000:
                    mainUrl = URL_IMAGE_ANNOTATION_ENGLISH_2000;
                    mainName = LAYER_NAME_IMAGE_ANNOTATION_ENGLISH;
                    mainIs2000 = true;
                    break;
                case TIANDITU_IMAGE_ANNOTATION_CHINESE_MERCATOR:
                    mainUrl = URL_IMAGE_ANNOTATION_CHINESE_MERCATOR;
                    mainName = LAYER_NAME_IMAGE_ANNOTATION_CHINESE;
                    break;
                case TIANDITU_IMAGE_ANNOTATION_ENGLISH_MERCATOR:
                    mainUrl = URL_IMAGE_ANNOTATION_ENGLISH_MERCATOR;
                    mainName = LAYER_NAME_IMAGE_ANNOTATION_ENGLISH;
                    break;
                case TIANDITU_IMAGE_MERCATOR:
                    mainUrl = URL_IMAGE_MERCATOR;
                    mainName = LAYER_NAME_IMAGE;
                    break;
                case TIANDITU_VECTOR_ANNOTATION_CHINESE_2000:
                    mainUrl = URL_VECTOR_ANNOTATION_CHINESE_2000;
                    mainName = LAYER_NAME_VECTOR_ANNOTATION_CHINESE;
                    mainIs2000 = true;
                    break;
                case TIANDITU_VECTOR_ANNOTATION_ENGLISH_2000:
                    mainUrl = URL_VECTOR_ANNOTATION_ENGLISH_2000;
                    mainName = LAYER_NAME_VECTOR_ANNOTATION_ENGLISH;
                    mainIs2000 = true;
                    break;
                case TIANDITU_VECTOR_ANNOTATION_CHINESE_MERCATOR:
                    mainUrl = URL_VECTOR_ANNOTATION_CHINESE_MERCATOR;
                    mainName = LAYER_NAME_VECTOR_ANNOTATION_CHINESE;
                    break;
                case TIANDITU_VECTOR_ANNOTATION_ENGLISH_MERCATOR:
                    mainUrl = URL_VECTOR_ANNOTATION_ENGLISH_MERCATOR;
                    mainName = LAYER_NAME_VECTOR_ANNOTATION_ENGLISH;
                    break;
                case TIANDITU_TERRAIN_2000:
                    mainUrl = URL_TERRAIN_2000;
                    mainName = LAYER_NAME_TERRAIN;
                    mainIs2000 = true;
                    break;
                case TIANDITU_TERRAIN_ANNOTATION_CHINESE_2000:
                    mainUrl = URL_TERRAIN_ANNOTATION_CHINESE_2000;
                    mainName = LAYER_NAME_TERRAIN_ANNOTATION_CHINESE;
                    mainIs2000 = true;
                    break;
                case TIANDITU_TERRAIN_MERCATOR:
                    mainUrl = URL_TERRAIN_MERCATOR;
                    mainName = LAYER_NAME_TERRAIN;
                    break;
                case TIANDITU_TERRAIN_ANNOTATION_CHINESE_MERCATOR:
                    mainUrl = URL_TERRAIN_ANNOTATION_CHINESE_MERCATOR;
                    mainName = LAYER_NAME_TERRAIN_ANNOTATION_CHINESE;
                    break;
            }
            List<LevelOfDetail> mainLevelOfDetail = new ArrayList<LevelOfDetail>();
            Point mainOrigin = null;
            if(mainIs2000 == true)
            {
                for (int i = minZoomLevel; i <= maxZoomLevel; i++) {
                    LevelOfDetail item = new LevelOfDetail(i,RESOLUTIONS_2000[i-1],SCALES[i-1]);
                    mainLevelOfDetail.add(item);
                }
                mainEnvelope = ENVELOPE_2000;
                mainOrigin = ORIGIN_2000;
            }
            else
            {
                for (int i = minZoomLevel; i <= maxZoomLevel; i++) {
                    LevelOfDetail item = new LevelOfDetail(i,RESOLUTIONS_MERCATOR[i-1],SCALES[i-1]);
                    mainLevelOfDetail.add(item);
                }
                mainEnvelope = ENVELOPE_MERCATOR;
                mainOrigin = ORIGIN_MERCATOR;
            }
            mainTileInfo = new TileInfo(
                    DPI,
                    TileInfo.ImageFormat.PNG24,
                    mainLevelOfDetail,
                    mainOrigin,
                    mainOrigin.getSpatialReference(),
                    tileHeight,
                    tileWidth
            );
            webTiledLayer = new WebTiledLayer(
                    mainUrl,
                    SubDomain,
                    mainTileInfo,
                    mainEnvelope);
            webTiledLayer.setName(mainName);
            webTiledLayer.loadAsync();
        }
        catch (Exception e)
        {
            e.getCause();
        }
        return webTiledLayer;
    }

使用实例

三维场景中使用:需要Web墨卡托投影的
mainSceneView = (SceneView) mainSceneViewContainer.findViewById(R.id.mainSceneView);
        ArcGISScene scene = new ArcGISScene();
        WebTiledLayer webTiledLayer = TianDiTuMethodsClass.CreateTianDiTuTiledLayer(TianDiTuMethodsClass.LayerType.TIANDITU_VECTOR_MERCATOR);
        Basemap tdtBasemap =new Basemap(webTiledLayer);
        WebTiledLayer webTiledLayer1 = TianDiTuMethodsClass.CreateTianDiTuTiledLayer(TianDiTuMethodsClass.LayerType.TIANDITU_VECTOR_ANNOTATION_CHINESE_MERCATOR);
        tdtBasemap.getBaseLayers().add(webTiledLayer1);
        scene.setBasemap(tdtBasemap);
        mainSceneView.setScene(scene);
        mainSceneView.setAttributionTextVisible(false);

二维中使用

WebTiledLayer webTiledLayer = TianDiTuMethodsClass.CreateTianDiTuTiledLayer(TianDiTuMethodsClass.LayerType.TIANDITU_VECTOR_2000);
        Basemap tdtBasemap =new Basemap(webTiledLayer);
        WebTiledLayer webTiledLayer1 = TianDiTuMethodsClass.CreateTianDiTuTiledLayer(TianDiTuMethodsClass.LayerType.TIANDITU_VECTOR_ANNOTATION_CHINESE_2000);
        tdtBasemap.getBaseLayers().add(webTiledLayer1);
mainMapView.getMap().setBasemap(tdtBasemap);

这里写图片描述

<think> 我们注意到用户的问题是关于在ArcGIS for Android中不使用`com.esri.arcgisruntime.mapping.view.MapView`来使用ArcGIS地图的方法。 根据引用[3],常见的ArcGIS地图展示使用的是`com.esri.arcgisruntime.mapping.view.MapView`控件。但是用户明确要求不使用这个控件。 在ArcGIS Runtime SDK for Android中,`MapView`是展示地图的主要视图组件。如果不使用它,我们需要考虑替代方案。 可能的替代方案: 1. 使用WebView加载ArcGIS JavaScript API的地图(即通过Web方式嵌入地图)。 2. 使用其他地图引擎(如Google Maps、Mapbox等)并叠加ArcGIS地图服务(例如作为瓦片图层或动态图层)。 由于用户要求使用ArcGIS地图,我们主要考虑第一种方案,因为第二种方案虽然可以加载ArcGIS服务,但并不是直接使用ArcGIS SDK。 方案一:使用WebView加载ArcGIS JavaScript API 步骤: a. 在布局文件中添加WebView组件。 b. 在Activity中初始化WebView,并启用JavaScript。 c. 加载包含ArcGIS JavaScript API的HTML页面,该页面中初始化地图。 示例代码: 1. 布局文件(activity_main.xml): ```xml <?xml version="1.0" encoding="utf-8"?> <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android" android:layout_width="match_parent" android:layout_height="match_parent" android:orientation="vertical"> <WebView android:id="@+id/webView" android:layout_width="match_parent" android:layout_height="match_parent" /> </LinearLayout> ``` 2. 在assets目录下创建html文件(例如map.html): ```html <!DOCTYPE html> <html> <head> <meta charset="utf-8" /> <meta name="viewport" content="initial-scale=1, maximum-scale=1, user-scalable=no" /> <title>ArcGIS JavaScript API in WebView</title> <link rel="stylesheet" href="https://js.arcgis.com/4.24/esri/themes/light/main.css" /> <script src="https://js.arcgis.com/4.24/"></script> <style> html, body, #viewDiv { padding: 0; margin: 0; height: 100%; width: 100%; } </style> <script> require(["esri/Map", "esri/views/MapView"], function(Map, MapView) { var map = new Map({ basemap: "streets" }); var view = new MapView({ container: "viewDiv", map: map, center: [118.79, 32.06], // 南京的经纬度 zoom: 10 }); }); </script> </head> <body> <div id="viewDiv"></div> </body> </html> ``` 3. Activity中(MainActivity.java): ```java import android.os.Bundle; import android.webkit.WebSettings; import android.webkit.WebView; import androidx.appcompat.app.AppCompatActivity; public class MainActivity extends AppCompatActivity { private WebView webView; @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.activity_main); webView = findViewById(R.id.webView); WebSettings webSettings = webView.getSettings(); webSettings.setJavaScriptEnabled(true); webSettings.setDomStorageEnabled(true); // 加载本地html文件 webView.loadUrl("file:///android_asset/map.html"); } } ``` 注意事项: - 需要确保在AndroidManifest.xml中声明了网络权限:`<uses-permission android:name="android.permission.INTERNET" />`。 - 这种方式实际上是在WebView中运行一个Web应用,因此性能可能不如原生MapView,并且一些原生功能(如GPS定位)需要额外通过JavaScript接口桥接。 方案二:在其他地图引擎中加载ArcGIS服务(以Google Maps为例) 我们可以将ArcGIS地图服务作为瓦片图层叠加到Google Maps上。但是这种方法需要用户集成Google Maps SDK,并且需要知道ArcGIS地图服务的URL(通常是REST服务)。 步骤: a. 添加Google Maps SDK依赖。 b. 在布局中添加Google MapView。 c. 在代码中配置Google Map,并添加一个TileOverlay,该TileOverlay使用ArcGIS的瓦片服务URL。 示例(假设我们使用一个ArcGIS的瓦片服务URL,例如:https://services.arcgisonline.com/ArcGIS/rest/services/World_Topo_Map/MapServer): 1. 在GoogleMap中添加TileOverlay: ```java // 假设你已经初始化了GoogleMap对象:googleMap // 创建一个瓦片提供器,指向ArcGIS的瓦片服务 TileProvider arcgisTileProvider = new UrlTileProvider(256, 256) { @Override public URL getTileUrl(int x, int y, int zoom) { // 注意:不同的服务URL模板可能不同,这里是一个示例模板 String url = "https://services.arcgisonline.com/ArcGIS/rest/services/World_Topo_Map/MapServer/tile/"+zoom+"/"+y+"/"+x; try { return new URL(url); } catch (MalformedURLException e) { return null; } } }; // 添加瓦片图层 googleMap.addTileOverlay(new TileOverlayOptions().tileProvider(arcgisTileProvider)); ``` 但是请注意,这种方法需要用户集成Google Maps SDK,并且需要处理坐标转换(例如,Web墨卡托投影)和瓦片URL的拼接规则。不同的ArcGIS服务可能有不同的URL模式。 结论: - 如果不使用`MapView`,推荐使用WebView的方式,因为它直接使用ArcGIS JavaScript API,功能全面且兼容性好。 - 如果应用已经集成了其他地图引擎(如Google Maps),并且只需要加载特定的ArcGIS瓦片服务,则可以使用第二种方法。 用户可以根据具体需求选择合适的方法。 引用说明: - 方案一参考了Web开发中嵌入ArcGIS JavaScript API的常规方法。 - 方案二参考了Google Maps中叠加自定义瓦片图层的文档。 如果用户有特定的ArcGIS服务需要加载,或者有特定的需求(如离线使用),可能需要进一步的调整。 </think> 在 ArcGIS for Android 中,如果不使用 `com.esri.arcgisruntime.mapping.view.MapView`,可以通过以下两种替代方案实现地图加载: ### 方案一:通过 WebView 集成 ArcGIS JavaScript API(推荐) 1. **原理** 在 WebView 中运行 ArcGIS JavaScript API 的 HTML 页面,通过 Web 接口调用地图服务,避开原生 MapView 控件。 2. **实现步骤** **① 添加权限和布局** ```xml <!-- AndroidManifest.xml --> <uses-permission android:name="android.permission.INTERNET" /> ``` ```xml <!-- activity_main.xml --> <WebView android:id="@+id/webview" android:layout_width="match_parent" android:layout_height="match_parent" /> ``` **② 创建 HTML 地图页面**(存于 `assets/map.html`) ```html <!DOCTYPE html> <html> <head> <meta charset="utf-8"> <link rel="stylesheet" href="https://js.arcgis.com/4.24/esri/themes/light/main.css"> <script src="https://js.arcgis.com/4.24/"></script> <script> require(["esri/Map", "esri/views/MapView"], (Map, MapView) => { const map = new Map({ basemap: "topo-vector" }); const view = new MapView({ container: "viewDiv", map: map, center: [118.79, 32.06], // 南京坐标 zoom: 10 }); }); </script> </head> <body> <div id="viewDiv" style="height:100%;width:100%"></div> </body> </html> ``` **③ 加载 WebView** ```java WebView webView = findViewById(R.id.webview); webView.getSettings().setJavaScriptEnabled(true); webView.loadUrl("file:///android_asset/map.html"); ``` 3. **优点** - 完全避开原生 MapView 依赖 - 跨平台兼容性强 -使用全部 ArcGIS Online 服务 --- ### 方案二:通过其他地图引擎加载 ArcGIS 服务 1. **原理** 使用第三方地图控件(如 Google Maps)加载 ArcGIS 提供的 WMTS/TMS 服务。 2. **实现步骤**(以 Google Maps 为例) **① 添加 WMTS 图层** ```java // 构建 ArcGIS 瓦片服务 URL(天地图示例) String urlTemplate = "https://t0.tianditu.gov.cn/vec_w/wmts?layer=vec&style=default&tilematrixset=w&Service=WMTS&Request=GetTile&Version=1.0.0&Format=tiles&TileMatrix={z}&TileCol={x}&TileRow={y}&tk=您的密钥"; // 创建瓦片图层 TileOverlayOptions tileOverlayOptions = new TileOverlayOptions() .tileProvider(new UrlTileProvider(256, 256) { @Override public URL getTileUrl(int x, int y, int zoom) { String sUrl = urlTemplate .replace("{x}", String.valueOf(x)) .replace("{y}", String.valueOf(y)) .replace("{z}", String.valueOf(zoom)); try { return new URL(sUrl); } catch (Exception e) { return null; } } }); // 添加到地图 GoogleMap googleMap = ... // 初始化 Google 地图 googleMap.addTileOverlay(tileOverlayOptions); ``` 3. **服务 URL 示例** | 服务类型 | URL 模板 | |---|---| | 矢量地图 | `https://services.arcgisonline.com/arcgis/rest/services/World_Street_Map/MapServer/tile/{z}/{y}/{x}` | | 影像地图 | `https://server.arcgisonline.com/arcgis/rest/services/World_Imagery/MapServer/tile/{z}/{y}/{x}` | --- ### 关键注意事项 1. **WebView 方案** - 需启用 JavaScript:`webView.getSettings().setJavaScriptEnabled(true)` - 网络权限必须声明:`<uses-permission android:name="android.permission.INTERNET" />`[^2][^3] 2. **瓦片服务方案** - 坐标系需匹配(ArcGIS 常用 `EPSG:3857`) - 需处理密钥认证(如天地图服务) - 缩放级别需服务层级对齐 两种方案均无需 `com.esri.arcgisruntime.mapping.view.MapView`,可根据项目需求选择: - **推荐 WebView 方案**:功能完整,维护成本低 - **瓦片服务方案**:适合轻量级集成,需自定义坐标转换 ---
评论 4
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

虾神说D

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值