Android data binding crash when using include tag with custom view layout

I am trying to add a custom view using a tag includeto my activity layout that uses a DataBinding. My custom view also uses a DataBinding. But I had a crash when starting the application:

05-02 17:30:03.685 12595-12595/? E/AndroidRuntime: FATAL EXCEPTION: main
                                                   Process: com.novachevskyi.databindingtest, PID: 12595
                                                   java.lang.RuntimeException: Unable to start activity ComponentInfo{com.novachevskyi.databindingtest/com.novachevskyi.databindingtest.MainActivity}: java.lang.NullPointerException: Attempt to invoke virtual method 'void com.novachevskyi.databindingtest.databinding.CustomViewBinding.invalidateAll()' on a null object reference
                                                       at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2416)
                                                       at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2476)
                                                       at android.app.ActivityThread.-wrap11(ActivityThread.java)
                                                       at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1344)
                                                       at android.os.Handler.dispatchMessage(Handler.java:102)
                                                       at android.os.Looper.loop(Looper.java:148)
                                                       at android.app.ActivityThread.main(ActivityThread.java:5417)
                                                       at java.lang.reflect.Method.invoke(Native Method)
                                                       at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:726)
                                                       at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:616)
                                                    Caused by: java.lang.NullPointerException: Attempt to invoke virtual method 'void com.novachevskyi.databindingtest.databinding.CustomViewBinding.invalidateAll()' on a null object reference
                                                       at com.novachevskyi.databindingtest.databinding.ActivityMainBinding.invalidateAll(ActivityMainBinding.java:41)
                                                       at com.novachevskyi.databindingtest.databinding.ActivityMainBinding.<init>(ActivityMainBinding.java:33)
                                                       at com.novachevskyi.databindingtest.databinding.ActivityMainBinding.bind(ActivityMainBinding.java:105)
                                                       at android.databinding.DataBinderMapper.getDataBinder(DataBinderMapper.java:11)
                                                       at android.databinding.DataBindingUtil.bind(DataBindingUtil.java:185)
                                                       at android.databinding.DataBindingUtil.bindToAddedViews(DataBindingUtil.java:299)
                                                       at android.databinding.DataBindingUtil.setContentView(DataBindingUtil.java:279)
                                                       at android.databinding.DataBindingUtil.setContentView(DataBindingUtil.java:261)
                                                       at com.novachevskyi.databindingtest.MainActivity.onCreate(MainActivity.java:11)
                                                       at android.app.Activity.performCreate(Activity.java:6251)
                                                       at android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1107)
                                                       at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2369)
                                                       at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2476at android.app.ActivityThread.-wrap11(ActivityThread.java) 
                                                       at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1344at android.os.Handler.dispatchMessage(Handler.java:102at android.os.Looper.loop(Looper.java:148at android.app.ActivityThread.main(ActivityThread.java:5417at java.lang.reflect.Method.invoke(Native Method) 
                                                       at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:726at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:616

MainActivity:

public class MainActivity extends AppCompatActivity {
  @Override protected void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);
    DataBindingUtil.setContentView(this, R.layout.activity_main);
  }
}

CustomView:

public class CustomView extends LinearLayout {
  public CustomView(Context context, AttributeSet attrs) {
    super(context, attrs);
  }

  @Override protected void onFinishInflate() {
    super.onFinishInflate();
    DataBindingUtil.bind(this);
  }
}

activity_main.xml:

<?xml version="1.0" encoding="utf-8"?>
<layout
    xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:tools="http://schemas.android.com/tools">

  <RelativeLayout
      android:layout_width="match_parent"
      android:layout_height="match_parent"
      android:paddingLeft="@dimen/activity_horizontal_margin"
      android:paddingRight="@dimen/activity_horizontal_margin"
      android:paddingTop="@dimen/activity_vertical_margin"
      android:paddingBottom="@dimen/activity_vertical_margin"
      tools:context="com.novachevskyi.databindingtest.MainActivity">

    <include layout="@layout/custom_view"/>

  </RelativeLayout>

</layout>

custom_view.xml:

<?xml version="1.0" encoding="utf-8"?>
<layout
    xmlns:android="http://schemas.android.com/apk/res/android">

  <com.novachevskyi.databindingtest.CustomView
      android:layout_width="match_parent"
      android:layout_height="match_parent">

    <TextView
        android:text="Hello World!"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"/>

  </com.novachevskyi.databindingtest.CustomView>

</layout>

I also created a public repo with a sample project: https://github.com/novachevskyi/DataBinding-issue

I used data binding to com.android.tools.build:gradle:1.3.1, and now that I tried to upgrade the build tool version to com.android.tools.build:gradle:2.1.0, I ran into such a problem with all of my views containing the includexml tag . Understand any information about the problem described above.

+4
1

. , , - ,

@Override protected void onFinishInflate() {
    super.onFinishInflate();
    DataBindingUtil.bind(this);
}

DataBindingUtil.bind(this), . , bind <layout>, , , . CustomView , , ViewDataBinding throw new IllegalArgumentException("View is not a binding layout")

, , bind onFinishInflate , , . CustomView, :

@Override protected void onAttachedToWindow() {
  super.onAttachedToWindow();
  CustomViewBinding binding = DataBindingUtil.findBinding(this);
}
0

All Articles