我正在尝试绑定以下元素:
.xml:
<android.support.v7.widget.SwitchCompat
...
bind:onCheckedChanged="@{(isChecked) -> viewModel.onCheckedChanged(isChecked)}"
.../>
查看型号:
class MyViewModel() {
fun onCheckedChanged(isChecked: Boolean) {
...
}
}
使用绑定适配器:
@BindingAdapter("onCheckedChanged")
fun bindOnCheckedChanged(view: SwitchCompat, onCheckedChanged: (Boolean) -> Unit) {
view.setOnCheckedChangeListener(
{ _, isChecked ->
if (view.isPressed) onCheckedChanged(isChecked)
}
)
}
我得到的错误是这个:
数据绑定错误****msg:找不到方法 onCheckedChanged(java.lang.Object( in class 我的视图模型
数据绑定器似乎无法将isChecked
识别为Boolean
。我试图像isChecked:Boolean
一样强制输入xml,但我得到了一堆不同的错误。
现在我通过使用Any
而不是Boolean
让它工作,但我觉得这是错误的:
@BindingAdapter("onCheckedChanged")
fun bindOnCheckedChanged(view: SwitchCompat, onCheckedChanged: (Any) -> Unit) {
...
和
fun onCheckedChanged(isChecked: Any) {
val isSwitchChecked = isChecked as? Boolean ?: return
...
有谁知道如何让它工作正确的函数签名?
根据绑定适配器文档:"事件处理程序只能与具有一个抽象方法的接口或抽象类一起使用,如以下示例所示:
@BindingAdapter("android:onLayoutChange")
fun setOnLayoutChangeListener(
view: View,
oldValue: View.OnLayoutChangeListener?,
newValue: View.OnLayoutChangeListener?
) {
if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.HONEYCOMB) {
if (oldValue != null) {
view.removeOnLayoutChangeListener(oldValue)
}
if (newValue != null) {
view.addOnLayoutChangeListener(newValue)
}
}
}
"数据库文档从未指定您可以在绑定适配器中使用 Kotlin lambda在这种情况下,您需要仅使用一种方法创建一个接口,如下所示:
interface CustomOnCheckedListener {
fun onChecked(isChecked: Boolean)
}
然后您的绑定适配器:
@BindingAdapter("onCheckedChanged")
fun bindOnCheckedChanged(view: SwitchCompat, onCheckedChanged: CustomCheckListener) {
view.setOnCheckedChangeListener(
{ _, isChecked ->
if (view.isPressed) onCheckedChanged.onChecked(isChecked)
}
)
}
在 ViewModel 类中,您需要创建一个与侦听器方法具有相同签名的函数:
fun onChecked(isChecked: Boolean){
//some code here
}
在你的XML中,只需传递对函数的引用:
"@{viewModel::onChecked}"
解决方案:(科特林(
将 lambda 与参数一起使用
<小时 />|val lambda: (arg1, arg2, ...( -> type |
<小时 />1️➖ ⃣ Lambda 实现:
MainActivity.kt
val lambda: (TextView?) -> Unit = {
Log.i(TAG, "lambda: ${it?.text}")
}
<小时 />2️➖ ⃣ 绑定适配器实现:
Bindings.kt
@BindingAdapter("lambda")
fun View.lambda(block: (TextView?) -> Unit) {
// Your logic
}
<小时 />3️➖ ⃣ 使用数据绑定和绑定适配器:
activity_main.xml
<layout xmlns:android="http://schemas.android.com/apk/res/android">
<data>
<variable
name="activityMain"
type="com.veldan.mvi.ui.activities.MainActivity" />
</data>
<View
lambda="@{activityMain.lambda}"
android:layout_width="match_parent"
android:layout_height="match_parent" />
</layout>