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) {
}
})
}
}
当我想使用数据绑定方法将数据从 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) {
}
})
}
}