일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
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 |
- Algorithm
- 코틀린
- AppBarLayout
- CollapsingToolbarLayout
- CustomView
- Navigation
- Behavior
- View
- CoordinatorLayout
- 알림
- sqlite
- kotlin
- 알고리즘
- activity
- Android
- DataBinding
- room
- 안드로이드
- lifecycle
- BOJ
- hilt
- ViewModel
- notification
- HTTP
- LiveData
- onLayout
- onMeasure
- Coroutine
- 백준
- recyclerview
- Today
- Total
목록안드로이드 (95)
개발일지
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..
![](http://i1.daumcdn.net/thumb/C150x150/?fname=https://blog.kakaocdn.net/dn/bz9CvE/btqS9YIqEjU/xX4jwtvi3xutNufaw7kLw0/img.png)
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 ..
![](http://i1.daumcdn.net/thumb/C150x150/?fname=https://blog.kakaocdn.net/dn/bqog8T/btqS1UN50CA/3SCsgIEf2mRDOXj5zQkwz0/img.gif)
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..
![](http://i1.daumcdn.net/thumb/C150x150/?fname=https://blog.kakaocdn.net/dn/bh5qBT/btqS9ZUCtVy/uuxPptwbNrMLJ5ZSuKtBtk/img.png)
Layout Manager RecyclerView에 Layout을 관리하는 클래스이다. 종류 LinearLayoutManager : 수평, 수직으로 ViewHolder를 표현한다. GridLayoutManager : 격자판 형식으로 ViewHolder를 표현한다. StaggeredGridLayoutManager : 높이가 불규칙한 격자판 형식으로 ViewHolder를 표현한다. FlexBoxLayoutManager : 반응형으로 ViewHolder를 표현한다. LinearLayoutManager Programming recyclerview.layoutManager = LinearLayoutManager(context) // 수직 recyclerview.layoutManager = LinearLayoutM..
![](http://i1.daumcdn.net/thumb/C150x150/?fname=https://blog.kakaocdn.net/dn/b8iPnD/btqSZxL4l83/jxfpJnmQaVlRy77GNaOwS0/img.png)
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은 View의 Visible상태가 GONE인 것은 생략하기 때문에 FloatingActionButton을 그냥 hide로 숨기면 그 다음부터 상태전달을 생략한다. (hide는 View의 Visible을 GONE으로 만들기 때문) => hide에 재정의한 리스너를 달아주자!! override fun onNestedScroll(coordinatorLayout: CoordinatorLayout, child: FloatingActionButton, target: View, dxConsumed: Int, dyConsumed: Int, dxUnconsumed: Int, dyUnconsumed: Int, type: Int, consumed: IntArray) { super.onNeste..