1. 概要
HMS Map KitはHMSの地図サービスであり、現時点では以下の5つのサービスを提供しています。
現時点では、どのSDK/APIも無料で使えます。
今回はAndroid SDKの導入方法について説明したいと思います。
2. Map Kit Android SDKを使用する流れ
全体の流れは以下のようになります。
- 開発者アカウントの登録
- 開発者コンソール(AppGallery Connect)でプロジェクトを作成
- コンソールでプロジェクトの詳細を設定
- Androidプロジェクトに必要なファイルの導入、依頼関係の追加
- コーディング
次に各ステップについて詳細に説明します。
3. 詳細ステップ
3.1 開発者アカウントの登録
HMSのSDKを使用するには、Huawei開発者アカウントを取得する必要があります。
アカウントの申請には主に以下の2つのステップがあります。
- Huawei IDの取得(すてにHuawei IDをもっている人はこのステップが不要となります)
- 開発者認証
詳しいガイドは以下のサイト(英語)を参照してください。
Huawei ID申請ガイド:https://developer.huawei.com/consumer/en/doc/10104
開発者認証(個人の場合):https://developer.huawei.com/consumer/en/doc/10122
3.2 Appgallery Connectにてアプリプロジェクトの作成とプロジェクトの設定
3.2.1 プロジェクトの作成
AppGallery Connect(リンク)はHuaweiの開発者サイトです。
開発者サイトにログインしたら、最初は以下のページが表示されます。
このページから、AppGallery Connectをクリックしてコンソールに入ります。
クリックしたら以下のページが表示されます。
次に、Map appsをクリックしてアプリ管理画面に入ります。
My appsページの右上の「New app」をクリックして新しいプロジェクトを作成します。
「New apps」をクリックしたら次に下のページが表示されます。
このページでは、アプリの種類(APK:Androidアプリの場合、RPK:QuickAppの場合)、アプリ名やデフォルト言語を設定できます。
また、ここでは「Add to project」にチェックを入れる必要があります。
入力が完了したら、「OK」をクリックして作成が完了となります。
「OK」をクリックしたらアプリの詳細ページが表示されます。
次に、プロジェクトのAPI設定やFingerprint設定をする必要がありますので、左上のMy appsより、My projectsを選択してプロジェクトの詳細設定ページに入ります。
3.2.2 プロジェクトの設定
プロジェクト詳細ページでは、以下のようにアプリの詳細情報が表示されています。
まずは、Map APIを有効にする必要がありますので、Manage APIsをクリックします。
Manage APIsページで使用したいAPIを有効にします。今回はMap Kitを有効にしました。
次に、fingerprintを設定し、コンフィグファイル(agconnect-services.json)をダウンロードします。
以上の操作で、Map Kitを使用する準備が完了となります。
詳しいガイドは以下のサイト(英語)を参照してください。
https://developer.huawei.com/consumer/en/doc/development/HMS-Guides/hms-map-configuringinagc
3.3 Android Studioでの前準備(SDK導入)
3.3.1 コンフィグファイルの導入
先ほどダウンロードしたagconnect-services.jsonファイルをappフォルダに入れます。
このファイルは、アプリの認証情報が記載されたコンフィグファイルとなります。このファイルがないと、HMS SDKが機能しなくなる可能性が高いですのでかならずプロジェクトに導入してください
3.3.2 gradleファイルに依頼関係を追加
次に、gradleファイルに依頼関係を追加します。
まずはProjectのgradleに、以下のコメントの下の行を追加します。
buildscript {
repositories {
google()
jcenter()
//HMS Core SDKのMavenを追加します
maven {url 'https://developer.huawei.com/repo/'}
}
dependencies {
classpath "com.android.tools.build:gradle:4.1.0"
//agcpのclasspathを追加します
classpath 'com.huawei.agconnect:agcp:1.4.1.300'
}
}
allprojects {
repositories {
google()
jcenter()
//HMS Core SDKのMavenを追加します
maven {url 'https://developer.huawei.com/repo/'}
}
}
追加したら一度Syncし、次にappのgradleに以下のように依頼関係を追加します。
plugins {
id 'com.android.application'
//'com.android.application'の後に以下の行を追加します
id 'com.huawei.agconnect'
}
android {
compileSdkVersion 30
buildToolsVersion "30.0.2"
//signingConfigsを追加します
signingConfigs {
config {
storeFile file("Your_KeyStore")
storePassword "Your_Password"
keyAlias "Your_KeyAlias"
keyPassword "Your_Password"
v2SigningEnabled true
}
}
defaultConfig {
applicationId "com.example.mapdemoqiita"
//HMS Map Kitを使うには、minSdkVersionを19以上にする必要があります
minSdkVersion 21
targetSdkVersion 30
versionCode 1
versionName "1.0"
testInstrumentationRunner "androidx.test.runner.AndroidJUnitRunner"
}
buildTypes {
release {
minifyEnabled false
proguardFiles getDefaultProguardFile('proguard-android-optimize.txt'), 'proguard-rules.pro'
//signingConfigsを追加します
signingConfig signingConfigs.config
}
debug{
//signingConfigsを追加します
signingConfig signingConfigs.config
}
}
compileOptions {
sourceCompatibility JavaVersion.VERSION_1_8
targetCompatibility JavaVersion.VERSION_1_8
}
}
dependencies {
...
//HMS Map SDKを追加します。最新のバージョンは以下のリンクから確認できます。
//https://developer.huawei.com/consumer/en/doc/development/HMSCore-Guides-V5/android-sdk-version-change-history-0000001050156688-V5
implementation 'com.huawei.hms:maps:5.0.3.301'
}
完了したらSyncをクリックしてSDKの導入が完了となります。
詳しいガイドは以下のサイト(英語)を参照してください。
https://developer.huawei.com/consumer/en/doc/development/HMS-Guides/hms-map-integratingthehmssdk
3.4 コーディング
3.4.1 Permissionの追加
Map Kitを使用するにはManifestに以下のPermissionを追加する必要があります。
<!-- Map Kitを使うには以下のpermissionを追加する必要があります -->
<uses-permission android:name="android.permission.INTERNET"/>
<uses-permission android:name="android.permission.ACCESS_NETWORK_STATE"/>
<uses-permission android:name="com.huawei.appmarket.service.commondata.permission.GET_COMMON_DATA"/>
<!-- 現在位置を表示したい場合には以下のpermissionを追加する必要があります -->
<!-- <uses-permission android:name="android.permission.ACCESS_COARSE_LOCATION"/> -->
<!-- <uses-permission android:name="android.permission.ACCESS_FINE_LOCATION"/> -->
3.4.2 Mapの作成
現時点では、Map KitはMapFragmentとMapViewをサポートしています。
今回はMapFragmentを使って、Mapのinstanceを作成する方法を示します。
詳しいガイドは、Huawei Developerオフィシャルサイトから確認できます。
まずは、LayoutファイルにMapFragmentを追加します。
<?xml version="1.0" encoding="utf-8"?>
<androidx.constraintlayout.widget.ConstraintLayout xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:app="http://schemas.android.com/apk/res-auto"
xmlns:tools="http://schemas.android.com/tools"
android:layout_width="match_parent"
android:layout_height="match_parent"
tools:context=".MainActivity">
<!-- MapFragmentを追加します。 -->
<fragment
android:id="@+id/map_fragment"
class="com.huawei.hms.maps.SupportMapFragment"
android:layout_width="match_parent"
android:layout_height="match_parent"
/>
</androidx.constraintlayout.widget.ConstraintLayout>
次に、ActivityでMapのInstanceを作成します。
public class MainActivity extends AppCompatActivity implements OnMapReadyCallback {
HuaweiMap mMap;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
//MapFragmentをロードし、getMapAsyncでコールバックを設定します
SupportMapFragment supportMapFragment = (SupportMapFragment) getSupportFragmentManager().findFragmentById(R.id.map_fragment);
supportMapFragment.getMapAsync(this);
}
public void onMapReady(HuaweiMap huaweiMap) {
//ここでmapの詳細設定をすることができます
mMap = huaweiMap;
}
}
最後に、API Keyを設定します。
HMS Android Map SDK 5.0.0.300から、Mapをロードする前に、API Keyを設定する必要があるようになっていますので、以下のようにApplicationでAPI Keyを設定できます。
API Keyの設定については、こちらの記事も合わせて参考できます:HMS CoreのMap KitとSite KitにおけるAPI Keyの利用の注意点
public class MainApplication extends Application {
@Override
public void onCreate() {
super.onCreate();
//API Keyを設定します
MapsInitializer.setApiKey("YOUR_API_KEY");
}
}
これで実行すると、以下のようにHuawei Mapが表示されました。
より詳しい開発ガイドは以下のリンクより確認できます。
Creating a Map:https://developer.huawei.com/consumer/en/doc/development/HMS-Guides/hms-map-createmap
Interacting with a Map: https://developer.huawei.com/consumer/en/doc/development/HMS-Guides/hms-map-mapinteraction
Draring on a Map: https://developer.huawei.com/consumer/en/doc/development/HMS-Guides/hms-map-drawonthemap
4. トラブルシューティング
Mapが表示されない場合には、以下の項目を確認したらいいと思います。
- Map APIが有効になっているかどうか
- fingerprintは正しくコンソールに登録できているかどうか
- agconnect-services.jsonファイルはプロジェクトに導入しているかどうか
- Permissionは追加したかどうか
- API Keyが設定されているかどうか
5. その他リソース
APIリファレンス:https://developer.huawei.com/consumer/en/doc/development/HMS-References/hms-map-cameraupdate
サンプルコード:https://developer.huawei.com/consumer/en/doc/development/HMS-Examples/hms-map-v4-example