用HMS Core地圖服務自定義地圖樣式,給你的應用製作專屬個性化地圖

来源:https://www.cnblogs.com/hmscore/archive/2022/05/30/16327718.html
-Advertisement-
Play Games

不同行業的開發者對地圖樣式的展示需求差異很大。例如,物流類應用希望地圖樣式簡潔一些,重點突出城市分佈和快遞路徑;AR游戲類應用中的地圖色彩需要和游戲UI適配,做的更酷炫一些;景區導覽應用中的地圖樣式要景區特色相結合,重點呈現關鍵景點。 自定義地圖樣式可以更好的迎合不同行業的開發者對於地圖樣式的展示需 ...


不同行業的開發者對地圖樣式的展示需求差異很大。例如,物流類應用希望地圖樣式簡潔一些,重點突出城市分佈和快遞路徑;AR游戲類應用中的地圖色彩需要和游戲UI適配,做的更酷炫一些;景區導覽應用中的地圖樣式要景區特色相結合,重點呈現關鍵景點。

自定義地圖樣式可以更好的迎合不同行業的開發者對於地圖樣式的展示需求,開發者可以綜合考慮自身產品的使用場景、品牌色調等因素,自由創建最適合的地圖樣式。

HMS Core地圖服務(Map Kit)提供了自定義地圖樣式能力,開發者可通過更改Petal Maps Studio中的樣式選項,自定義地圖樣式的顯示,更改道路、公園、企業和其他興趣點等功能的可視化顯示。提供七大類,上百種地圖元素的樣式編輯,讓開發者自由編輯個性化地圖。同時,開發者只需編輯一次,地圖即可適用於多種終端(Android/iOS/Web)極大的提高了開發效率

集成步驟

一、 生成樣式ID

1. 登錄Petal Maps Studio,點擊“Create map”創建自定義樣式。

2. 導入JSON樣式文件,點擊“Import”。

3. 在編輯器里修改樣式。

4. 點擊“SAVE”生成預覽ID,通過預覽ID測試樣式效果。點擊“PUBLISH”發佈生成樣式ID,樣式ID是唯一ID,一旦發佈生效不會變化。

二、 各平臺代碼實現步驟

地圖服務提供兩種方法設置自定義地圖樣式:

• 設置樣式文件:通過嵌入JSON樣式聲明文件手動定義地圖樣式的更改。

• 設置樣式ID:在Petal Maps Studio上創建新樣式,或導入現有樣式定義。樣式一旦發佈,使用此樣式的應用都會自動應用新樣式,不需要更新版本。

1. 第一種方法:設置樣式文件

新建樣式文件mapstyle_road.json
[
    {
        "mapFeature": "road.highway.city",
        "options": "all",
        "paint": {
            "color": "#7569ce"
        }
    },
    {
        "mapFeature": "road.highway.country",
        "options": "all",
        "paint": {
            "color": "#7271c6"
        }
    },
    {
        "mapFeature": "road.province",
        "options": "all",
        "paint": {
            "color": "#6c6ae2"
        }
    },
    {
        "mapFeature": "road.city-arterial",
        "options": "geometry.fill",
        "paint": {
            "color": "#be9bca"
        }
    },
    {
        "mapFeature": "transit.railway",
        "options": "all",
        "paint": {
            "color": "#b2e6b2"
        }
    }
]
1.1 Android設置樣式文件

(1)在res/raw目錄下添加JSON文件 mapstyle_road.json

(2)使用loadRawResourceStyle()方法,載入為MapStyleOptions對象,再將該對象傳遞給HuaweiMap.setMapStyle()方法。

private HuaweiMap hMap;
MapStyleOptions styleOptions = MapStyleOptions.loadRawResourceStyle(this, R.raw.mapstyle_road);
hMap.setMapStyle(styleOptions);
1.2 iOS設置樣式文件

(1)在工程目錄下定義一個JSON文件 mapstyle_road.json

(2)將文件路徑傳遞給setMapStyle方法

// 讀取樣式文件的路徑
NSString *path = [NSBundle.mainBundle pathForResource:name ofType:@"json"];
// 調用設置方法
[self.mapView setMapStyle:path];
1.3 JavaScript設置樣式文件
map.setStyle("mapstyle_road.json");

2.第二種方法:設置預覽ID或樣式ID

2.1 Android設置樣式ID

Android SDK提供兩種方式設置預覽ID或樣式ID:創建地圖前、創建地圖後。

(1)在創建地圖後使用自定義樣式。

通過調用HuaweiMap的setStyleId和previewId方法設置自定義樣式。

private HuaweiMap hMap;
String styleIdStr = edtStyleId.getText().toString();           //創建地圖後設置樣式ID
// String previewIdStr = edtPreviewId.getText().toString();   //在創建地圖後設置預覽ID
if (TextUtils.isEmpty(styleIdStr)) {
    Toast.makeText(this, "Please make sure the style ID is edited", Toast.LENGTH_SHORT).show();
    return;
}
if (null != hMap) {
    hMap.setStyleId("859320508888914176");
    //   hMap.previewId("888359570022864384");
}

(2)在創建地圖前改變現有樣式

通過調用HuaweiMapOptions的styleId和previewId方法設置自定義樣式,當同時設置styleId和previewId時,優先使用styleId。

FragmentManager fragmentManager = getSupportFragmentManager();
mSupportMapFragment = (SupportMapFragment) fragmentManager.findFragmentByTag("support_map_fragment");

if (mSupportMapFragment == null) {
    HuaweiMapOptions huaweiMapOptions = new HuaweiMapOptions();
    // please replace "styleId" with style ID field value in
    huaweiMapOptions.styleId("styleId");       //在創建地圖前設置樣式ID
    // please replace "previewId" with preview ID field value in
    huaweiMapOptions.previewId("previewId");    //在創建地圖前設置預覽ID
    mSupportMapFragment = SupportMapFragment.newInstance(huaweiMapOptions);
    FragmentTransaction fragmentTransaction = fragmentManager.beginTransaction();
    fragmentTransaction.add(R.id.map_container_layout, mSupportMapFragment, "support_map_fragment");
    fragmentTransaction.commit();
}

mSupportMapFragment.getMapAsync(this);
mSupportMapFragment.onAttach(this);
2.2 iOS SDK提供1種設置預覽ID或樣式ID的方式:創建地圖後。

在創建地圖後使用自定義樣式,請調用HMapView的setMapStyleID:和setMapPreviewID:方法設置。

/**
* @brief 改變底圖樣式
* @param styleID值為在官網配置的自定義樣式列表中ID
* @return 是否設置成功
*/
- (BOOL)setMapStyleID:(NSString*)styleID;
/**
* @brief 改變底圖樣式
* @param previewID值為在官網配置的自定義樣式列表中預覽ID
* @return 是否設置成功
*/
- (BOOL)setMapPreviewID:(NSString*)previewID;
2.3 JavaScript提供兩種方式設置預覽ID或樣式ID:地圖載入前、地圖載入後

(1)在首次載入地圖時使用指定自定義樣式

在創建地圖引入華為地圖API文件時,增加styleId或者previewId參數,當同時傳入styleId和previewId時,優先使用styleId。註意key要經過URL轉碼。

<script src="https://mapapi.cloud.huawei.com/mapjs/v1/api/js?callback=initMap&key=API KEY&styleId=styleId"></script>

(2)在載入地圖後改變現有樣式

// 設置樣式ID
map.setStyleId(String styleId)
// 設置預覽ID
map.setPreviewId(String previewId)

瞭解更多詳情>>

訪問地圖服務開發者聯盟官網

獲取地圖服務開髮指導文檔

訪問華為開發者聯盟官網
獲取開髮指導文檔
華為移動服務開源倉庫地址:GitHubGitee

關註我們,第一時間瞭解 HMS Core 最新技術資訊~


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • ClickHouse的由來 ClickHouse是什麼資料庫?ClickHouse速度有多快?應用場景是怎麼樣的?ClickHouse是關係型資料庫嗎?ClickHouse目前是很火爆的一款面向OLAP的數據,可以提供秒級的大數據查詢。 Google於2003~2006年相繼發表了三篇論文“Goog ...
  • - Jedis - 優點:以 Redis 命令作為方法名稱,學習成本低廉,簡單且實用 - 缺點:Jedis 的實例是線程不安全的,在多線程的環境下需要基於線程池來使用 - lettuce(spring 官方預設) - 基於 Netty 實現的,支持同步、非同步和響應式編程方式,並且是線程安... ...
  • redis是一個key-value存儲系統。和Memcached類似,它支持存儲的value類型相對更多,包括string(字元串)、list(鏈表)、set(集合)、zset(sorted set --有序集合)和hash(哈希類型)。這些數據類型都支持push/pop、add/remove及取交... ...
  • 一、初識HBase HBase 是一個面向列式存儲的分散式資料庫,其設計思想來源於 Google 的 BigTable 論文。HBase 底層存儲基於 HDFS 實現,集群的管理基於 ZooKeeper 實現。HBase 良好的分散式架構設計為海量數據的快速存儲、隨機訪問提供了可能,基於數據副本機制 ...
  • UniqueMergeTree 開發的業務背景 首先,我們看一下哪些場景需要用到實時更新。 我們總結了三類場景: 第一類是業務需要對它的交易類數據進行實時分析,需要把數據流同步到 ClickHouse 這類 OLAP 資料庫中。大家知道,業務數據諸如訂單數據天生是存在更新的,所以需要 OLAP 數據 ...
  • SELECT 查詢 101 Id Title Director Year Length_minutes 1 Toy Story John Lasseter 1995 81 2 A Bug's Life John Lasseter 1998 95 3 Toy Story 2 John Lasseter ...
  • 作者:王志斌 編輯:鐘華龍 本文來自社區小伙伴 王志斌 的投稿。從小白的角度,帶你一步步實現將 RadonDB PostgreSQL 集群部署到 Kubernetes 上。文章分為上下兩部分,第一部分將為大家演示如何搭建一套 Kubernetes 環境,包括詳細的配置調優等。 什麼是 RadonDB ...
  • mysqldump 和 mydumper 是我們常用的兩個邏輯備份工具。 無論是 mysqldump 還是 mydumper 都是將備份數據通過 INSERT 的方式寫入到備份文件中。 恢復時,myloader( mydumper 中的恢復工具 ) 是多線程導入,且一個 INSERT 語句中包含多條 ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...