DataBinding-xml中使用include

DataBinding-xml中使用include

需要include的xml文件

该文件同其他普通的xml文件相同,用layout标签包裹其他内容,需要的变量定义在data中,代码如下:

<?xml version="1.0" encoding="utf-8"?>
<layout>

    <data>

        <import type="android.view.View" />

        <variable
            name="showEmptyView"
            type="boolean" />
    </data>

    <FrameLayout xmlns:android="http://schemas.android.com/apk/res/android"
        android:layout_width="match_parent"
        android:layout_height="match_parent">

        <RelativeLayout
            android:layout_width="match_parent"
            android:layout_height="match_parent"
            android:visibility="@{showEmptyView ? View.VISIBLE : View.GONE}">

            <ImageView
                android:layout_width="wrap_content"
                android:layout_height="wrap_content"
                android:layout_centerInParent="true"
                android:src="@mipmap/ic_placeholder" />
        </RelativeLayout>

        <android.support.v7.widget.RecyclerView
            android:id="@+id/recycler_view"
            android:layout_width="match_parent"
            android:layout_height="match_parent"
            android:layout_marginTop="12dp" />

    </FrameLayout>
</layout>

使用include

上面代码简单在data中定义了一个boolean型的变量showEmptyView。接下来我们在其他布局中引入该布局的时候就需要用到这个变量,并赋值给他,如下代码所示:

<?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:bind="http://schemas.android.com/apk/res-auto"
    xmlns:tools="http://schemas.android.com/tools">

    <data>

        <variable
            name="viewModel"
            type="xxx.xxx.xxx.ViewModel" />
    </data>

    <LinearLayout
        android:layout_width="match_parent"
        android:layout_height="match_parent"
        android:background="@color/color_bg"
        android:orientation="vertical">
        <include
            android:id="@+id/include"
            layout="@layout/include_recycler"
            android:layout_width="match_parent"
            android:layout_height="match_parent"
            bind:showEmptyView="@{viewModel.showEmptyView}" />
    </LinearLayout>
</layout>

重点有两处:

  • bind: bind:showEmptyView=“”,这里需要使用bind来绑定我们include布局中的showEmptyView变量,然后还需要定义bind的命名空间 xmlns:bind=”http://schemas.android.com/apk/res-auto”
  • include标签需要给一个id:否则的话想用include的布局中的控件ID是无法使用的,给定include标签一个id如include,那么在binding中就可以使用binding.include.recyclerView就可以来操作RecyclerView了。

谢谢观看

该项目Sunshine已放在GitHub,这是其中一篇开发记录,更多开发记录文章请点击该项目查看。

发布了39 篇原创文章 · 获赞 46 · 访问量 7万+
展开阅读全文

如何在include的xml布局使用观察者模式对ImageView显示的图片进行修改

01-12

主布局 <layout xmlns:android="http://schemas.android.com/apk/res/android" xmlns:bind="http://schemas.android.com/apk/res-auto"> <data> <import type="android.databinding.ObservableMap"/> <import type="com.village.crops.utils.DataBindUtil"/> <variable name="main" type="ObservableMap<String,Integer>"/> <variable name="click" type="com.village.crops.activity.MainActivity"/> <variable name="imageUtil" type="DataBindUtil"/> <variable name="imageUrl" type="Integer"/> </data> <LinearLayout android:layout_width="fill_parent" android:layout_height="fill_parent" android:background="@color/colorWhite" android:orientation="vertical" > <FrameLayout android:id="@+id/content" android:layout_width="match_parent" android:layout_height="0dp" android:layout_weight="1"> </FrameLayout> <include android:id="@+id/village_base_bottom" layout="@layout/village_bottom" bind:main="@{main}" bind:click="@{click}" bind:imageUtil="@{imageUtil}" bind:imageUrl="@{imageUrl}"/> </LinearLayout> </layout> 引用布局 <?xml version="1.0" encoding="utf-8"?> <layout xmlns:android="http://schemas.android.com/apk/res/android" xmlns:bind="http://schemas.android.com/apk/res-auto"> <data> <import type="android.databinding.ObservableMap"/> <import type="com.village.crops.utils.DataBindUtil"/> <variable name="main" type="ObservableMap<String,Integer>"/> <variable name="click" type="com.village.crops.activity.MainActivity"/> <variable name="imageUtil" type="DataBindUtil"/> <variable name="imageUrl" type="Integer"/> </data> <LinearLayout android:layout_width="match_parent" android:layout_height="50dp" android:background="@color/colorWhite" android:gravity="center_vertical"> <LinearLayout android:id="@+id/layout_home" android:layout_width="wrap_content" android:layout_height="wrap_content" android:gravity="center" android:layout_weight="1" android:orientation="vertical" android:onClick="@{click.onClick}"> <ImageView android:id="@+id/img_home" android:layout_width="30dp" android:layout_height="30dp" android:src='@{main["imgid"]}' bind:imageUrl="@{imageUrl}"/> <TextView android:id="@+id/text_home" android:layout_width="wrap_content" android:layout_height="wrap_content" style="@style/VillageTextTheme" android:text="@string/home_home" android:textColor='@{main["textColor"]}'/> </LinearLayout> </LinearLayout> </layout> Main代码 activityMainBinding = DataBindingUtil.setContentView(this,R.layout.activity_main); ObservableArrayMap<String, Integer> resourceMap = new ObservableArrayMap<>(); resourceMap.put("imgid",R.mipmap.icon_home_car_sel); resourceMap.put("textColor", Color.RED); activityMainBinding.setClick(this); activityMainBinding.setMain(resourceMap); 问答

没有更多推荐了,返回首页

©️2019 CSDN 皮肤主题: 大白 设计师: CSDN官方博客

分享到微信朋友圈

×

扫一扫,手机浏览