1. 模块级别的 build.gradle 需要加入 mvvm 的 gradle
2. 需要创建一个 Java类, 作为 ViewModel, 这个类的要求是 需要继承 androidx.lifecycle.ViewModel
3. 修改布局文件 fragment_demo.xml 将其修改成为mvvm的结构
4. 定义 Fragment 需要初始化 ViewModel 的操作
5. 在 MainActivity 当中, 替换容器成为 Fragment
代码
buildFeatures {
viewBinding true
}
dataBinding {
enabled true
}
说明
1、位置说明:
存在于 app 模块级别的 gradle 里面,需要放在 android{ … } 当中
2、原因说明:
只有引入了当前的内容,后续的 MainActivity 当中才能自动创建具体的 Binding 类型
代码
import android.util.Log;
import androidx.lifecycle.ViewModel;
public class DemoViewModel extends ViewModel {
private static final String TAG = DemoViewModel.class.getSimpleName();
// 增加了一个方法, 用于 布局当中的事件处理方案
// 在布局当中采用属性, 绑定事件 android:onClick = "@{()->viewModel.show()}"
public void show() {
Log.i(TAG, "Hello This is My First Fragment type MVVM");
}
}
说明
1、注意问题:
这里的 ViewModel 需要继承的是 androidx.lifecycle.ViewModel 这个类
2、方法说明:
这里的 show( ) 方法是后期为了给 控件 TextView 增加的点击事件处理。
代码 activity 的布局文件 activity_main.xml
,后期作为容器替换成为 Fragment
<FrameLayout xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:tools="http://schemas.android.com/tools"
android:id="@+id/container"
android:layout_width="match_parent"
android:layout_height="match_parent"
tools:context=".MainActivity" />
代码 fragment 的布局文件fragment_demo.xml
,需要改造成为 mvvm 类型
<layout xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:app="http://schemas.android.com/apk/res-auto">
<data>
<import type="svip.chc.DemoViewModel" />
<variable
name="viewModel"
type="DemoViewModel" />
data>
<androidx.constraintlayout.widget.ConstraintLayout
android:layout_width="match_parent"
android:layout_height="match_parent">
<TextView
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:onClick="@{()->viewModel.show()}"
android:text="HelloWorld"
android:textColor="#FF0000"
android:textSize="60sp"
app:layout_constraintBottom_toBottomOf="parent"
app:layout_constraintLeft_toLeftOf="parent"
app:layout_constraintRight_toRightOf="parent"
app:layout_constraintTop_toTopOf="parent" />
androidx.constraintlayout.widget.ConstraintLayout>
layout>
说明
1、结构说明
<根布局> 根布局>
- 1
- 2
- 3
- 4
- 5
- 6
- 7
- 8
- 9
- 10
- 11
2、事件处理
对于事件处理的方式存在多种写法,这里不做一一列举。
目前采用的写法格式是
android:onclick="@{()->viewModel.show()}"
在事件处理当中的
viewModel
是上面标签当中定义的 name 属性值
代码
import androidx.appcompat.app.AppCompatActivity;
import android.os.Bundle;
public class MainActivity extends AppCompatActivity {
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
// 替换 Fragment 的操作
getSupportFragmentManager()
.beginTransaction()
.replace(R.id.container, new DemoFragment())
.commitNow();
}
}
代码
import android.os.Bundle;
import android.view.LayoutInflater;
import android.view.View;
import android.view.ViewGroup;
import androidx.annotation.NonNull;
import androidx.annotation.Nullable;
import androidx.fragment.app.Fragment;
import androidx.lifecycle.ViewModelProvider;
import svip.chc.databinding.FragmentDemoBinding;
public class DemoFragment extends Fragment {
// 说明: 当前的 DemoViewModel 的对象
private DemoViewModel viewModel;
// 说明: FragmentDemoBinding 是根据布局文件的名称自动生成的对象
private FragmentDemoBinding binding;
@Override
public void onCreate(@Nullable Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
// 1. 初始化 ViewModel 的对象
viewModel = new ViewModelProvider(requireActivity()).get(DemoViewModel.class);
}
@Nullable
@Override
public View onCreateView(@NonNull LayoutInflater inflater,
@Nullable ViewGroup container, @Nullable Bundle savedInstanceState) {
// 2. 初始化 binding 的对象
binding = FragmentDemoBinding.inflate(getLayoutInflater(), container, false);
// 3. 绑定 viewModel 和 bing 之间的关系
binding.setViewModel(viewModel);
// 4. 设置生命周期监听, 才能进行事件的监听效果
binding.setLifecycleOwner(getViewLifecycleOwner());
// 5. 获取到根视图的对象, 返回结果
return binding.getRoot();
}
}
说明
1、布局整改
将原始的设置布局的方式,需要修改成为
return binding.getRoot();
2、对于成员变量需要定义两个
他们分别是
binding
和viewModel
两个成员变量都要完成初始化的过程,以及初始化完毕之后的,绑定过程。
3、需要注意的两件事情:
第一件事情:
binding
的类型是自动生成的,他是在我们app
的gralde
当中添加两段代码之后,才能自动生成 第二讲事情: 如果没有设置生命周期的所有者,点击事件的监听会失效