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

CoordinatorLayout View간의 상호작용을 처리하기 위한 View이다. CoordinatorLayout이 Child View의 Behavior를 수신하여 다른 Child View에 Behavior를 전달한다. 각 Child View는 미리 정의된 Behavior를 사용하거나 새롭게 만든 Behavior를 사용하여 수신된 Behavior로 특정 작업을 수행할 수 있다. Scroll시 AppBarLayout 변경 SnackBar생성시 FloatingActionButton 위치 변경 Developer 정의 CoordinatorLayout is a super-powered FrameLayout. CoordinatorLayout is intended for two primary use cases: 1..
CoordinatorLayout에서 ViewPager를 사용할 경우 이상하게 작동하는 경우가 있다. (ex : ViewPager가 짤린다.) AppBarLayout과 같이 사용시 @string/appbar_scrolling_view_behavior를 behavior로 설정하자. => @string/appbar_scrolling_view_behavior는 Scroll이 가능한 View에 설정해야한다. (NestedScrollView, RecyclerView)
Fragment에서 ViewPagerAdapter를 Fragment 맴버 변수로 선언한 경우 navigation시 오류 발생 => onCreateView에 ViewPagerAdapter를 생성해서 사용하자

SnapHelper RecyclerView를 ViewPager처럼 사용하거나 NumberPicker처럼 Scroll하다가 하나의 Item을 자석처럼 끌어당겨 하나의 Item을 선택하게 도와주는 클래스이다. Kotlin val snapHelper = LinearSnapHelper() snapHelper.attachToRecyclerView(recyclerView) OnScrollListener를 사용해서 SnapHelper가 선택한 position 받기 recyclerView.addOnScrollListener(object : RecyclerView.OnScrollListener() { var currentPosition = RecyclerView.NO_POSITION override fun onScrol..

BindingAdapter Databinding을 사용하다 보면 기본적으로 제공하는 수식으로 표현 못하는 경우가 생긴다. (Glide를 사용한 ImageView 업데이트) BindingAdapter를 정의하면 해결할 수 있다. BindingAdapter object BindingAdapter { @JvmStatic @BindingAdapter(value = ["imageUrl", "error"], requireAll = false) fun loadImage(view: ImageView, url: String?, error: Drawable?) { Glide.with(view).load(url).error(error).into(view) } } @JvmStatic : Java에서도 호환을 도와주는 코드(J..

Databinding에서 제공하는 수식으로 XML에서 간단한 수식을 처리하여 Java나 Kotlin의 코드를 줄일 수 있고, 코드의 유지보수성을 높일 수 있습니다. import Java에서 import와 비슷한 의미로 변수를 선언할 때 사용한다. bind include를 사용하여 다른 layout을 포함할 때 다른 layout에 데이터를 결합하는 방법. => merge에서는 사용할 수 없다. default 데이터를 결합하기 전에 표시할 값을 선택한다. => Databinding을 사용하면 Design을 미리 볼 수 없는데 Design을 미리 볼 때도 사용할 수 있다. 문자열 리터럴 Databinding에서 문자열을 사용할 때 android:text='@{map["firstName"]}' android:t..

바인딩 객체 Databinding을 사용해서 Data를 결합하기 위해서는 DataBindingUtil이나 바인딩 클래스를 사용해서 바인딩 객체를 얻어야한다. Activity DataBindingUtil.setContentView를 사용해서 얻는다. abstract class BaseActivity(private val layoutId: Int) : AppCompatActivity() { protected lateinit var binding: VB override fun onCreate(savedInstanceState: Bundle?) { super.onCreate(savedInstanceState) init() } protected open fun init() { initViewDataBinding(..

Databinding Java나 Kotlin으로 View를 업데이트하는 방식이 아닌 XML에서 View를 업데이트 하는 방식이다. View를 업데이트하는 코드를 분리하면서 코드의 간결함과 유지보수성이 좋고 앱의 성능이 향상된다. build.gradle(module) plugins { ... id 'kotlin-kapt' } android { ... buildFeatures { dataBinding = true } } holder_movie 기본적으로 layout안에 data와 view를 넣는다. data안에는 XML에서 사용할 변수를 선언할 수 있다. variable로 변수를 선언하여 name으로 이름을 정하고 type으로 변수의 타입을 정한다. 선언한 변수를 사용하려면 @{}로 변수를 사용한다. 데이터..