web-dev-qa-db-ja.com

e:[kapt]例外が発生しました:Android.databinding.tool.util.LoggedErrorException:Found data binding errors

データバインディングを有効にしましたが、コードの実行中にこのエラーが発生します。

エラー

e:[kapt]例外が発生しました:Android.databinding.tool.util.LoggedErrorException:データバインディングエラーが見つかりました。

フラグメントクラスとそのクラスのXMLを作成しました。 datbindingutilクラスをインポートできません。

再構築/ gradleファイルとの同期/キャッシュの無効化と再起動を行いましたが、何も機能しませんでした。

xml

<layout>

<!--suppress AndroidUnknownAttribute -->
<data class=".databinding.ProfileFragmentBinding">

    <variable
        name="user"
        type="com.sample.sample.user.User" />

    <variable
        name="vm"
        type="com.sample.sample.user.UserViewModel" />

    <variable
        name="handler"
        type="com.sample.sample.user.profile.ProfileFragment" />
</data>


<androidx.constraintlayout.widget.ConstraintLayout 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"
    Android:layout_width="match_parent"
    Android:layout_height="match_parent">

    <de.hdodenhof.circleimageview.CircleImageView
        Android:id="@+id/profileIV"
        Android:layout_width="wrap_content"
        Android:layout_height="wrap_content"
        Android:layout_marginStart="@dimen/medium"
        Android:layout_marginTop="@dimen/medium"
        Android:contentDescription="@null"
        Android:src="@mipmap/ic_launcher_round"
        app:layout_constraintStart_toStartOf="parent"
        app:layout_constraintTop_toTopOf="parent"
        app:url="@{user.avatarUrl}" />

    <LinearLayout
        Android:layout_width="wrap_content"
        Android:layout_height="wrap_content"
        Android:gravity="center"
        Android:orientation="vertical"
        app:layout_constraintBottom_toBottomOf="@+id/profileIV"
        app:layout_constraintLeft_toLeftOf="parent"
        app:layout_constraintRight_toRightOf="parent"
        app:layout_constraintTop_toTopOf="@+id/profileIV">

        <TextView
            Android:id="@+id/profileNameLabel"
            Android:layout_width="wrap_content"
            Android:layout_height="wrap_content"
            Android:fontFamily="@font/myriad_pro_semibold"
            Android:text="@{user.name}"
            Android:textColor="@color/black_transparent_de"
            Android:textSize="@dimen/text_regular"
            tools:text="NAME" />

        <TextView
            Android:id="@+id/badgeLabel"
            Android:layout_width="wrap_content"
            Android:layout_height="wrap_content"
            Android:layout_marginTop="5dp"
            Android:fontFamily="@font/myriad_pro_semibold"
            Android:text="@{user.badge}"
            Android:textColor="@color/grey_000000"
            Android:textSize="@dimen/text_regular"
            tools:text="Superman" />

        <TextView
            Android:id="@+id/profile_Label"
            Android:layout_width="wrap_content"
            Android:layout_height="wrap_content"
            Android:layout_marginTop="5dp"
            Android:fontFamily="@font/roboto_bold"
            Android:text="@{user.badge}"
            Android:textColor="@color/green_39b54a"
            Android:textSize="@dimen/text_small"
            tools:text="farmer_v1" />

    </LinearLayout>

    <ImageView
        Android:id="@+id/badgeIV"
        Android:layout_width="wrap_content"
        Android:layout_height="wrap_content"
        Android:layout_marginEnd="@dimen/medium"
        Android:layout_marginTop="@dimen/medium"
        Android:contentDescription="@null"
        Android:src="@mipmap/ic_launcher"
        app:error="@{@drawable/ic_profile_default_grey_24dp}"
        app:layout_constraintEnd_toEndOf="parent"
        app:layout_constraintTop_toTopOf="parent"
        app:placeholder="@{@drawable/ic_profile_default_grey_24dp}"
        app:url="@{user.badgeUrl}" />

    <ImageView
        Android:id="@+id/locationPinIV"
        Android:layout_width="wrap_content"
        Android:layout_height="wrap_content"
        Android:layout_marginTop="@dimen/medium"
        Android:contentDescription="@null"
        Android:src="@drawable/ic_location_pin"
        app:layout_constraintStart_toStartOf="@+id/profileIV"
        app:layout_constraintTop_toBottomOf="@+id/profileIV" />

    <TextView
        Android:id="@+id/profileAddressTV"
        Android:layout_width="wrap_content"
        Android:layout_height="wrap_content"
        Android:layout_marginStart="@dimen/narrow"
        Android:fontFamily="@font/roboto"
        Android:textColor="@color/grey_000000"
        app:layout_constraintBottom_toBottomOf="@+id/locationPinIV"
        app:layout_constraintLeft_toRightOf="@+id/locationPinIV"
        app:layout_constraintTop_toTopOf="@+id/locationPinIV"
        tools:text="bangalore, Karnataka" />

    <ImageView
        Android:id="@+id/dobIV"
        Android:layout_width="wrap_content"
        Android:layout_height="wrap_content"
        Android:layout_marginStart="@dimen/standard"
        Android:layout_marginTop="@dimen/medium"
        Android:contentDescription="@null"
        Android:src="@drawable/ic_dob"
        app:layout_constraintLeft_toRightOf="@+id/profileAddressTV"
        app:layout_constraintTop_toBottomOf="@+id/profileIV" />

    <TextView
        Android:layout_width="wrap_content"
        Android:layout_height="wrap_content"
        Android:layout_marginStart="@dimen/narrow"
        Android:fontFamily="@font/roboto"
        Android:textColor="@color/grey_000000"
        app:layout_constraintBottom_toBottomOf="@+id/locationPinIV"
        app:layout_constraintLeft_toRightOf="@+id/dobIV"
        app:layout_constraintTop_toTopOf="@+id/locationPinIV"
        tools:text="born on 01/01/2000" />

    <TextView
        Android:id="@+id/activityLabel"
        Android:layout_width="wrap_content"
        Android:layout_height="wrap_content"
        Android:layout_marginTop="@dimen/big"
        Android:fontFamily="@font/myriad_pro_semibold"
        Android:text="@string/activities"
        Android:textColor="@color/black_transparent_de"
        Android:textSize="@dimen/text_regular"
        app:layout_constraintStart_toStartOf="@+id/profileIV"
        app:layout_constraintTop_toBottomOf="@+id/locationPinIV" />

    <View
        Android:id="@+id/dividerV"
        Android:layout_width="match_parent"
        Android:layout_height="1dp"
        Android:layout_marginEnd="@dimen/small"
        Android:layout_marginStart="@dimen/small"
        Android:layout_marginTop="@dimen/regular"
        Android:background="@color/grey_000000"
        app:layout_constraintTop_toBottomOf="@+id/activityLabel" />

    <RelativeLayout
        Android:layout_width="match_parent"
        Android:layout_height="0dp"
        app:layout_constraintTop_toBottomOf="@+id/dividerV">

        <!--<com.google.Android.material.tabs.TabLayout
            Android:id="@+id/tablayout"
            Android:layout_width="match_parent"
            Android:layout_height="wrap_content"
            app:pager="@{(pager)}"
            app:tabGravity="fill"
            app:tabIndicatorColor="@color/black"
            app:tabMode="fixed"
            app:tabSelectedTextColor="@color/black"
            app:tabTextAppearance="@style/CustomTextTab"
            app:tabTextColor="#b4ffffff" />

        <androidx.viewpager.widget.ViewPager
            Android:id="@+id/viewpager"
            Android:layout_width="match_parent"
            Android:layout_height="wrap_content"
            Android:layout_below="@+id/tablayout"
            app:handler="@{handler}"
            app:layout_behavior="@string/appbar_scrolling_view_behavior" />-->

    </RelativeLayout>

</androidx.constraintlayout.widget.ConstraintLayout>

クラス

    class ProfileFragment : Fragment() {
    @Inject
    lateinit var mFactory: ViewModelProvider.Factory
    private lateinit var mBinding: ProfileFragmentBinding

    override fun onCreateView(inflater: LayoutInflater, container: ViewGroup?, savedInstanceState: Bundle?): View? {
        mBinding = DataBindingUtil.inflate(inflater, R.layout.fragment_profile, container, false);
        return mBinding.root
    }

    override fun onActivityCreated(savedInstanceState: Bundle?) {
        super.onActivityCreated(savedInstanceState)
        val vm: UserViewModel = getViewModel(mFactory)
        mBinding.vm = vm
        //mBinding.handler = this
        //mBinding.setLifecycleOwner(this)
    }

    /*@BindingAdapter("bind:handler")
    fun bindViewPagerAdapter(view: ViewPager, activity: MainActivity) {
        val adapter = ProfilePagerAdapter(view.context, activity.supportFragmentManager)
        view.adapter = adapter
    }

    @BindingAdapter("bind:pager")
    fun bindViewPagerTabs(view: TabLayout, pagerView: ViewPager) {
        view.setupWithViewPager(pagerView, true)
    }*/
}
11
wasim

私の場合、次のように、マウスがビルド出力でその行をホバリングしているときに見つけることができました。

ホバーなし: enter image description here

ホバーあり: enter image description here

彼らがエラーを表示する方法は本当に残念です、これまでで最も単純なエラーのために、私は10の異なる解決策を試していただけでなく、キャッシュを無効にしました...

[〜#〜] update [〜#〜]

こちらをクリックすることもできます:

enter image description here

次のようなものが得られます:

enter image description here

これはエラーに関する非常に詳細な情報です。7年間でAndroid Development:D

15

ほとんどの場合、このエラーは、データバインディングを通じてXMLファイルに渡された変数の名前が正しくない場合に発生します。エラーの上にマウスを置くだけで、犯人変数を特定できます。

2
neer17

実行./gradlew build --stacktraceで詳細を確認します。これにより、次のような問題が発生した場所がわかります。

e:[kapt]例外が発生しました:Android.databinding.tool.util.LoggedErrorException:データバインディングエラーが見つかりました。アクセサーxxファイルが見つかりませんでした:xxx/app/src/main/res/layout/fragment_xxxx.xml行:108

プロパティ名を変更した場合、特にrefactor => renameで変更した場合、xmlでプロパティ名は自動的に変更されないことがあります。

2
li2