이 라이브러리는 Jetpack Compose에서 사용할 수 있는 네이버 지도 API를 제공합니다.
이 저장소에는 샘플 앱이 포함되어 있습니다. 실행하려면 다음을 수행해야 합니다.
- NAVER Map Android SDK Demo 레포지터리의 How To Run을 참고하여, 클라이언트 ID를 발급받습니다.
client_id.xml
의naver_map_sdk_client_id
에 발급받은 클라이언트 ID를 입력합니다.- 빌드하고 실행합니다.
Compose 1.1 (1.1.x) | |
Compose 1.2 (1.2.x) | |
Compose 1.3 (1.3.x) | |
Compose 1.4 (1.4.x) | |
Compose 1.5 (1.5.x) | |
Compose 1.6 (1.6.x) | |
Compose 1.7 (1.7.x) | |
Compose 1.8 (1.8.x) |
play-services-location 16.0.0 ~ | |
play-services-location 18.0.0 ~ | |
play-services-location 21.0.1 ~ |
repositories {
mavenCentral()
}
dependencies {
implementation 'io.github.fornewid:naver-map-compose:<version>'
// (Optional) 위치 추적하기
// 다른 버전의 play-services-location 과 함께 사용하려면 선언해야 합니다.
// 선언하지 않았을 때, 기본으로 포함되는 play-services-location 버전은 16.0.0 입니다.
implementation 'io.github.fornewid:naver-map-location:<version>'
}
이 라이브러리는 내부적으로 네이버 지도 SDK를 사용하고 있습니다.
이에 따라오는 몇 가지 주의사항이 있습니다. (참고: 네이버 지도 안드로이드 SDK - 시작하기 - 의존성 추가)
- 네이버 지도 SDK는 https://repository.map.naver.com/archive/maven Maven 저장소에서 배포됩니다.
따라서 루트 프로젝트의
build.gradle
에 저장소 설정을 추가해야 합니다.
allprojects {
repositories {
google()
mavenCentral()
+ maven {
+ url 'https://repository.map.naver.com/archive/maven'
+ }
// naver-map-compose 1.5.6 버전까지는 다른 Maven 저장소 주소를 사용해야 합니다.
// maven { url 'https://naver.jfrog.io/artifactory/maven/' }
}
}
- 예전 네이버 지도 SDK는 appcompat-v7 28 버전을 사용합니다.
naver-map-compose 1.5.6 버전까지는,
gradle.properties
에 Jetifier 옵션을 추가해줘야 합니다. naver-map-compose 1.5.7 버전부터는 필요하지 않습니다.
android.useAndroidX=true
android.enableJetifier=true
- 네이버 지도 SDK는 위치 추적기능을 지원하려고, play-services-location 라이브러리 16.0.0 버전을 사용합니다. 이 버전보다 높은 버전을 사용하고 있으면, 컴파일 혹은 런타임에 오류가 발생할 수 있습니다. 이 때는 play-services-location 라이브러리 버전과 같은 naver-map-location 라이브러리를 추가로 선언해야 합니다.
dependencies {
implementation 'io.github.fornewid:naver-map-compose:<version>'
implementation 'com.google.android.gms:play-services-location:21.0.1'
+ implementation 'io.github.fornewid:naver-map-location:21.0.2'
}
NaverMap(
modifier = Modifier.fillMaxSize()
)
지도는 MapProperties
와 MapUiSettings
객체를 NaverMap
composable에 전달하여 구성할 수 있습니다.
var mapProperties by remember {
mutableStateOf(
MapProperties(maxZoom = 10.0, minZoom = 5.0)
)
}
var mapUiSettings by remember {
mutableStateOf(
MapUiSettings(isLocationButtonEnabled = false)
)
}
Box(Modifier.fillMaxSize()) {
NaverMap(properties = mapProperties, uiSettings = mapUiSettings)
Column {
Button(onClick = {
mapProperties = mapProperties.copy(
isBuildingLayerGroupEnabled = !mapProperties.isBuildingLayerGroupEnabled
)
}) {
Text(text = "Toggle isBuildingLayerGroupEnabled")
}
Button(onClick = {
mapUiSettings = mapUiSettings.copy(
isLocationButtonEnabled = !mapUiSettings.isLocationButtonEnabled
)
}) {
Text(text = "Toggle isLocationButtonEnabled")
}
}
}
CameraPositionState
를 통해 카메라 변경을 관찰하고 제어할 수 있습니다.
val seoul = LatLng(37.532600, 127.024612)
val cameraPositionState: CameraPositionState = rememberCameraPositionState {
// 카메라 초기 위치를 설정합니다.
position = CameraPosition(seoul, 11.0)
}
Box(Modifier.fillMaxSize()) {
NaverMap(cameraPositionState = cameraPositionState)
Button(onClick = {
// 카메라를 새로운 줌 레벨로 이동합니다.
cameraPositionState.move(CameraUpdate.zoomIn())
}) {
Text(text = "Zoom In")
}
}
지도에 Marker
처럼 Overlay를 추가하려면, NaverMap
의 content에 child composable을 추가하면 됩니다.
NaverMap {
Marker(
state = MarkerState(position = LatLng(37.532600, 127.024612)),
captionText = "Marker in Seoul"
)
Marker(
state = MarkerState(position = LatLng(37.390791, 127.096306)),
captionText = "Marker in Pangyo"
)
}
제공되는 Overlay는 다음과 같습니다.
ArrowheadPathOverlay
CircleOverlay
GroundOverlay
LocationOverlay
Marker
MultipartPathOverlay
PathOverlay
PolygonOverlay
PolylineOverlay
특정 UseCase에서는 NaverMap
객체가 필요합니다.
예를 들어, 이 라이브러리에서 마커 클러스터링은 아직 지원되지 않지만(Issue #14 참조),
외부 라이브러리 를 이용하여 클러스터링을 구현할 수 있습니다.
이렇게 구현하려면 MapEffect
혹은 DisposableMapEffect
composable을 사용하여 네이버지도 SDK의 raw NaverMap
객체에 접근해야 합니다.
NaverMap(
// ...
) {
val context = LocalContext.current
var clusterManager by remember { mutableStateOf<TedNaverClustering<MyItem>?>(null) }
DisposableMapEffect(items) { map ->
if (clusterManager == null) {
clusterManager = TedNaverClustering.with<MyItem>(context, map).make()
}
clusterManager?.addItems(items)
onDispose {
clusterManager?.clearItems()
}
}
}
⚠️ play-services-location
버전이 16.0.0 보다 높으면, 컴파일 혹은 런타임에 오류가 발생할 수 있습니다. (Warnings 섹션을 참고하세요.)
구글에서 제공하는 FusedLocationProviderClient을 이용하여, 위치를 추적하는 기능을 제공합니다.
MapProperties
의 locationTrackingMode
를 설정하여 위치 추적 모드를 지정할 수 있습니다.
NaverMap(
locationSource = rememberFusedLocationSource(),
properties = MapProperties(
locationTrackingMode = LocationTrackingMode.Follow,
),
uiSettings = MapUiSettings(
isLocationButtonEnabled = true,
)
)
LocationTrackingMode
가 Follow
또는 Face
일 때, 나침반 기능을 활성화하려면 isCompassEnabled
을 true로 설정해야 합니다.
NaverMap(
locationSource = rememberFusedLocationSource(isCompassEnabled = true),
properties = MapProperties(
locationTrackingMode = LocationTrackingMode.Face,
),
uiSettings = MapUiSettings(
isLocationButtonEnabled = true,
)
)
현재 개발 중인 버전을 확인하고 싶다면 SNAPSHOT 버전을 사용할 수 있습니다.
Snapshot은 main
branch에 커밋이 추가될 때마다 업데이트됩니다.
repositories {
maven { url 'https://s01.oss.sonatype.org/content/repositories/snapshots' }
}
dependencies {
// 위 링크에서 최신 SNAPSHOT 버전을 확인하세요.
classpath 'io.github.fornewid:naver-map-compose:XXX-SNAPSHOT'
}
- 오류를 발견하거나 궁금한 점이 있다면 이슈를 등록해주세요.
- 새로운 기능을 추가하고 싶다면 GitHub Issues를 통해 지원 가능 여부를 확인해야 합니다.
Copyright 2022 SOUP
Licensed to the Apache Software Foundation (ASF) under one or more contributor
license agreements. See the NOTICE file distributed with this work for
additional information regarding copyright ownership. The ASF licenses this
file to you under the Apache License, Version 2.0 (the "License"); you may not
use this file except in compliance with the License. You may obtain a copy of
the License at
http://www.apache.org/licenses/LICENSE-2.0
Unless required by applicable law or agreed to in writing, software
distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the
License for the specific language governing permissions and limitations under
the License.