Я новичок в разработке программ android и пытаюсь познакомиться с использованием привязок данных. Я выполнил правильные шаги для создания классов привязки данных, но всякий раз, когда я пытаюсь использовать сгенерированные классы в моей программе, всегда возвращается значение null. Изучив множество возможных причин, я понял, что класс привязки данных расширяет неправильный суперкласс. Ниже приведен один из моих сгенерированных классов
public class FragmentDuosBindingImpl extends FragmentDuosBinding {
@Nullable
private static final androidx.databinding.ViewDataBinding.IncludedLayouts sIncludes;
@Nullable
private static final android.util.SparseIntArray sViewsWithIds;
static {
sIncludes = null;
sViewsWithIds = null;
}
// views
@NonNull
private final androidx.constraintlayout.widget.ConstraintLayout mboundView0;
// variables
// values
// listeners
// Inverse Binding Event Handlers
public FragmentDuosBindingImpl(@Nullable androidx.databinding.DataBindingComponent bindingComponent, @NonNull View root) {
this(bindingComponent, root, mapBindings(bindingComponent, root, 1, sIncludes, sViewsWithIds));
}
private FragmentDuosBindingImpl(androidx.databinding.DataBindingComponent bindingComponent, View root, Object[] bindings) {
super(bindingComponent, root, 0
);
this.mboundView0 = (androidx.constraintlayout.widget.ConstraintLayout) bindings[0];
this.mboundView0.setTag(null);
setRootTag(root);
// listeners
invalidateAll();
}
@Override
public void invalidateAll() {
synchronized(this) {
mDirtyFlags = 0x1L;
}
requestRebind();
}
@Override
public boolean hasPendingBindings() {
synchronized(this) {
if (mDirtyFlags != 0) {
return true;
}
}
return false;
}
@Override
public boolean setVariable(int variableId, @Nullable Object variable) {
boolean variableSet = true;
return variableSet;
}
@Override
protected boolean onFieldChange(int localFieldId, Object object, int fieldId) {
switch (localFieldId) {
}
return false;
}
@Override
protected void executeBindings() {
long dirtyFlags = 0;
synchronized(this) {
dirtyFlags = mDirtyFlags;
mDirtyFlags = 0;
}
// batch finished
}
// Listener Stub Implementations
// callback impls
// dirty flag
private long mDirtyFlags = 0xffffffffffffffffL;
/* flag mapping
flag 0 (0x1L): null
flag mapping end*/
//end}
Как видите, этот сгенерированный класс не похож на типичный класс привязки данных. Класс расширяет класс FragmentDuosFragment вместо класса ViewDataBinding. Я не могу получить доступ ни к одному из моих элементов, которые показаны ниже
<?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"
tools:context="safi.oussama.codwarzonesquadlink.Fragments.DuosFragment">
<androidx.constraintlayout.widget.ConstraintLayout
android:layout_width="match_parent"
android:layout_height="match_parent">
<ListView
android:layout_width="405dp"
android:layout_height="505dp"
app:layout_constraintBottom_toBottomOf="parent"
app:layout_constraintEnd_toEndOf="parent"
app:layout_constraintStart_toStartOf="parent"
app:layout_constraintTop_toTopOf="parent" />
</androidx.constraintlayout.widget.ConstraintLayout>
</layout>
Ниже приведен код из моего фрагмента, который используется для расширения макета и создания классов привязки данных
override fun onCreateView(
inflater: LayoutInflater, container: ViewGroup?,
savedInstanceState: Bundle?
): View? {
val binding:ViewDataBinding=DataBindingUtil.inflate(
inflater, R.layout.fragment_duos, container, false
)
return binding.root}
* 1009 немного по этой проблеме и не нашли ничего похожего на эту ошибку. И, конечно же, я не могу редактировать код сгенерированного класса. Я был бы очень признателен за решение или несколько советов, которые могли бы помочь мне обнаружить неисправность