일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
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 | 31 |
- hilt
- CollapsingToolbarLayout
- LiveData
- onLayout
- View
- CoordinatorLayout
- Algorithm
- sqlite
- DataBinding
- kotlin
- lifecycle
- room
- 알고리즘
- 알림
- 안드로이드
- Coroutine
- 코틀린
- HTTP
- activity
- ViewModel
- Navigation
- Behavior
- BOJ
- recyclerview
- onMeasure
- 백준
- Android
- AppBarLayout
- CustomView
- notification
- Today
- Total
목록recyclerview (15)
개발일지
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..

ItemDecoration RecyclerView의 ViewHolder를 꾸미는 역할을 한다. ViewHolder간의 동일한 여백을 주거나, 구분선을 넣기, RecyclerView Background 이미지 주기 등 다양한 효과를 줄 수 있다. GridSpacingItemDecoration 여백을 주는 ItemDecoration이다. class GridSpacingItemDecoration(private val spanCount: Int, private val spacing: Int, private val includeEdge: Boolean = true) : RecyclerView.ItemDecoration() { override fun getItemOffsets(outRect: Rect, view: ..
AdapterDataObserver RecyclerView.Adapter에서 notifyItem~ 함수를 사용할 때 콜백을 받을 수 있는 Observer이다. private val adapterDataObserver = object : RecyclerView.AdapterDataObserver() { override fun onChanged() { super.onChanged() Log.d("PASS", "onChanged") } override fun onItemRangeChanged(positionStart: Int, itemCount: Int) { super.onItemRangeChanged(positionStart, itemCount) Log.d("PASS", "onItemRangeChanged ..

ItemTouchHelper OnDragListener, GestureDetectors 등을 활요한 View에 다양한 제스처를 반응할 수 있지만 매우 복잡하다는 단점을 가지고 있다. RecyclerView에서는 쉽고 간편하게 제스처에 반응할 수 있도록 ItemTouchHelper를 제공한다. ItemTouchHelper.SimpleCallback ItemTouchHelper(object : ItemTouchHelper.SimpleCallback(ItemTouchHelper.UP or ItemTouchHelper.DOWN, ItemTouchHelper.LEFT or ItemTouchHelper.RIGHT) { override fun onMove(recyclerView: RecyclerView, viewHo..

Layout Manager RecyclerView에 Layout을 관리하는 클래스이다. 종류 LinearLayoutManager : 수평, 수직으로 ViewHolder를 표현한다. GridLayoutManager : 격자판 형식으로 ViewHolder를 표현한다. StaggeredGridLayoutManager : 높이가 불규칙한 격자판 형식으로 ViewHolder를 표현한다. FlexBoxLayoutManager : 반응형으로 ViewHolder를 표현한다. LinearLayoutManager Programming recyclerview.layoutManager = LinearLayoutManager(context) // 수직 recyclerview.layoutManager = LinearLayoutM..

RecyclerView 제한된 화면에 여러가지 데이터를 리스트 형식으로 표현하는 뷰이다. ListView보다 성능이 좋으며 다양한 LayoutManager를 제공하므로 다양한 형식의 리스트로 데이터를 표현할 수 있다. 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" } 장점 DataBinding과 MVVM 패턴을 활용하여 다양한 데이터의 형식..
CoordinatorLayout자식뷰들의 상호작용을 도와준다. 보통 자식뷰에 Behaviors를 지정하여 스크롤시 효과를 주기도 한다. ScrollView는 Behaviros를 못주지만 NestedScrollView와 RecyclerView는 줄 수 있다. 만약 CoordinatorLayoutAppbarLayout RecyclerView구조에서 RecyclerView에게 Behaviors를 주지 않는 경우 AppbarLayout에 RecyclerView가 겹쳐서 안보이고 상호작용을 할 수 없다. 해결코드