一、说在前面

昨天 完成了对记账本的账单的增删
今天

完善昨天的框架结构(

1、引入ViewModel管理数据、使MainActive 只管理界面、不再管数据了

2、引入AsyncTask、后台执行。不必强制在主线程执行

3、将Database.java修改为singleton模式、只维护一个Database

4、引入LiveData

问题 没有

二、结构完善

1、引入LiveData,管理所有账单,设置观察者,自主更新界面数据,不必再调用unDataView()来更新界面。

1)、Dao

@Query("SELECT * From ACCOUNTRECORD ORDER BY ID DESC")
LiveData<List<AccountRecord>> getAllAccountRecordLive ();

2)、在MainActive中设置观察者

 accountRecordViewModel.getAllAcountRecord().observe(this, new Observer<List<AccountRecord>>() {
@Override
public void onChanged(List<AccountRecord> accountRecords) {
StringBuilder text = new StringBuilder();
for (int i=0;i<accountRecords.size();i++){
AccountRecord accountRecord = accountRecords.get(i);
text.append(accountRecord.getId()).append(" ").append(accountRecord.getCostType()).append(" ").append(accountRecord.getCostTime()).append(" ").append(accountRecord.getCostMoney()).append("\n");
}
textView.setText(text.toString());
}
});

2、引入ViewModel管理数据、使MainActive 只管理界面、不再管数据了

1)、仓库类操作数据库

package com.me.familybookkeepingbook;

import android.content.Context;
import android.os.AsyncTask; import androidx.lifecycle.LiveData; import java.util.List; public class AccountRecordRepository {
private LiveData<List<AccountRecord>> allAcountRecord;
private AccountRecordDao accountRecordDao;
public AccountRecordRepository(Context context) {
AccountRecordDatabase accountRecordDatabase = AccountRecordDatabase.getAccountRecordDataBase(context.getApplicationContext());
accountRecordDao = accountRecordDatabase.getAccountRecordDao();
allAcountRecord = accountRecordDao.getAllAccountRecordLive();
} public LiveData<List<AccountRecord>> getAllAcountRecord() {
return allAcountRecord;
}
void insertAccountRecord(AccountRecord ... accountRecords){
new InsertAsyncTask(accountRecordDao).execute(accountRecords);
}
void deleteAllAccountRecord(){
new DeleteAsyncTask(accountRecordDao).execute();
}
static class InsertAsyncTask extends AsyncTask<AccountRecord ,Void,Void> {
private AccountRecordDao accountRecordDao; public InsertAsyncTask(AccountRecordDao accountRecordDao) {
this.accountRecordDao = accountRecordDao;
} @Override
protected Void doInBackground(AccountRecord... accountRecords) {
accountRecordDao.insertAccountRecord(accountRecords);
return null;
}
}
static class DeleteAsyncTask extends AsyncTask<Void ,Void,Void>{
private AccountRecordDao accountRecordDao; public DeleteAsyncTask(AccountRecordDao accountRecordDao) {
this.accountRecordDao = accountRecordDao;
} @Override
protected Void doInBackground(Void... Voids) {
accountRecordDao.deleteAllAccountRecord();
return null;
}
}
}

2)、ViewModel管理数据

package com.me.familybookkeepingbook;

import android.app.Application;
import android.os.AsyncTask; import androidx.annotation.NonNull;
import androidx.lifecycle.AndroidViewModel;
import androidx.lifecycle.LiveData; import java.util.List; public class AccountRecordViewModel extends AndroidViewModel {
private AccountRecordRepository accountRecordRepository;
public AccountRecordViewModel(@NonNull Application application) {
super(application);
accountRecordRepository = new AccountRecordRepository(application);
} public LiveData<List<AccountRecord>> getAllAcountRecord() {
return accountRecordRepository.getAllAcountRecord();
} void insertAccountRecord(AccountRecord ... accountRecords){
accountRecordRepository.insertAccountRecord(accountRecords);
}
void deleteAllAccountRecord(){
accountRecordRepository.deleteAllAccountRecord();
}
static class InsertAsyncTask extends AsyncTask<AccountRecord ,Void,Void> {
private AccountRecordDao accountRecordDao; public InsertAsyncTask(AccountRecordDao accountRecordDao) {
this.accountRecordDao = accountRecordDao;
} @Override
protected Void doInBackground(AccountRecord... accountRecords) {
accountRecordDao.insertAccountRecord(accountRecords);
return null;
}
}
static class DeleteAsyncTask extends AsyncTask<Void ,Void,Void>{
private AccountRecordDao accountRecordDao; public DeleteAsyncTask(AccountRecordDao accountRecordDao) {
this.accountRecordDao = accountRecordDao;
} @Override
protected Void doInBackground(Void... Voids) {
accountRecordDao.deleteAllAccountRecord();
return null;
}
}
}

3)、MainActive 管理界面

package com.me.familybookkeepingbook;

import android.os.Bundle;
import android.view.View;
import android.widget.Button;
import android.widget.TextView; import androidx.appcompat.app.AppCompatActivity;
import androidx.lifecycle.Observer;
import androidx.lifecycle.ViewModelProviders; import java.util.List; public class MainActivity extends AppCompatActivity {
AccountRecordViewModel accountRecordViewModel;
Button buttonInsert,buttonDelete;
TextView textView; @Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
accountRecordViewModel = ViewModelProviders.of(this).get(AccountRecordViewModel.class);
textView = findViewById(R.id.textView);
buttonDelete = findViewById(R.id.buttonDelete);
buttonInsert = findViewById(R.id.buttonInsert);
accountRecordViewModel.getAllAcountRecord().observe(this, new Observer<List<AccountRecord>>() {
@Override
public void onChanged(List<AccountRecord> accountRecords) {
StringBuilder text = new StringBuilder();
for (int i=0;i<accountRecords.size();i++){
AccountRecord accountRecord = accountRecords.get(i);
text.append(accountRecord.getId()).append(" ").append(accountRecord.getCostType()).append(" ").append(accountRecord.getCostTime()).append(" ").append(accountRecord.getCostMoney()).append("\n");
}
textView.setText(text.toString());
}
});
buttonInsert.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View v) {
AccountRecord accountRecord = new AccountRecord(1,"2020-01-26","学习",100.0);
accountRecordViewModel.insertAccountRecord(accountRecord);
}
});
buttonDelete.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View v) {
accountRecordViewModel.deleteAllAccountRecord();
}
});
} }

3、引入AsyncTask、后台执行。不必强制在主线程执行

static class InsertAsyncTask extends AsyncTask<AccountRecord ,Void,Void> {
private AccountRecordDao accountRecordDao; public InsertAsyncTask(AccountRecordDao accountRecordDao) {
this.accountRecordDao = accountRecordDao;
} @Override
protected Void doInBackground(AccountRecord... accountRecords) {
accountRecordDao.insertAccountRecord(accountRecords);
return null;
}
}
static class DeleteAsyncTask extends AsyncTask<Void ,Void,Void>{
private AccountRecordDao accountRecordDao; public DeleteAsyncTask(AccountRecordDao accountRecordDao) {
this.accountRecordDao = accountRecordDao;
} @Override
protected Void doInBackground(Void... Voids) {
accountRecordDao.deleteAllAccountRecord();
return null;
}
}

4、将Database.java修改为singleton模式、只维护一个Database

package com.me.familybookkeepingbook;

import android.content.Context;

import androidx.room.Database;
import androidx.room.Room;
import androidx.room.RoomDatabase;
@Database(entities = {AccountRecord.class },version = 1,exportSchema = false)
public abstract class AccountRecordDatabase extends RoomDatabase {
private static AccountRecordDatabase INSTANCE;
public abstract AccountRecordDao getAccountRecordDao();
static synchronized AccountRecordDatabase getAccountRecordDataBase(Context context){
if (INSTANCE == null){
INSTANCE = Room.databaseBuilder(context.getApplicationContext(),AccountRecordDatabase.class,"accountrecord_database")
.build();
}
return INSTANCE;
} }

【Android】家庭记账本手机版开发报告二的更多相关文章

  1. 【Android】家庭记账本手机版开发报告五

    一.说在前面   昨天  1.添加菜单(查询.清除所有等)2.使用滑动删除   今天 1.创建登入和注册界面 2.向数据库添加一张用户表   问题 做完后在登入时有bug(未解决) 二.界面的搭建 1 ...

  2. 【Android】家庭记账本手机版开发报告一

    一.说在前面 昨天 学习了数据库的一些简单操作 今天 使用数据库,完成对记账本的账单记录的增删 问题 没有 二.数据库 1.账单表的结构 (注 id:账单的唯一标识,uid:记录账单的用户的id,co ...

  3. 【Android】家庭记账本手机版开发报告七

    一.说在前面  昨天 实现了账单的图标显示  今天 本地化,测试APP,将工程源码放到github上 源码:https://github.com/xiaotian12-call/Android_Boo ...

  4. 【Android】家庭记账本手机版开发报告六

    一.说在前面  昨天 1.创建登入和注册界面:2.向数据库添加一张用户表  今天 用图标显示账单情况 问题 1.使用第三方库 hellochart,时添加依赖构建失败 2.在 chertFragmen ...

  5. 【Android】家庭记账本手机版开发报告四

    一.说在前面 昨天 对界面显示和逻辑结构进行完善 今天 1.添加菜单(查询.清除所有等) 2.使用滑动删除 问题 1.在做查询时获取SearchView时引 入包错误经过长时间的尝试后才修正 2.滑动 ...

  6. 【Android】家庭记账本手机版开发报告三

    一.说在前面 昨天 对第一天的框架结构进行了四方面的完善 今天 对界面显示和逻辑结构进行完善 问题 无 二.界面展示完善 1.使用可回收的列表recyclerView展示账单的信息,并设置数据项为卡片 ...

  7. 手机版地图api

    手机版地图api一: <iframe style="height:300px;" src="http://map.baidu.com/mobile/webapp/s ...

  8. WPS Office手机版调用接口代码指导帖之一(Android)

    经常会有一些喜欢开发鼓捣的童鞋问我们,WPS Office手机版是否提供调用接口,希望在android中使用一个调用命令,直接调用WPS手机版来打开指定的DOC文件,而不用弹出一个程序可选列表(如果用 ...

  9. 手机版WEB开发经验分享,手机版网站开发注意事项,网站自适应,手机版网站自适应,移动安卓APP自适应

    转自 http://my.oschina.net/cart/blog/282477 做前端开发不短了,用过jQuery Mobile jqMobi 也纯手工写过.. 最后总结如下: jQuery Mo ...

随机推荐

  1. 第1节 storm编程:1、storm第一天上次课程内容回顾

    上次课程内容回顾:1.kafka的基本介绍:kafka是一个消息队列2.消息队列的作用:解耦3.kafka与传统消息队列的对比: 传统消息队列:支持事务 kafka的特点:比较快,比较快的两个原因:顺 ...

  2. SQL常用关键字

    常用SQL语句 SAP实际上提供了两种访问数据库的方式:Open SQL与Native SQL ---语句 功能 数据操作   insert 向表添加新数据行 delete 从表中删除数据行 upda ...

  3. ubuntu最基本的软件

    输入法: https://www.cnbawwwlogs.com/zlslch/p/6943318.html qq: http://www.linuxidc.com/Linux/2016-09/134 ...

  4. LeetCode 297.序列化二叉树 - JavaScript

    题目描述 序列化是将一个数据结构或者对象转换为连续的比特位的操作,进而可以将转换后的数据存储在一个文件或者内存中,同时也可以通过网络传输到另一个计算机环境,采取相反方式重构得到原数据. 请设计一个算法 ...

  5. 101、Java中String类之判断是否由数字组成

    01.代码如下: package TIANPAN; /** * 此处为文档注释 * * @author 田攀 微信382477247 */ public class TestDemo { public ...

  6. Python dir和vars的区别

    dir()和vars()的区别就是 dir()只打印属性(属性,属性......) 而vars()则打印属性与属性的值(属性:属性值......) ex. >> a='aaaaaaaaaa ...

  7. javascript中,对象本身就是一种Map结构。

    var map = {}; map['key1'] = 1; map['key2@'] = 2;   console.log(map['key1']);//结果是1. console.log(map[ ...

  8. MQTT 协议学习:002- 通信报文的构成

    背景 之前工作中参与有关协议调试的时候,发现对于协议帧的解析是比较重要的. 参考:<MQTT协议 -- 消息报文格式>.<基于STM32实现MQTT>.<MQTT协议从服 ...

  9. 2.24 模拟赛 + DIV2 总结

    本来实在是不想打了,后来真的手痒. 晚上发现正进行DIV2然后就打了场,模拟,幸好没参加,逆风.排名2400 Codeforces Round #622 (Div. 2) A题十分钟过了 B题http ...

  10. Network Policy【转】

    Network Policy 是 Kubernetes 的一种资源.Network Policy 通过 Label 选择 Pod,并指定其他 Pod 或外界如何与这些 Pod 通信. 默认情况下,所有 ...