Application Service > Maps > AndroidマップSDKガイド

Androidプラットフォームでinaviマップを使用するためのプロジェクト基本設定方法を説明します。

事前準備

  • inaviマップを使用するには、認証用のAppkeyが必要です。

サービス有効化

  • NHN Cloud Consoleでサービスを選択してApplication Service > Mapsをクリックします

Appkey確認

  • Appkeyは、NHN Cloud Console上部のURL & Appkeyメニューで確認できます。

Project環境構成

inaviマップSDKを使用するには、次のようにプロジェクトおよびアプリモジュールレベルのbuild.gradleファイルに保存場所の設定とinaviマップSDKに対する依存性を追加します。

SDK 0.10.0以降のバージョンから新しいマップ保存場所へ配布されます。以前のマップ保存場所を利用している場合、マップ保存場所を変更する必要があります。 - 従来 - https://inavisystems.jfrog.io/artifactory/maps/ - 新規 - https://repo.inavi.com/artifactory/maps

/* Root Project build.gradle */

allprojects {
    repositories {
        google()
        ...
        // inaviマップ保存場所
        maven {
            url 'https://repo.inavi.com/artifactory/maps'
        }
    }
}
/* App Module build.gradle */

dependencies {
    implementation 'com.inavi.mapsdk:inavi-maps-sdk:0.10.0'
}

Appkey設定

発行したAppkeyを設定する方法は下記のとおりです。

Appkeyが設定されていない場合、マップ初期化段階で認証エラーが発生します。

1. AndroidManifest.xmlで設定

AndroidManifest.xml<meta-data>を追加してAppkeyを設定できます。

<!-- AndroidManifext.xml -->

<manifest>
    <application>
        <meta-data
            android:name="com.inavi.mapsdk.AppKey"
            android:value="YOUR_APP_KEY" />
    </application>
</manifest>

2. InaviMapSdk APIを呼び出して設定

Application作成時点で動的に[InaviMapSdk]シングルトンオブジェクトの関数を呼び出してAppkeyを設定できます。

// Kotlin
InaviMapSdk.getInstance(context).appKey = "YOUR_APP_KEY"

認証失敗

マップ初期化段階で認証に失敗した場合、SDK内部に登録されたCallbackでエラーコードとメッセージを伝達します。 失敗のCallbackを受けるには[InaviMapSdk]シングルトンオブジェクトに[AuthFailureCallback]を下記のように設定する必要があります。

// Kotlin
InaviMapSdk.getInstance(context).authFailureCallback =
    InaviMapSdk.AuthFailureCallback { errCode: Int, msg: String ->
        // 認証失敗処理
}

認証失敗Callbackを別途設定していない場合は、エラーコードとメッセージがポップアップ表示されます。

認証エラーコード

Code Description
300 Appkeyが無効
401 Appkeyが未設定
503 サーバー接続失敗
504 サーバー接続時間超過
500 不明なエラー
その他 サーバーエラー(今後定義したらアップデート)

マップを作成する

アプリ画面にinaviマップを表示する方法を説明します。

マップ表示

アクティビティレイアウトファイルに下記のように<fragment>タグを追加して[InvMapFragment]を定義するとマップを表示できます。

<fragment
    android:id="@+id/map_fragment"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    android:name="com.inavi.mapsdk.maps.InvMapFragment" />

マップオブジェクトにアクセス

マップに関するすべての操作は[InaviMap]オブジェクトを通して行われます。 [InaviMap]オブジェクトにアクセスするには、まず[InvMapFragment]オブジェクトのgetMapAsync()関数を呼び出す必要があります。 マップの初期化が完了したら、onMapReady()コールバック関数を通して[InaviMap]オブジェクトが伝達されます。

// Kotlin
val mapFragment = supportFragmentManager.findFragmentById(R.id.map_fragment) as InvMapFragment
mapFragment.getMapAsync(object : OnMapReadyCallback {
    override fun onMapReady(inaviMap: InaviMap) {
        // InaviMapオブジェクトアクセス可能
    }
})

マップイベント設定

マップクリック、ダブルクリック、長押しなど、マップとユーザー間のインタラクションに対するイベントを設定できます。


inaviMap.setOnMapClickListener { pointF, latLng ->
    // pointF:クリックした地点の画面上の座標
    // latLng:クリックした地点のマップ上の座標
    Toast.makeText(context, "マップクリック", Toast.LENGTH_SHORT).show()
}

マーカー表示

マーカーオブジェクトを作成し、positionプロパティとmapプロパティを設定すると、マーカーが表示されます。

// Kotlin
val marker = InvMarker().apply {
    position = LatLng(37.40219, 127.11077)
    title = "タイトル"
    map = inaviMap
}

マーカー削除

マーカーオブジェクトのmapプロパティをnullに設定すると、マーカーが削除されます。

// Kotlin
marker.map = null

カメラ移動

[CameraUpdate]のFactory Methodまたは[CameraUpdateBuilder]を通して[CameraUpdate]オブジェクトを作成した後 moveCamera()関数にパラメータを伝達して呼び出すと、カメラが移動します。

アニメーションとカメライベントに対するコールバックをサポートするため、カメラ移動を自由に実装できます。

// Kotlin
val cameraUpdate = CameraUpdate.targetTo(LatLng(36.99473, 127.81832))
cameraUpdate.setAnimationType(CameraAnimationType.Fly, 3000)
inaviMap.moveCamera(cameraUpdate)

自分だけのマップスタイルの作成

Map Studioサービスを利用すると、フォントはもちろん、マップの色、凡例アイコンまで自由に変更して自分だけの特別なマップを作成できます。また最新バージョンのSDKで提供するAPIを利用すると、カスタムスタイルをマップに適用できます。

// Kotlin
InaviMapSdk.getInstance(this).authSuccessCallback = object: InaviMapSdk.AuthSuccessCallback{
    override fun onAuthSuccess(mapStyleList: MutableList<MapStyle>) {
        // マップ初期化認証が完了すると、マップスタイルリストをコールバックに渡す
    }
}
// 保存されたカスタムスタイルリストの最初のカスタムスタイルをマップに適用
inaviMap.customMapStyle = InaviMapSdk.getInstance(context).savedCustomMapStyles.firstOrNull()

主要iNavi Maps SDK案内

Maps SDKの使用方法はiNavi Maps APIセンターを参照してください。

[InaviMapSdk] : https://inavi-systems.github.io/inavi-maps-sdk-reference/android/com/inavi/mapsdk/maps/InaviMapSdk.html [InaviMap] : https://inavi-systems.github.io/inavi-maps-sdk-reference/android/com/inavi/mapsdk/maps/InaviMap.html [InvMapView] : https://inavi-systems.github.io/inavi-maps-sdk-reference/android/com/inavi/mapsdk/maps/InvMapView.html [InvMapFragment] : https://inavi-systems.github.io/inavi-maps-sdk-reference/android/com/inavi/mapsdk/maps/InvMapFragment.html [AuthFailureCallback] : https://inavi-systems.github.io/inavi-maps-sdk-reference/android/com/inavi/mapsdk/maps/InaviMapSdk.AuthFailureCallback.html [CameraUpdate] : https://inavi-systems.github.io/inavi-maps-sdk-reference/android/com/inavi/mapsdk/maps/CameraUpdate.html [CameraUpdateBuilder] : https://inavi-systems.github.io/inavi-maps-sdk-reference/android/com/inavi/mapsdk/maps/CameraUpdateBuilder.html

[NHN Cloud Console] : https://console.toast.com/

TOP