Android 双向绑定整数类型问题

Android two way binding Integer type issue

当我想使用数据绑定方法将数据从 XML 传输到带有 Int 的视图模型 class 时,我遇到了问题。我见过很多与此相关的问题,但我尝试过的解决方案都没有。这是什么原因?

XML

      <EditText
        android:id="@+id/editTextTextPersonName3"
        android:layout_width="0dp"
        android:layout_height="wrap_content"
        android:layout_marginEnd="30dp"
        android:ems="10"
        android:hint="Telefon"
        android:inputType="textPersonName"
        app:layout_constraintBaseline_toBaselineOf="@+id/editTextTextPersonName2"
        app:layout_constraintEnd_toEndOf="parent"
        app:layout_constraintStart_toEndOf="@+id/editTextTextPersonName2"
        android:text="@={`` +addTenant.tc}"/>

查看模型

class AddTenantVM(application: Application): BaseViewModel(application) {
    val tc = MutableLiveData<Int>()

    fun tenant (){
        println(tc.value.toString())
    }
}

由于您的 MutableLiveData 是 Integer 类型,因此编辑文本应该是整数输入类型。尝试使用:android:inputType="phone"android:inputType="numberDecimal"。 还在视图模型中初始化可变实时数据。像这样val tc = MutableLiveData<Int>(0)

当您传递一个 int 时,默认情况下,它会尝试搜索相同的字符串资源。 (R.string.example_string实际上是一个int

并且通过放置 `` + (int) ,2 向绑定功能将丢失 - 因为活页夹不知道如何转换它。

解决方法: 将以下代码放在单独的 .kt 文件中(我创建了 CustomBindings.kt 并放置了它)。不需要 Class - 直接粘贴函数即可。

@BindingAdapter("my_number")
fun setNumber(view: TextView, value: Int?) {
    if (view.text != value)
        view.text = "" + value
}

@InverseBindingAdapter(attribute = "my_number")
fun getNumber(view: TextView): Int {
    return view.text.toString().toIntOrNull() ?: 0
}

在 XML 中,删除 android:text 并放入:

app:my_number="@={addTenant.tc}"

================= 下面的可选步骤 =======================

此外,如果您遇到 my_numberAttrChange not defined 之类的任何错误,请将其放入 CustomBindings.kt

@BindingAdapter(value = ["my_numberAttrChanged"])
fun setListener(textView: EditText, numberAttrChanged: InverseBindingListener?) {
    if (numberAttrChanged!= null) {
        textView.addTextChangedListener(object : TextWatcher {
            override fun beforeTextChanged(charSequence: CharSequence, i: Int, i1: Int, i2: Int) {
            }

            override fun onTextChanged(charSequence: CharSequence, i: Int, start: Int, end: Int) {
// this will change as per your app's behavourial requirements
                if (start != end) {
                    numberAttrChanged.onChange()
                }
                textView.setSelection(end)
            }

            override fun afterTextChanged(editable: Editable) {
            }
        })
    }
}