DataBinding框架使用记录
一、DataBinding作用:
· 单纯的摆脱findviewbyid
· 绑定基本数据类型及String
· 绑定Model数据
· 绑定事件
· 通过静态方法转换数据类型
· 通过运算符操作数据
· 自定义Binding的类名
· 绑定相同Model的操作
· model变量改变自动更新数据
· 绑定List/Map等集合数据
· Observable自动更新
· Databinding与include标签的结合
· DataBinding与RecyclerView的结合
二、使用环境:
1、android studio 版本必须大于1.3。
2、Android 的 Gradle 插件版本不低于 1.5.0-alpha1:
classpath 'com.android.tools.build:gradle:2.3.2'
3、修改对应模块(Module)的 build.grade:
android {
....
dataBinding{
enabled = true
}
...
}
三、使用:
1、将布局文件根布局修改为<layout></layout>
<?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">
<LinearLayout
android:layout_width="match_parent"
android:layout_height="match_parent"
android:gravity="center"
android:orientation="horizontal"
tools:context="com.example.nanchen.databindingdemo.MainActivity">
<TextView
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:text="helloworld"
/>
</LinearLayout>
</layout>
注意:(<layout>没有宽、高)
2、加入<data></data>数据集合:data属性里面装的是一系列数据。如下所示:
<data>
<import
type="com.xhx.databinding.databindingtest.User"/>
<variable
name="users"
<!--这里导入的是List集合类<User>加入的泛型此处可能爆红-->
type="java.util.List<User>"/>
</data>
<import>:跟java代码中导包的import类似,区别在java代码中导入的是包,这里导入的是类。(User是自定义的javabean类)。在此导入User类之后就可以在后面引用该类。
<variable>:变量。跟java代码中的变量意思一样。这里有name、type属性。name代表变量名,type表示变量类型。可以在控件中使用变量来进行系列操作。例如给TextView设定字符串。
public class User {
private String title;
private String details;
public User(String title, String details) {
this.title = title;
this.details = details;
}
public String getTitle() {
return title;
}
public void setTitle(String title) {
this.title = title;
}
public String getDetails() {
return details;
}
public void setDetails(String details) {
this.details = details;
}
}
3、在控件中引用data数据:
<?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">
<data>
<import type="com.xhx.databinding.databindingtest.User"/>
<variable
name="user"
type="User"/>
</data>
<LinearLayout
android:layout_width="match_parent"
android:layout_height="match_parent"
android:gravity="center"
android:orientation="horizontal"
tools:context="com.example.nanchen.databindingdemo.MainActivity">
<TextView
android:id="@+id/tv_title"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
<!--引用user对象中的title-->
android:text="@{user.title}"
/>
<TextView
android:id="@+id/tv_details"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
<!--引用user对象中的details-->
android:text="@{user.details}"
/>
</LinearLayout>
</layout>
从上面可以看出如何在将data数据加入布局,并在控件中引用data中的相应的值。虽然看似有点意思了,但稍微一思考会发现此时的user不知道从哪里来的,user.title和user.details也并没有看到在哪里赋值,那么接下来我们看看user从哪里来,如何对这些变量赋值。
public class MainActivity extends AppCompatActivity {
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
//设置界面视图。返回ViewDataBinding
ActivityMainBinding binding=DataBindingUtil.setContentView(MainActivity.this,R.layout.activity_main);
//给data变量赋值
binding.setUser(new User("title---这是title","details---这是details"));
}
}
4、事件绑定:
DataBinding框架提供了相应的事件绑定方式:
普通点击事件:
第一步:在布局xml中的<data>添加<variable>
<?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="com.xhx.databinding.databindingtest.MainActivity">
<data>
<import type="com.xhx.databinding.databindingtest.Main2Activity"/>
<variable
name="main2"
type="Main2Activity"/>
</data>
<!--android stuio 2.3自动生成的布局控件-->
<android.support.constraint.ConstraintLayout
android:layout_width="match_parent"
android:layout_height="match_parent">
<Button
android:onClick="@{main2.clickListner}"
android:id="@+id/btn_1"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_marginLeft="8dp"
android:layout_marginTop="8dp"
android:text="Button"
app:layout_constraintLeft_toLeftOf="parent"
app:layout_constraintTop_toTopOf="parent" />
</android.support.constraint.ConstraintLayout>
</layout>
第二步:实现对应的事件回调方法:
public class Main2Activity extends AppCompatActivity {
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
// setContentView(R.layout.activity_test);
ViewDataBinding binding = DataBindingUtil.setContentView(this, R.layout.include_layout);
binding.setVariable(BR.main1,Main2Activity.this);
}
public void clickListner(View view){
switch (view.getId()){
case R.id.btn_1:
Toast.makeText(Main2Activity.this,"点击了"+((Button)view).getText(),Toast.LENGTH_SHORT).show();
break;
}
}
}
这个事件绑定类似于我们给一个控件onClick属性,然后在Activity中实现对应的回调方法。此方式进行了更灵活的扩展,它可以在任何的类中实现相应的回调方法,这里不再局限于在Activity中。
例如我们将上面的<variable>改为:
<import type="com.xhx.databinding.databindingtest.ClickListner"/>
<variable
name="listner"
type="ClickListner"/>
将android:onClick="@{main2.clickListner}"改为:
android:onClick="@{listner.clickListner}"
实现ClickListner类:
public class ClickListner {
Context context;
public ClickListner(Context context){
this.context=context;
}
public void clickListner(View view){
switch (view.getId()){
case R.id.btn_1:
Toast.makeText(context,"点击了"+((Button)view).getText(),Toast.LENGTH_SHORT).show();
break;
}
}
}
Activity:
public class Main2Activity extends AppCompatActivity {
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
// setContentView(R.layout.activity_test);
ViewDataBinding binding = DataBindingUtil.setContentView(this, R.layout.include_layout);
binding.setVariable(BR.listner,new ClickListner(this));
}
}
长按监听需要在方法中设置返回值:返回true表示长按拦截
如下:
public boolean longClickListener(View view){
switch (view.getId()){
case R.id.tv_long:
Toast.makeText(context,"点击了"+((TextView)view).getText(),Toast.LENGTH_SHORT).show();
return true;
}
return false;
}