美文网首页
Jetpack DataBinding

Jetpack DataBinding

作者: 周末不加班 | 来源:发表于2020-09-18 15:00 被阅读0次

    作用

    1. 将视图绑定到Activity不再需要findViewById()
    2. DataBinding 与 ViewModle+LiveData 将可观察数据反向绑定到View,此时可以实现一个结构化较好的程序

    使用

    一、将视图绑定到Activity

    1. build.gradle 启用数据绑定

    android {
        ......
        dataBinding {
            enabled = true
        }
    }
    

    2. xml中增加layout标签

    <?xml version="1.0" encoding="utf-8"?>
    <layout xmlns:android="http://schemas.android.com/apk/res/android">
    
        <data>
    
        </data>
    
        <LinearLayout
            android:layout_width="match_parent"
            android:layout_height="match_parent"
            android:orientation="vertical">
            <TextView
                android:id="@+id/tv"
                android:layout_width="wrap_content"
                android:layout_height="wrap_content" />
            <Button
                android:id="@+id/but"
                android:layout_width="wrap_content"
                android:layout_height="wrap_content"/>
        </LinearLayout>
    
    </layout>
    
    

    此时会自动生成与xml文件名相对应的类例如 activity_main.xml 会生成 ActivityMainBinding 类

    3. Activity中创建binding对象

    private LayoutBinding binding;
    @Override
    protected void onCreate(@Nullable Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        binding = DataBindingUtil.setContentView(this, R.layout.layout);
        binding.tv.setText("文本");
        binding.but.setOnClickListener(v -> {
            //...
        });
    }
    

    省略了findViewById 通过binding.id直接调用view,但这样还不够简洁还需要.setText、setOnClickListener等操作设置数据,通过下一步可以反向绑定将数据直接绑定到界面上

    二、DataBinding 与 ViewModle+LiveData 将可观察数据反向绑定

    • ViewModel
    public class MyViewModle extends ViewModel {
        // public int index = 0;
        private MutableLiveData<Integer> liveDataIndex;
    
        //获取liveDataIndex类型
        public MutableLiveData<Integer> getLiveDataIndex() {
            if (null == liveDataIndex) {
                liveDataIndex = new MutableLiveData<>();
                liveDataIndex.setValue(0);
            }
            return liveDataIndex;
        }
    
        //liveDataIndex 数据加1
        public void addLiveDataIndex() {
            getLiveDataIndex().setValue(liveDataIndex.getValue() + 1);
        }
    }
    
    • xml
    <?xml version="1.0" encoding="utf-8"?>
    <layout xmlns:android="http://schemas.android.com/apk/res/android">
    
        <data>
    
            <variable
                name="data"
                type="com.example.modle.MyViewModle" />
          
        </data>
    
        <LinearLayout
            android:layout_width="match_parent"
            android:layout_height="match_parent"
            android:orientation="vertical">
    
            <TextView
                android:id="@+id/tv"
                android:layout_width="wrap_content"
                android:layout_height="wrap_content"
                android:text="@{String.valueOf(data.liveDataIndex)}" />
    
            <Button
                android:id="@+id/but"
                android:layout_width="wrap_content"
                android:layout_height="wrap_content"
                android:onClick="@{()->data.addLiveDataIndex(1)}" />
        </LinearLayout>
    
    </layout>
    

    variable标签中引用了一个ViewModel,给TextView绑定数据liveDataIndex,在Button中绑定点击事件调用addLiveDataIndex方法,addLiveDataIndex执行liveDataIndex数据变更,则界面自动更新。此时Activity不在需要setText、setListener()

    • Activity
    @Override
    protected void onCreate(@Nullable Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        MyViewModle myViewModle = new ViewModelProvider(this).get(MyViewModle.class);
        LayoutBinding binding = DataBindingUtil.setContentView(this, R.layout.layout);
        binding.setData(myViewModle);
        binding.setLifecycleOwner(this);
    }
    
    • Fragment
    public View onCreateView(@NonNull LayoutInflater inflater, ViewGroup container, Bundle savedInstanceState)
    {
        MyViewModle myViewModle = new ViewModelProvider(this).get(MyViewModle.class);
        binding = DataBindingUtil.inflate(inflater, R.layout.fragment_about, container, false);
        binding.setModel(myViewModle );
        binding.setLifecycleOwner(this); //委托当前类管理生命周期
        return binding.getRoot();
    }
    
    • 如果希望Fragment获取Activity的ViewModel 使用requireActivity()
    MyViewModle myViewModle = new ViewModelProvider(requireActivity()).get(MyViewModle.class);
    

    相关文章

      网友评论

          本文标题:Jetpack DataBinding

          本文链接:https://www.haomeiwen.com/subject/yaehzhtx.html