数据绑定 - 无法从布局文件调用函数

Data Binding - Cannot call function from a layout file

我试图从我的数据绑定布局中调用一个函数,但我总是收到一些错误。我正在尝试使用我创建的 MyUtilClass 函数在我的 textView 上设置文本。这是我的代码:

activity_main.xml

<?xml version="1.0" encoding="utf-8"?>
<layout 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">

    <data>
        <import type="com.example.testapp.User"/>
        <import type="com.example.testapp.MyUtilClass"/>
        <variable
            name="user"
            type="User" />
    </data>

    <androidx.constraintlayout.widget.ConstraintLayout
        android:layout_width="match_parent"
        android:layout_height="match_parent"
        tools:context=".MainActivity">

        <TextView
            android:id="@+id/textView"
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:text="@{MyUtilClass.Companion.changeText(user.firstName)}"
            app:layout_constraintBottom_toBottomOf="parent"
            app:layout_constraintLeft_toLeftOf="parent"
            app:layout_constraintRight_toRightOf="parent"
            app:layout_constraintTop_toTopOf="parent" />

    </androidx.constraintlayout.widget.ConstraintLayout>
</layout>

MyUtilClass

class MyUtilClass {

    companion object {
        @JvmStatic
        fun changeText(text: String): String {
            return text
        }
    }

}

用户

data class User(
    val firstName: String,
    val lastName: String,
    val age: Int,
    val loggedIn: Boolean
)

MainActivity.java

class MainActivity : AppCompatActivity() {

    private lateinit var binding: ActivityMainBinding

    override fun onCreate(savedInstanceState: Bundle?) {
        super.onCreate(savedInstanceState)
        binding = ActivityMainBinding.inflate(layoutInflater)
        setContentView(binding.root)

        val myUser = User("John", "Doe", 25, true)

        binding.user = myUser
    }

}

错误:

C:\Users\Stefan\AndroidStudioProjects\TestApp\app\build\generated\source\kapt\debug\com\example\testapp\DataBinderMapperImpl.java:9: error: cannot find symbol import com.example.testapp.databinding.ActivityMainBindingImpl; ^ symbol: class ActivityMainBindingImpl location: package com.example.testapp.databinding

cannot find method changeText(java.lang.String) in class com.example.testapp.MyUtilClass.Companion Open File

将 JvmStatic 添加到 MyUtilClass 中的 changeText() 方法会自动使其成为静态的。 因此,您可以在布局文件中像这样访问它:

<?xml version="1.0" encoding="utf-8"?>
<layout 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">

    <data>
        <import type="com.example.testapp.User"/>
        <import type="com.example.testapp.MyUtilClass"/>
        <variable
            name="user"
            type="User" />
    </data>

    <androidx.constraintlayout.widget.ConstraintLayout
        android:layout_width="match_parent"
        android:layout_height="match_parent"
        tools:context=".MainActivity">

        <TextView
            android:id="@+id/textView"
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:text="@{MyUtilClass.changeText(user.firstName)}"
            app:layout_constraintBottom_toBottomOf="parent"
            app:layout_constraintLeft_toLeftOf="parent"
            app:layout_constraintRight_toRightOf="parent"
            app:layout_constraintTop_toTopOf="parent" />

    </androidx.constraintlayout.widget.ConstraintLayout>
</layout>

您可以查看此 link 以了解更多信息:

这是我所做的更改,并且有效。我基本上删除了 class 关键字并添加了对象。

object MyUtilClass {

    @JvmStatic
    fun changeText(text: String): String {
        return text
    }

}