Android Jetpack LiveData

当数据改变时自动刷新界面

在这里插入图片描述
在这里插入图片描述在这里插入图片描述

LiveData

数据变动时,可加观察者,自动刷新数据,不再需要references(指针)刷新界面,简化Controller


实现效果:
在这里插入图片描述

1.使用矢量图

ImageButton支持矢量图,res目录下,new Vector Asset完成后在drawable下会多个xml文件
使用Vector必须在build.gradle(Module:app)文件中defaultConfig下设置:

android.defaultConfig.vectorDrawables.useSupportLibrary = true

其次设置ImageButton的ContentDescription属性

2.新建ViewModel

  1. 声明数据类型 private MutableLiveData LikedNumber 它是一个对象类型 所以要保证不为空,通过构造方法或是get前先判断。
    构造方法
MyViewModelWithLiveData(){
        LikedNumber=new MutableLiveData<>();
        LikedNumber.setValue(0);
    }

get前先判断

public MutableLiveData<Integer> getLikedNumber() {
        if (LikedNumber==null){
            LikedNumber=new MutableLiveData<>();
            LikedNumber.setValue(0);
        }
        return LikedNumber;
    }

这里采用后者

  1. 添加add方法
public void addLikedNumber(int n){
        LikedNumber.setValue(LikedNumber.getValue()+n);
    }

自此,ViewModel写完,写activity


各种关联

重点,以内部匿名类的方式给getLikedNumber()返回的MutableLiveData添加观察,当其变化时,刷新界面

// getLikedNumber()返回 MutableLiveData<Integer> 观察其变化 就只需写一句set方法了
        myViewModelWithLiveData.getLikedNumber().observe(this, new Observer<Integer>() {
            @Override
            public void onChanged(Integer integer) {
                textView.setText(String.valueOf(integer));
            }
        });

完整代码:

package com.example.livedatatest2;

import androidx.appcompat.app.AppCompatActivity;
import androidx.lifecycle.Observer;
import androidx.lifecycle.ViewModelProviders;

import android.os.Bundle;
import android.view.View;
import android.widget.ImageButton;
import android.widget.TextView;

public class MainActivity extends AppCompatActivity {
    MyViewModelWithLiveData myViewModelWithLiveData;
    ImageButton imageButtonLike,imageButtonDisLike;
    TextView textView;
    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);
        textView=findViewById(R.id.textView);
        imageButtonLike=findViewById(R.id.imageButton);
        imageButtonDisLike=findViewById(R.id.imageButton2);
        myViewModelWithLiveData=ViewModelProviders.of(this).get(MyViewModelWithLiveData.class);
        // getLikedNumber()返回 MutableLiveData<Integer> 观察其变化 就只需写一句set方法了
        myViewModelWithLiveData.getLikedNumber().observe(this, new Observer<Integer>() {
            @Override
            public void onChanged(Integer integer) {
                textView.setText(String.valueOf(integer));
            }
        });
        // 单纯让LikedNumber变化
        imageButtonLike.setOnClickListener(new View.OnClickListener() {
            @Override
            public void onClick(View v) {
                myViewModelWithLiveData.addLikedNumber(1);
            }
        });
        imageButtonDisLike.setOnClickListener(new View.OnClickListener() {
            @Override
            public void onClick(View v) {
                myViewModelWithLiveData.addLikedNumber(-1);
            }
        });
    }
}


区别就是在ViewModel中使用了LiveData,就可以用observe观察,就只需在观察中写一句set方法。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值