Google Play Service에서 제공하는 Location 라이브러리로 위치 정보를 가져올 수 있습니다.
이 글에서는 간단한 샘플 코드를 소개합니다.
Android Developer에서 제공하는 문서들을 보시면 더 자세한 사용 방법을 얻을 수 있습니다.
Android Framework의 LocationManager를 이용해서 위치 정보를 가져올 수도 있습니다.
의존성 설정
App의 build.gradle
의 dependencies에 다음과 같이 play-services-location
를 추가하면 Location 라이브러리를 사용할 수 있습니다.
dependencies {
...
implementation 'com.google.android.gms:play-services-location:17.1.0'
}
Location 퍼미션
위치 정보를 얻으려면 다음 퍼미션 중 하나는 AndroidManifest에 정의해야 합니다.
<uses-permission android:name="android.permission.ACCESS_FINE_LOCATION" />
<uses-permission android:name="android.permission.ACCESS_COARSE_LOCATION" />
ACCESS_COARSE_LOCATION
: 도시 Block 단위의 정밀도의 위치 정보를 얻을 수 있습니다.ACCESS_FINE_LOCATION
:ACCESS_COARSE_LOCATION
보다 더 정밀한 위치 정보를 얻을 수 있습니다.
Runtime Permission 요청에 대한 자세한 구현은 Android - Runtime permission 요청 방법을 참고해주세요.
마지막으로 확인된 위치 정보 얻기
FusedLocationProviderClient 객체는 다음과 같이 얻을 수 있습니다.
val fusedLocationClient: FusedLocationProviderClient!
= LocationServices.getFusedLocationProviderClient(this)
FusedLocationProviderClient에서 마지막에 저장된 위치 정보를 가져올 수 있습니다.
fusedLocationClient.lastLocation.addOnSuccessListener { location : Location? ->
if (location != null) {
val latitude = location.latitude
val longitude = location.longitude
Log.d("Test", "GPS Location Latitude: $latitude" +
", Longitude: $longitude")
}
}
LocationService는 위치 정보를 캐시하며, lastLocation.addOnSuccessListener()
으로 마지막에 캐시된 위치 정보를 가져옵니다.
다음과 같은 경우에 null이 리턴될 수 있습니다.
- 디바이스의 Location 사용이 중지되는 경우 캐시 정보가 삭제되기 때문에 null이 리턴될 수 있습니다.
- 위치 정보를 얻은 적이 없을 때 null이 리턴될 수 있습니다.
- Google Play 서비스가 재실행되었을 때, 저장된 위치 정보가 없기 때문에 null이 리턴될 수 있습니다.
위치 정보 변경에 대한 이벤트 받기
다음과 같이 위치 정보가 업데이트될 때마다 이벤트를 받을 수 있습니다.
먼저 업데이트 Interval 등의 옵션이 저장된 LocationRequest와 LocationCallback을 생성하고 requestLocationUpdates()
으로 변경사항에 대한 Callback을 요청할 수 있습니다.
val locationRequest = LocationRequest.create()
locationRequest.priority = LocationRequest.PRIORITY_HIGH_ACCURACY
locationRequest.interval = 20 * 1000
fusedLocationClient.requestLocationUpdates(locationRequest,
locationCallback,
Looper.getMainLooper());
val locationCallback = object : LocationCallback() {
override fun onLocationResult(locationResult: LocationResult) {
if (locationResult == null) {
return
}
for (location in locationResult.locations) {
if (location != null) {
val latitude = location.latitude
val longitude = location.longitude
Log.d("Test", "GPS Location changed, Latitude: $latitude" +
", Longitude: $longitude")
}
}
}
}
Callback 등록 해제
더 이상 위치 정보를 받을 필요가 없다면 다음과 같이 서비스에 등록된 Callback을 해제할 수 있습니다.
fusedLocationClient.removeLocationUpdates(locationCallback);
참고
Related Posts
- Android 14 - 사진/동영상 파일, 일부 접근 권한 소개
- Android - adb push, pull로 파일 복사, 다운로드
- Android 14 - 암시적 인텐트 변경사항 및 문제 해결
- Jetpack Compose - Row와 Column
- Android 13, AOSP 오픈소스 다운로드 및 빌드
- Android 13 - 세분화된 미디어 파일 권한
- Android 13에서 Notification 권한 요청, 알림 띄우기
- Android 13에서 'Access blocked: ComponentInfo' 에러 해결
- 에러 해결: android gradle plugin requires java 11 to run. you are currently using java 1.8.
- 안드로이드 - 코루틴과 Retrofit으로 비동기 통신 예제
- 안드로이드 - 코루틴으로 URL 이미지 불러오기
- Android - 진동, Vibrator, VibrationEffect 예제
- Some problems were found with the configuration of task 에러 수정
- Query method parameters should either be a type that can be converted into a database column or a List
- 우분투에서 Android 12 오픈소스 다운로드 및 빌드
- Android - ViewModel을 생성하는 방법
- Android - Transformations.map(), switchMap() 차이점
- Android - Transformations.distinctUntilChanged() 소개
- Android - TabLayout 구현 방법 (+ ViewPager2)
- Android - 휴대폰 전화번호 가져오는 방법
- Android 12 - Splash Screens 알아보기
- Android 12 - Incremental Install (Play as you Download) 소개
- Android - adb 명령어로 bugreport 로그 파일 추출
- Android - adb 명령어로 App 데이터 삭제
- Android - adb 명령어로 앱 비활성화, 활성화
- Android - adb 명령어로 특정 패키지의 PID 찾기
- Android - adb 명령어로 퍼미션 Grant 또는 Revoke
- Android - adb 명령어로 apk 설치, 삭제
- Android - adb 명령어로 특정 패키지의 프로세스 종료
- Android - adb 명령어로 screen capture 저장
- Android - adb 명령어로 System 앱 삭제, 설치
- Android - adb 명령어로 settings value 확인, 변경
- Android 12 - IntentFilter의 exported 명시적 선언
- Android - adb 명령어로 공장초기화(Factory reset)
- Android - adb logcat 명령어로 로그 출력