androidでDataBinding + ViewModel + LiveDataを使ってみた
の続編
そういえばやろうと思っていて放置してた
DataBinding + ViewModel + LiveDataで双方向Bindingしてみた
・やりたいこと
前回の記事の通り変数更新したらlayout更新したい
さらにlayoutの変更されたら変数のデータが更新されるようにしたい
・コード
このコードだと
ボタンクリックするとtextView2とチェックボックスが更新される
さらにチェックボックスをUI上でいじるとtextView2の表示が更新される
layoutからでもkotlinからでもどちらからいじってもデータが変数に反映されるわけだ
MainActivity.kt
class MainActivity : AppCompatActivity() { override fun onCreate(savedInstanceState: Bundle?) { super.onCreate(savedInstanceState) val binding: ActivityMainBinding = DataBindingUtil.setContentView(this, R.layout.activity_main) val viewModel = ViewModelProviders.of(this).get(MainViewModel::class.java) binding.lifecycleOwner = this binding.viewModel = viewModel binding.button.setOnClickListener{ viewModel.isCheck.postValue(!binding.checkBox.isChecked) } } }
MainViewModel.kt
class MainViewModel : ViewModel() { val isCheck = MutableLiveData<Boolean>() }
activity_main.xml
<layout> <androidx.constraintlayout.widget.ConstraintLayout xmlns:android="http://schemas.android.com/apk/res/android" xmlns:app="http://schemas.android.com/apk/res-auto" xmlns:tools="http://schemas.android.com/tools" android:layout_width="match_parent" android:layout_height="match_parent" tools:context=".MainActivity"> <CheckBox android:id="@+id/checkBox" android:layout_width="match_parent" android:layout_height="wrap_content" android:text="チェックしてね" android:checked="@={viewModel.isCheck}" app:layout_constraintLeft_toLeftOf="parent" app:layout_constraintRight_toRightOf="parent" app:layout_constraintTop_toBottomOf="parent" /> <TextView android:id="@+id/textView2" android:layout_width="match_parent" android:layout_height="wrap_content" android:text='@{viewModel.isCheck ? "true" :"false"}' app:layout_constraintLeft_toLeftOf="parent" app:layout_constraintRight_toRightOf="parent" app:layout_constraintTop_toBottomOf="@id/checkBox" /> <Button android:id="@+id/button" android:layout_width="match_parent" android:layout_height="wrap_content" app:layout_constraintLeft_toLeftOf="parent" app:layout_constraintRight_toRightOf="parent" app:layout_constraintTop_toBottomOf="@id/textView2" /> </androidx.constraintlayout.widget.ConstraintLayout> <data> <variable name="viewModel" type="com.example.twice.binding.MainViewModel" /> </data> </layout>
・参考
https://qiita.com/YusukeIwaki/items/3fb4e10ac87fa1c7f6ba
関連記事:
- androidでDataBinding + ViewModel + LiveDataを使ってみた
- AndroidでLiveDataのTransformationsを使ってみた
- Android Studio 4.0のMotion Editorでアニメーションを作ってみた