Radiogroup のように機能する 2 つの MaterialCardViews を実装しようとしています。したがって、一方をクリックすると、もう一方のチェックを外す必要があります。私はviewModel、liveData、およびカスタムの双方向データバインディングを使用して、これらの値を後の目的のために保存しています(電子メールごとに送信)。
.xml の作成とチェック ロジックの実装には成功しましたが、チェック解除ロジックの実装に苦労しています。
XML、見やすくするための短いバージョン
<layout
xmlns:app="http://schemas.android.com/apk/res-auto">
<data>
<variable
name="vm"
type="com.example.app.data.viewmodel.EmailViewModel" />
</data>
<com.google.android.material.card.MaterialCardView
android:id="@+id/cardViewOne"
android:checkable="true"
android:clickable="true"
android:focusable="true"
<!-- Custom Two way databinding -->
app:state_checked="@={vm.cardOptionOneChecked}"
</com.google.android.material.card.MaterialCardView>
<com.google.android.material.card.MaterialCardView
android:id="@+id/cardViewTwo"
android:checkable="true"
android:clickable="true"
android:focusable="true"
<!-- Custom Two way databinding -->
app:state_checked="@={vm.cardOptionTwoChecked}">
</com.google.android.material.card.MaterialCardView>
</layout>
ビューモデル
class EmailViewModel @ViewModelInject constructor(
@Assisted private val savedStateHandle: SavedStateHandle
) : ViewModel() {
// Variable for Id = cardViewOne
val cardOptionOneChecked = MutableLiveData<Boolean>()
// Variable for Id = cardViewTwo
val cardOptionTwoChecked = MutableLiveData<Boolean>()
}
CardViewAdapter.kt
@BindingAdapter("state_checked")
fun setStateChecked(view: MaterialCardView, liveData: MutableLiveData<Boolean>) {
if (view.isChecked != liveData.value) {
liveData.value = view.isChecked
}
}
@InverseBindingAdapter(attribute = "state_checked")
fun getStateChecked(view: MaterialCardView,): Boolean {
return view.isChecked
}
// I don't know what logic belongs here to make it work!
// Current approach just checks the current view and does nothing more. How can I save the last
// checked value?
@BindingAdapter("state_checkedAttrChanged")
fun setCheckedAttrListener(
view: MaterialCardView,
attrChange: InverseBindingListener,
) {
view.apply {
setOnClickListener { view.isChecked = true }
setOnCheckedChangeListener { card, isChecked ->
if (card.isChecked && card != view) {
card.isChecked = false
}
}
attrChange.onChange()
}
}
私はすべての助けに感謝します、どうもありがとうございました!
PS: ビューから viewModel に isChecked を保存するように指示するなど、これを達成するためのより良い簡単な方法がある場合は、お知らせください。MaterialCardView はデフォルトで「isChecked」を実装していますが、ロジックは実装していません。