일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
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 |
- Behavior
- CollapsingToolbarLayout
- ViewModel
- BOJ
- notification
- room
- sqlite
- LiveData
- 안드로이드
- activity
- recyclerview
- 코틀린
- 알고리즘
- onLayout
- DataBinding
- lifecycle
- onMeasure
- 백준
- CustomView
- kotlin
- Android
- View
- Coroutine
- HTTP
- Algorithm
- AppBarLayout
- hilt
- Navigation
- 알림
- CoordinatorLayout
- Today
- Total
목록Android (111)
개발일지
![](http://i1.daumcdn.net/thumb/C150x150/?fname=https://blog.kakaocdn.net/dn/GmbfA/btqTLxRebDj/TXkornBOKJ1KswwRekhKQ0/img.png)
데이터 미리 채우기 상황에 따라 데이터베이스를 생성할 때 미리 데이터를 채워야 하는 경우나 데이터베이스를 Open할 때 데이터베이스를 조작해야하는 경우가 있다. 데이터베이스에 Callback을 제공하여 이러한 문제를 해결할 수 있다. AppDatabase 데이터베이스를 생성할 때 addCallback을 사용하여 Callback을 추가할 수 있다. @Database(entities = [Drawer::class, ToDo::class], version = 2, exportSchema = true) abstract class AppDatabase : RoomDatabase() { companion object { private var instance: AppDatabase? = null fun getInst..
![](http://i1.daumcdn.net/thumb/C150x150/?fname=https://blog.kakaocdn.net/dn/oZWW5/btqTF34Zc6y/jK3KieywNNcScupra4jpfk/img.png)
Room Room이란 SQLite를 쉽게 사용할 수 있도록 제공하는 추상레이어 라이브러리이다. Room을 사용하여 Android에 Database구현를 쉽고 빠르게 할 수 있다. Room은 기본적으로 LiveData, Optional, Cursor 등의 강력한 기능도 지원한다. dependency dependencies { def room_version = "2.2.5" implementation "androidx.room:room-runtime:$room_version" kapt "androidx.room:room-compiler:$room_version" // optional - Kotlin Extensions and Coroutines support for Room implementation "an..
![](http://i1.daumcdn.net/thumb/C150x150/?fname=https://blog.kakaocdn.net/dn/cG2m6Y/btqTvSinyj8/ptBpQi4sct88eHxuqWq6FK/img.png)
SelectionObserver Selection에 Observer을 통해 콜백 함수를 작성할 수 있다. Selection이 되면 Delete Option Menu가 생기는 예제이다. addObserver(object : SelectionTracker.SelectionObserver() { override fun onSelectionChanged() { super.onSelectionChanged() val tracker = this@apply if (tracker.hasSelection() && menu.findItem(MENU_DELETE) == null) { menu.add(Menu.NONE, MENU_DELETE, Menu.NONE, "Delete") .setIcon(R.drawable.ic_de..
![](http://i1.daumcdn.net/thumb/C150x150/?fname=https://blog.kakaocdn.net/dn/vJ3xt/btqTJSAAHdx/u9wHRoySwBgGqLZkAHNDoK/img.gif)
SelectionPredicate Select를 좀 더 디테일하게 설정할 수 있다.(하나만 선택, 여러개 선택, ViewHolder에 따른 조건적 선택) SelectionPredicates.createSelectAnything() : 아무거나 여러개 선택가능 SelectionPredicates.createSelectSingleAnything() : 아무거나 한개만 선택가능 SelectionTracker.SelectionPredicate를 상속받아서 구현 ViewHolder에 YES만 선택되게한 예제 class SelectionPredicate(private val recyclerView: RecyclerView) : SelectionTracker.SelectionPredicate() { override ..
![](http://i1.daumcdn.net/thumb/C150x150/?fname=https://blog.kakaocdn.net/dn/bIm2s7/btqTDctONgX/nrkS1I31jNVkHQFLYp8jl0/img.gif)
Selection Tracker RecyclerView에서 Item을 선택하는 기능을 제공한다. ex) 갤러리에서 사진 여러개 선택 Dependency dependencies { implementation "androidx.recyclerview:recyclerview:1.1.0" // For control over item selection of both touch and mouse driven selection implementation "androidx.recyclerview:recyclerview-selection:1.1.0-rc03" } 기본구조 RecyclerView에서 Select이 발생하면 Select된 ViewHolder의 Id를 Selection에 기록하고, onBindViewHolde..
![](http://i1.daumcdn.net/thumb/C150x150/?fname=https://blog.kakaocdn.net/dn/lXbHB/btqS9Zghgb7/YuklBErarix8OdIhHDrKuK/img.gif)
RecyclerView에서 Item변경 RecyclerView에서 Item변경은 Adapter에 notifyItem~ 함수를 호출하면, onBindViewHolder가 호출되어 Item을 변경한다. 하지만 이러한 구조는 특졍 조건을 주어 특정한 부분만 변경하기에는 어렵다 => 클릭을 했을 때 아이템 상태에 따른 에니메이션주기, View 변화주기 등 Payload 이러한 구조적 문제를 해결하기 위해 notifyItem~ 함수를 호출할 때 payload를 전달하여 특정 조건을 설정해 줄 수 있다. Adapter에서는 onBindViewHolder(holder, position, payloads)를 구현하여 payload에 따른 특정 부분을 변화시킬 수 있다. BaseHolder abstract class B..
setHasFixedSize RecyclerView가 고정된 사이즈를 가진다고 알려주는 함수이다. RecyclerView는 Item이 추가, 삭제, 변경되면 Size가 변경될 수 있는 View이다. 그렇기 때문에 RecyclerView는 내부적으로 Size를 측정하여 자신의 Size를 결정하고 이는 비용이 많이 드는 작업이다. => 고정된 Size를 가지는 RecyclerView일 경우 setHasFixedSize를 사용하면서 불필요한 리소스를 아낄 수 있다. => 특히 Item의 변경이 자주 일어나는 RecyclerView에서 효과를 많이 볼 수 있다. 적용 binding.recyclerView.setHasFixedSize(true)
setHasStableIds Adapter에 Item들이 고유한 ID값을 가진다고 Adapter에 설정하는 함수이다. setHasStableIds 설정을 통해 ViewHolder에 onBindViewHolder를 필요할 때만 호출하여 불필요한 리소스를 아낄 수 있다. ToDoAdapter setHasStableIds를 사용하면 getItemId를 구현해야한다. 또한 getItemId는 고유한 id를 리턴하도록 설정해야하며 중복된 id가 있을경우 Exception을 발생시킨다. class ToDoAdapter : BaseAdapter(ToDoItemCallback()) { init { setHasStableIds(true) } override fun onCreateViewHolder(parent: View..