Notice
일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
1 | 2 | |||||
3 | 4 | 5 | 6 | 7 | 8 | 9 |
10 | 11 | 12 | 13 | 14 | 15 | 16 |
17 | 18 | 19 | 20 | 21 | 22 | 23 |
24 | 25 | 26 | 27 | 28 | 29 | 30 |
Tags
- 큐 자바 코드
- Rxjava Observable
- ar vr 차이
- 플러터 설치 2022
- 객체
- jvm이란
- 멤버변수
- 서비스 쓰레드 차이
- 안드로이드 유닛테스트란
- android ar 개발
- jvm 작동 원리
- 서비스 vs 쓰레드
- rxjava cold observable
- ANR이란
- 안드로이드 라이선스 종류
- 2022 플러터 설치
- android retrofit login
- 클래스
- 스택 큐 차이
- 안드로이드 os 구조
- 안드로이드 레트로핏 사용법
- 안드로이드 레트로핏 crud
- 2022 플러터 안드로이드 스튜디오
- 스택 자바 코드
- 자바 다형성
- 안드로이드 유닛 테스트 예시
- 안드로이드 라이선스
- rxjava hot observable
- 안드로이드 유닛 테스트
- rxjava disposable
Archives
- Today
- Total
나만을 위한 블로그
[Android] 현재 내 위치 가져오는 법 본문
728x90
반응형
※ 모든 코드는 예시 코드기 때문에 사용하려면 반드시 예외처리, 리팩토링 후 사용한다
libs.version.toml 파일에 라이브러리를 하나 추가하고 앱 gradle에 적용한다.
[versions]
playServicesLocation = "21.3.0"
[libraries]
play-services-location = { module = "com.google.android.gms:play-services-location", version.ref = "playServicesLocation" }
implementation(libs.play.services.location)
그리고 매니페스트에 권한을 추가한다.
<!-- Always include this permission -->
<uses-permission android:name="android.permission.ACCESS_COARSE_LOCATION" />
<!-- Include only if your app benefits from precise location access. -->
<uses-permission android:name="android.permission.ACCESS_FINE_LOCATION" />
액티비티 파일은 아래와 같이 작성한다.
import android.Manifest
import android.content.pm.PackageManager
import android.location.Geocoder
import android.location.Location
import android.os.Bundle
import androidx.activity.enableEdgeToEdge
import androidx.activity.result.contract.ActivityResultContracts
import androidx.appcompat.app.AppCompatActivity
import androidx.core.app.ActivityCompat
import androidx.core.view.ViewCompat
import androidx.core.view.WindowInsetsCompat
import com.example.locationtestapp.databinding.ActivityMainBinding
import com.google.android.gms.location.FusedLocationProviderClient
import com.google.android.gms.location.LocationServices
import java.util.Locale
class MainActivity : AppCompatActivity() {
private lateinit var fusedLocationClient: FusedLocationProviderClient
private lateinit var binding: ActivityMainBinding
private val requestPermissionLauncher =
registerForActivityResult(ActivityResultContracts.RequestPermission()) { isGranted: Boolean ->
if (isGranted) {
getCurrentLocation()
}
}
override fun onCreate(savedInstanceState: Bundle?) {
super.onCreate(savedInstanceState)
binding = ActivityMainBinding.inflate(layoutInflater)
setContentView(binding.root)
enableEdgeToEdge()
ViewCompat.setOnApplyWindowInsetsListener(binding.main) { v, insets ->
val systemBars = insets.getInsets(WindowInsetsCompat.Type.systemBars())
v.setPadding(systemBars.left, systemBars.top, systemBars.right, systemBars.bottom)
insets
}
fusedLocationClient = LocationServices.getFusedLocationProviderClient(this)
requestLocationPermission()
}
private fun requestLocationPermission() {
if (ActivityCompat.checkSelfPermission(
this,
Manifest.permission.ACCESS_FINE_LOCATION
) != PackageManager.PERMISSION_GRANTED
) {
requestPermissionLauncher.launch(Manifest.permission.ACCESS_FINE_LOCATION)
} else {
getCurrentLocation()
}
}
private fun getCurrentLocation() {
if (ActivityCompat.checkSelfPermission(
this,
Manifest.permission.ACCESS_FINE_LOCATION
) == PackageManager.PERMISSION_GRANTED
) {
fusedLocationClient.lastLocation.addOnSuccessListener { location: Location? ->
location?.let {
val latitude = it.latitude
val longitude = it.longitude
binding.tvLocation.text = getAddressFromLocation(latitude, longitude)
}
}
}
}
private fun getAddressFromLocation(latitude: Double, longitude: Double): String {
val geocoder = Geocoder(this, Locale.getDefault())
val addresses = geocoder.getFromLocation(latitude, longitude, 1)
if (!addresses.isNullOrEmpty()) {
val address = addresses[0]
val city = address.adminArea // OO시
val district = address.subLocality // OO구
val neighborhood = address.thoroughfare // OO동
return "$city $district $neighborhood"
} else {
return "something is wrong!"
}
}
}
이렇게 하면 getAddressFromLocation()의 리턴값으로 OO시 OO구 OO동이라는 문자열을 받게 된다. 얻은 문자열은 추가로 가공하거나 어딘가에 표시해서 사용하면 된다.
글 시작에 적어뒀듯 예시 코드기 때문에 사용하려면 반드시 필요한 예외처리와 리팩토링 후 사용하길 권장한다.
반응형
'Android' 카테고리의 다른 글
[Android] 초기 데이터 로드 2 : 의문점 해소하기 (0) | 2024.10.13 |
---|---|
[Android] 단위 테스트 시 Stub, Mock, Fake, Spy 선택 기준 (0) | 2024.10.11 |
[Android] 경쟁 상태(Race Condition)란? (0) | 2024.09.29 |
[Android] 초기 데이터 로드 : LaunchedEffect vs ViewModel (0) | 2024.09.23 |
[Android] BuildConfig를 찾을 수 없는 경우 해결법 (0) | 2024.09.16 |
Comments