ActivityMainBindingImpl не может быть найден - PullRequest
0 голосов
/ 01 декабря 2018

Это с сайта Google: класс привязки создается для каждого файла макета.По умолчанию имя класса основано на имени файла макета, преобразовывая его в регистр Pascal и добавляя к нему суффикс Binding.Приведенное выше имя файла макета - activity_main.xml, поэтому соответствующий сгенерированный класс - ActivityMainBinding.Этот класс содержит все привязки из свойств макета (например, пользовательской переменной) к представлениям макета и знает, как назначать значения для выражений привязки.

В моем случае ActivityMainBinding isгенерируется, но не ActivityMainBindingImpl .Что это за класс?Как это генерируется?Мой проект написан на Kotlin.

import android.util.SparseArray;
import android.util.SparseIntArray;
import android.view.View;
import androidx.databinding.DataBinderMapper;
import androidx.databinding.DataBindingComponent;
import androidx.databinding.ViewDataBinding;
import com.example.drake.kunuk.databinding.ActivityMainBindingImpl;
import java.lang.IllegalArgumentException;
import java.lang.Integer;
import java.lang.Object;
import java.lang.Override;
import java.lang.RuntimeException;
import java.lang.String;
import java.util.ArrayList;
import java.util.HashMap;
import java.util.List;

public class DataBinderMapperImpl extends DataBinderMapper {
  private static final int LAYOUT_ACTIVITYMAIN = 1;

  private static final SparseIntArray INTERNAL_LAYOUT_ID_LOOKUP = new SparseIntArray(1);

  static {
    INTERNAL_LAYOUT_ID_LOOKUP.put(com.example.drake.kunuk.R.layout.activity_main, LAYOUT_ACTIVITYMAIN);
  }

  @Override
  public ViewDataBinding getDataBinder(DataBindingComponent component, View view, int layoutId) {
    int localizedLayoutId = INTERNAL_LAYOUT_ID_LOOKUP.get(layoutId);
    if(localizedLayoutId > 0) {
      final Object tag = view.getTag();
      if(tag == null) {
        throw new RuntimeException("view must have a tag");
      }
      switch(localizedLayoutId) {
        case  LAYOUT_ACTIVITYMAIN: {
          if ("layout/activity_main_0".equals(tag)) {
            return new ActivityMainBindingImpl(component, view);
          }
      throw new IllegalArgumentException("The tag for activity_main is invalid. Received: " + tag);
    }
  }
}
return null;
  }

мой xml:

<layout xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:app="http://schemas.android.com/apk/res-auto">

<data>
    <import type="android.view.View" />
    <variable
            name="handler"
            type="com.example.drake.kunuk.ui.main.MainActivity" />
    <variable
            name="manager"
            type="androidx.fragment.app.FragmentManager" />
</data>

<LinearLayout
        android:layout_width="match_parent"
        android:layout_height="match_parent"
        android:orientation="vertical">

    <androidx.appcompat.widget.Toolbar
            android:id="@+id/toolbar"
            android:layout_width="match_parent"
            android:layout_height="wrap_content"
            android:animateLayoutChanges="true"
            app:title="@string/app_name"
            app:titleMarginStart="8dp" />

    <com.google.android.material.tabs.TabLayout
            android:id="@+id/tab_layout"
            android:layout_width="match_parent"
            android:layout_height="wrap_content"
            app:pager="@{(pager)}">
    </com.google.android.material.tabs.TabLayout>

    <androidx.viewpager.widget.ViewPager
            android:id="@+id/pager"
            android:layout_width="match_parent"
            android:layout_height="match_parent"
            app:handler="@{handler}" />

</LinearLayout>

MainActivity.kt:

import android.os.Bundle
import androidx.appcompat.app.AppCompatActivity
import androidx.databinding.DataBindingUtil
import com.example.drake.kunuk.R
import com.example.drake.kunuk.databinding.ActivityMainBinding

class MainActivity : AppCompatActivity() {

override fun onCreate(savedInstanceState: Bundle?) {
    super.onCreate(savedInstanceState)
    val binding: ActivityMainBinding = DataBindingUtil
        .setContentView(this, R.layout.activity_main)
    binding.handler = this
    binding.manager = supportFragmentManager



}

}

Ответы [ 3 ]

0 голосов
/ 17 января 2019

Вероятная причина - ошибка на этапе привязки данных.

Компилятор привязки данных берет файлы макета и генерирует классы для поддержки привязки данных (как вы заметили: ActivityMainBinding, ActivityMainBindingImpl; общееpattern, дорогие читатели, это {<i>layout</i>}Binding и {<i>layout</i>}BindingImpl, где {<i>layout</i>} - это имя файла макета в верблюжьей клетке).Ошибки, возникающие во время компиляции привязки данных, препятствуют созданию этих классов поддержки.Это приводит к ошибке отсутствующего класса, которую вы видите в компиляторе Kotlin или Java.

В настоящее время ошибки привязки данных не отображаются в журнале готовой сборки;чтобы увидеть их, переключитесь на вывод raw compiler .Начиная с версии AS 3.5, в обработанном журнале должны отображаться ошибки привязки данных .

Найдя сообщение об ошибке в компиляторе привязки данных, вы можете исправить его или найти ответздесь, как это исправить, если вы не уверены.

0 голосов
/ 21 июля 2019

Еще раз проверьте ваш xml-файл, может быть какая-то проблема, запустите задачу gradle "kaptDebugkotlin" в другом разделе и посмотрите в logCat

Произошло исключение: android.databinding.tool.util.LoggedErrorException:Обнаружены ошибки привязки данных.

enter image description here

0 голосов
/ 01 декабря 2018

в dataBinding шаблоне, если у вас есть какие-либо ошибки (без ошибок во время выполнения) в layout.xml или в activity ... У вас нет этого класса .. и в kotlin убедитесь, что вы добавили dataBinding вот так:

android {
   //
        }
    }

    dataBinding {
        enabled = true
    }
}

и:

// notice that the compiler version must be the same than our gradle version
kapt 'androidx.databinding:databinding-compiler:3.2.1'

должно быть в порядке.

...