일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
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 |
- lifecycle
- Behavior
- Navigation
- notification
- CoordinatorLayout
- hilt
- 코틀린
- 백준
- onMeasure
- sqlite
- Android
- onLayout
- CollapsingToolbarLayout
- LiveData
- 알고리즘
- CustomView
- kotlin
- ViewModel
- BOJ
- activity
- 안드로이드
- View
- Coroutine
- HTTP
- Algorithm
- AppBarLayout
- DataBinding
- recyclerview
- room
- 알림
- Today
- Total
목록Programming (프로그래밍) (212)
개발일지
Location 안드로이드에서 GPS 센서를 활용하여 위치 정보를 얻거나, Data, Wifi, Bluetooth 등 네트워크를 통해서 위치 정보를 얻을 수 있다. 권한 설정 포그라운드 위치 : 위치 정보를 한번 또는 정해진 시간안에서만 수신할 때 (앱이 종료되면 수신 불가능) 백그라운드 위치 : 앱이 주기적으로 위치 정보를 수신할 때 (앱이 종료되도 수신) manifest Android 6(API 23)이상에서는 런타임으로 포그라운드 위치 정보를 요청해야 합니다. (그 이전 버전은 앱 설치시 권한 사용 알림) (위험권한 확인 : developer.android.com/reference/android/Manifest.permission) Android 10(API 29)이상에서는 런타임에서 백그라운드 위..
LiveData LiveData는 Data를 Observer 패턴으로 관찰하여 변화가 있을 때 업데이트하는 코드를 작성할 수 있다. 일반적인 Observer패턴과 다르게 LiveData는 Activity나 Fragment의 생명주기를 관찰하여 활동 상태(STARTED, RESUMED)일 때만 업데이트한다. dependency dependencies { def lifecycle_version = "2.2.0" // LiveData implementation "androidx.lifecycle:lifecycle-livedata-ktx:$lifecycle_version" } 장점 UI와 데이터 상태의 일치 보장 Observer패턴을 따르기 때문에 Observer코드에 UI를 변경하는 코드를 삽입하면 데이터와 ..
ViewModelProvider ViewModel을 사용할 때 ViewModel을 직접 생성하는 것이 아닌 ViewModelProvider를 통해서 ViewModel를 요청하게 된다. ViewModel을 직접 생성자를 통해 생성하면 ViewModel을 잘못하용 하는 것이다. ViewModel 생성과정 ViewModelProvider를 통해 ViewModel을 요청한다. ViewModelProvider생성자로 ViewModelStoreOwner(Activity, Fragment), ViewModelProvider.Factory를 넘겨받는다. ViewModelProvider는 ViewModelStoreOwner를 참조하여 ViewModelStore에 ViewModel을 요청한다. ViewModelStore에..
ConfigurationChange같은 상황으로 Activity가 onDestroy되고 재생성될 때 Fragment도 같이 재생성된다. 하지만 setRetainInstance(true)를 설정하면 onCreate, onDestory가 호출되지 않고 재사용된다.
ViewModel Android Jetpack의 구성요소이며 UI관련 데이터를 관리하도록 설계되었습니다. UI관련 Data를 Activity, Fragment와 분리시켜 관리하면서 많은 이점을 얻을 수 있습니다. 장점 Android에서 Activity와 Fragment의 수명주기를 관리하기 때문에 Android에서 UI 컨트롤러를 제거하거나 다시 만드는 경우 데이터가 삭제되지만 ViewModel은 독립된 수명주기를 가지기 떼문에 데이터를 유지할 수 있습니다. UI관련 Data를 비동기적인 호출로 받아올 때 메모리 누수를 신경쓰거나, 비동기 호출을 관리하는 코드가 필요하거나 UI 컨트롤러가 변경될 경우 이미 호출한 코드를 다시 호출해야하는 경우가 생길 수 있지만 ViewModel을 재사용하면서 이러한 불편..
CollapsingToolbarLayout이 CollapseMode인지 아닌지 Handling하기 binding.nestedScrollView.setOnScrollChangeListener { v, scrollX, scrollY, oldScrollX, oldScrollY -> if (scrollY >= binding.toolbar.height && oldScrollY = binding.toolbar.height){ Log.d("COORDINATOR", "EXPANDED") } } Floati..
CollapsingToolbarLayout FrameLayout을 상속받은 View로 AppBarLayout이 CoordinatorLayout의 Child View에서만 정상작동 하듯이 CollapsingToolbarLayout은 AppBarLayout의 Child View일 때 정상작동 한다. Toolbar 기본적으로 toolbarId 값을 정하여 CollapsingToolbar에 Toolbar를 알리지만 굳이 추가하지 않아도 내부적으로 Toolbar를 찾는다. app:toolbarId="@id/toolbar" Title 기본적으로 title을 정하지 않으면 Toolbar의 title을 가져온다. titleEnabled를 설정하면 CollapsingToolbar의 Title을 사용하고 설정하지 않으면 ..
AppBarLayout LinearLayout을 상속받은 View로 Orientation이 Vertical만 지원한다. (Horizontal 사용시 Exception발생) AppBarLayout은 CoordinatorLayout의 Child View일 때만 정상작동하며 Scroll시 효과를 줄 수 있다. app:layout_scrollFlags scroll : Scroll에 대한 반응을 주려면 무조건 줘야한다. noScroll : 기본값 어떠한 반응도 하지 않는다. enterAlways : 언제든지 Scroll을 내리면 AppBar가 사라지고, 언제든지 Scroll을 올리면 AppBar가 나타난다. enterAlwaysCollapsed : Scroll을 내리면 min_height만큼 남기고 AppBar가..