Android Studio开发项目——记账簿应用

项目资源:

       百度网盘链接:https://pan.baidu.com/s/1zN9lrIypi1t_QpuoBcdBNQ?pwd=xj5h 
       提取码:xj5h

项目设计内容

1.基本功能描述

电子记账本是一种在线财务管理工具,用于帮助用户记录和管理他们的收入支出。以下是电子记账本的内容和基本功能的详细说明:

    1.1用户登录界面记账本启动后默认进入的界面,在该界面下已拥有账户的用户可以直接输入用户名和密码来进入记账本首页,新用户则需点击“注册”按钮以进入用户注册界面创建新用户信息。

    1.2用户注册界面:新用户需要设置一个用户名并设置密码才能使用电子记账本,一旦注册成功,用户就可以返回登录界面并通过输入用户名和密码来进入记账本首页

    1.3记账本首页:用户通过在成功登录后进入的页面,该页面主要用于跳转至其他功能性页面,包括新增数据、数据汇总、数据分析以及系统设置界面。

    1.4新增收入数据界面:用户可以在该界面中添加新的收入记录。包括收入的金额、日期、付款方和类别等信息。输入数据后点击“添加”按钮,系统即可将数据录入数据库中,以便后续的查询和汇总分析处理。

    1.5新增支出数据界面与新增收入界面类似,用户可该界面中添加新的支出记录包括支出的金额、日期、收款方和类别等信息。输入数据后点击“添加”按钮,系统即可将数据录入数据库中,以便后续的查询和汇总分析处理。

    1.6收入明细界面:该界面将列出用户在“新增收入”界面中录入的所有收入记录,为用户提供数据查询功能。

    1.7支出明细界面:与“收入明细”类似,该界面将列出用户在“新增支出”界面中录入的所有支出记录,为用户提供数据查询功能。

    1.8数据修改界面:用户可通过点击“收入/支出明细”界面中的数据直接跳转至对应数据的修改界面,在该界面下,用户可修改或删除当前的收入/支出数据,点击保存后,系统会将修改的新数据覆盖此前的旧数据。

    1.8数据汇总界面:电子记账本可以自动汇总用户的总收入和总支出,并计算出整体收支情况,这些汇总信息可以帮助用户了解他们的财务状况,并制定相应的预算计划。

    1.9数据分析界面:电子记账本利用折线统计图对数据走势进行统计分析,以帮助用户更好地理解他们的财务状况。

    1.10系统设置界面:如果用户想要更改他们的密码,他们可以在该界面下进行操作。通常,这需要输入当前的密码,然后输入新的密码并再次确认密码系统在确认新密码与旧密码不同且不为空,并且两次输入的新密码相同后,会用新的密码数据覆盖旧的密码数据,完成密码修改。

2.工作流程

图 1.1 记账本工作流程图

2.1记账簿工作流程如下:

       用户启动记账簿后,默认进入登录界面。已有账户的用户可在输入用户名和密码后直接点击“登录”按钮,系统在数据库的用户表中查询到对应的用户数据后即可进入记账本首页,没有相关信息的新用户则可在登录界面中点击“注册”按钮跳转至注册界面进行新用户信息的录入,成功注册后系统会将新的用户数据录入用户表中,随后即可返回用户登录界面进行登录。

       用户登录成功后进入首页,在该界面下,可点击对应图标跳转至各个功能界面。

       首次使用该记账本时,需先点击“新增收入”或“新增支出”进入对应界面进行收支数据的录入。输入数据并点击“保存”按钮后,系统会将输入的数据录入对应的收入/支出表中,便于后续的数据处理。

       返回记账簿首页,点击“收入明细”或“支出明细”即可进入对应的数据明细界面。在该页面下,系统会将此前用户在“新增”界面下录入的收支数据列出,便于用户进行数据查询。同时,在该界面下点击收支数据即可跳转至相应的数据修改界面,在数据修改界面用户可自行修改收支数据的各项属性,点击“修改”按钮,系统会将新的数据覆盖旧的数据,点击“删除”按钮,系统会将当前数据从数据库中删除,以此达到修改数据的目的。

       返回记账簿首页,点击首页顶部图片即可进入数据汇总界面,该界面中,系统从数据库中提取出收支金额并进行总和计算,得出总收入、总支出和整体收支情况,并列出,便于用户查看整体账目数据。

       返回记账簿首页,点击“数据分析”即可进入数据分析页面,该页面将此前“新增”或“修改”的数据处理后生成统计图,用户可以直观的查询收入或支出的变化。

       在首页点击“系统设置”以跳转至用户密码修改界面,该界面的左上角会标记出当前用户的名称,用户可以在该界面下修改自己的登录密码,系统核对新的密码与旧密码不同且不为空,并且与第二次输入的新密码相同后,会将新的密码数据录入数据库的用户表中,并覆盖旧的密码数据,以此达到修改密码的目的。

3.数据库设计

3.1项目相关数据库如表1.1、表1.2、表1.3所示。

用户表(tb_userinfo)

字段名

类型

属性

说明

ID

integer

PK,IDENTITY

用户ID

name

varchar(10)

NOT NULL

用户名

pwd

varchar(15)

NOT NULL

用户登录密码

表1.1

收入表(in_com)

字段名

类型

属性

说明

ID

integer

PK,IDENTITY

收入数据ID

inmoney

double

NULL

收入金额

intime

varchar(20)

NULL

收入时间

intype

varchar(30)

NULL

收入类型

inpayer

varchar(100)

NULL

付款方

inremark

varchar(500)

NULL

备注

表1.2

支出表(pay_out)

字段名

类型

属性

说明

ID

integer

PK,IDENTITY

支出数据ID

outmoney

double

NULL

支出金额

outtime

varchar(20)

NULL

支出时间

outtype

varchar(30)

NULL

支出类型

outpayee

varchar(100)

NULL

收款方

outremark

varchar(500)

NULL

备注

表1.3

4.程序运行结果

                                          

   图 4.1用户注册界面                          图 4.2用户登录界面                            图 4.3记账本首页

                                          

   图 4.4新增收入界面                           图 4.5新增支出界面                          图 4.6收入明细界面

                                          

    图 4.7支出明细界面                           图 4.8数据分析界面                            图 4.9系统设置界面

                    ​​​​​​​

   图 4.10数据修改界面                           图 4.11数据汇总界面

5.部分代码示例

      5.1新增收入页面

package com.example.tallybook.activity;

import androidx.appcompat.app.AppCompatActivity;

import android.content.ContentValues;
import android.content.Intent;
import android.database.sqlite.SQLiteDatabase;
import android.os.Bundle;
import android.view.View;
import android.widget.Button;
import android.widget.EditText;
import android.widget.Spinner;
import android.widget.Toast;

import com.example.tallybook.R;
import com.example.tallybook.db.MyDBHelper;
import com.example.tallybook.view.Home;

public class NewInComeActivity extends AppCompatActivity {

    EditText et_money,et_time,et_payer,et_remark;
    Spinner sp_type;
    Button bt_sava,bt_cancel;
    MyDBHelper mhelper;
    SQLiteDatabase db;

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_new_in_come);

        initView();
        btnSave();
        btnCancel();

    }

    private void initView() {
         et_money = findViewById(R.id.et_money_newin);
         et_time = findViewById(R.id.et_time_newin);
         sp_type = findViewById(R.id.sp_type_newin);
         et_payer = findViewById(R.id.et_payer_newin);
         et_remark = findViewById(R.id.et_remake_newin);
         bt_sava = findViewById(R.id.bt_save_newin);
         bt_cancel = findViewById(R.id.bt_cancel_newin);
         mhelper = new MyDBHelper(NewInComeActivity.this);
         db = mhelper.getWritableDatabase();
    }

    private void btnSave(){
        bt_sava.setOnClickListener(new View.OnClickListener(){
            @Override
            public void onClick(View v){
                ContentValues values = new ContentValues();
                values.put("inmoney",et_money.getText().toString());
                values.put("intime",et_time.getText().toString());
                values.put("intype",sp_type.getSelectedItem().toString());
                values.put("inpayer",et_payer.getText().toString());
                values.put("inremark",et_remark.getText().toString());
                db.insert("in_come",null,values);
                Toast.makeText(NewInComeActivity.this,"保存成功", Toast.LENGTH_SHORT).show();
                Intent intent = new Intent(NewInComeActivity.this,NewInComeActivity.class);
                startActivity(intent);
                finish();
            }
        });
    }

    private void btnCancel() {
        bt_cancel.setOnClickListener(new View.OnClickListener() {
            @Override
            public void onClick(View v) {
                Intent intent = new Intent(NewInComeActivity.this, Home.class);
                startActivity(intent);
                finish();
            }
        });
    }

}

    5.2收入明细界面

package com.example.tallybook.activity;

import androidx.appcompat.app.AppCompatActivity;
import androidx.recyclerview.widget.RecyclerView;
import androidx.recyclerview.widget.StaggeredGridLayoutManager;

import android.annotation.SuppressLint;
import android.database.Cursor;
import android.database.sqlite.SQLiteDatabase;
import android.os.Bundle;

import com.example.tallybook.R;
import com.example.tallybook.adapter.IncomeAdapter;
import com.example.tallybook.bean.IncomeBean;
import com.example.tallybook.db.MyDBHelper;

import java.util.ArrayList;
import java.util.List;

public class InComeDetailActivity extends AppCompatActivity {

    RecyclerView recy_view;
    MyDBHelper mhelper;
    SQLiteDatabase db;
    List<IncomeBean> arr1 = new ArrayList();

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_in_come_detail);

        initView();
        initData();
        IncomeAdapter adapter = new IncomeAdapter(InComeDetailActivity.this,arr1);
        StaggeredGridLayoutManager st = new StaggeredGridLayoutManager(StaggeredGridLayoutManager.VERTICAL,1);
        recy_view.setLayoutManager(st);
        recy_view.setAdapter(adapter);
    }

    private void initView(){
        recy_view = findViewById(R.id.recy_view_indetail);
        mhelper = new MyDBHelper(InComeDetailActivity.this);
        db = mhelper.getWritableDatabase();
    }

    private void initData(){
        Cursor cursor = db.rawQuery("select * from in_come",null);
        while (cursor.moveToNext()){
            @SuppressLint("Range") int myid = cursor.getInt(cursor.getColumnIndex("id"));
            @SuppressLint("Range") double mymoney = cursor.getDouble(cursor.getColumnIndex("inmoney"));
            @SuppressLint("Range") String mytime = cursor.getString(cursor.getColumnIndex("intime"));
            @SuppressLint("Range") String mytype = cursor.getString(cursor.getColumnIndex("intype"));
            @SuppressLint("Range") String mypayer = cursor.getString(cursor.getColumnIndex("inpayer"));
            @SuppressLint("Range") String myremark = cursor.getString(cursor.getColumnIndex("inremark"));
            IncomeBean incomeBean = new IncomeBean(myid,mymoney,mytime,mytype,mypayer,myremark);
            arr1.add(incomeBean);
        }
    }
}

    5.3数据库

package com.example.tallybook.db;

import androidx.annotation.Nullable;
import androidx.appcompat.app.AppCompatActivity;

import android.content.Context;
import android.database.sqlite.SQLiteDatabase;
import android.database.sqlite.SQLiteOpenHelper;
import android.os.Bundle;

import com.example.tallybook.R;
import com.example.tallybook.activity.NewInComeActivity;

public class MyDBHelper extends SQLiteOpenHelper {

    private static final String DBNAME = "financial.db";
    private static final int VERSION = 1;
    public MyDBHelper(Context context) {
        super(context, DBNAME, null, VERSION);
    }

    @Override
    public void onCreate(SQLiteDatabase db) {
        //用户表
        db.execSQL("create table tb_userinfo(id integer primary key autoincrement,name varchar(10),pwd varchar(15))");

        //收入表
        db.execSQL("create table in_come(id integer primary key autoincrement,inmoney double,intime varchar(20)," +
                "intype varchar(30),inpayer varchar(100),inremark varchar(500))");
        //支出表
        db.execSQL("create table pay_out(id integer primary key autoincrement,outmoney double,outtime varchar(20)," +
                "outtype varchar(30),outpayer varchar(100),outpayee varchar(100),outremark varchar(500))");
    }

    @Override
    public void onUpgrade(SQLiteDatabase db,int oldVersion,int newVersion){

    }

}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:/a/452140.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

行业突破!四信实现低延时摄像头弱网状态100ms以内实时传输

随着人工智能、大数据、区块链等技术在城市中快速发展&#xff0c;人们日常生活中已经离不开网络的支撑&#xff0c;而实现“人与人”、“人与物”及“物与物”之间高速连接应用的“时延”&#xff0c;是网络支撑中最重要的存在。 以城市生活例子为例&#xff0c;当网络延时出现…

刷题日记——16进制不进位加法(厦门大学机试)

例题 分析 输入 本题解题关键在于输入的两个数位数不同时候需要尾数对齐&#xff0c;由于是16进制输入&#xff0c;含有字母&#xff0c;需要当作字符串输入&#xff0c;当然输出也要字母&#xff0c;那么就需要我们的两个老伙计了&#xff0c;一个是map&#xff0c;另一个是…

第五篇【传奇开心果系列】Python的自动化办公库技术点案例示例:深度解读Pandas在教育数据和研究数据处理领域的应用

传奇开心果博文系列 系列博文目录Python的自动化办公库技术点案例示例系列 博文目录前言一、Pandas 在教育和学术研究中的常见应用介绍二、数据清洗和预处理示例代码三、数据分析和统计示例代码四、数据可视化示例代码五、时间序列分析示例代码六、数据导入和导出示例代码七、数…

搜维尔科技:工作室选择 OptiTrack 进行新的虚拟制作舞台

35North Studios 成立于 2020 年&#xff0c;是一家最先进的制作工作室。他们的全方位服务方法可帮助电影制片人和企业在一个设备齐全且先进的地点规划、拍摄、编辑、评分和完成项目。该工作室位于爱荷华州克利尔湖&#xff0c;为创作者提供了一个安静的空间&#xff0c;让他们…

就业班 2401--3.12 Linux Day16 PXE布置——自动化装系统

什么是PXE&#xff1f; PXE&#xff0c;全名Pre-boot Execution Environment&#xff0c;预启动执行环境&#xff1b;通过网络接口启动计算机&#xff0c;不依赖本地存储设备&#xff08;如硬盘&#xff09;或本地已安装的操作系统&#xff1b;由Intel和Systemsoft公司于1999年…

leetcode-hot100-矩阵

73. 矩阵置零 给定一个 _m_ x _n_ 的矩阵&#xff0c;如果一个元素为 0 &#xff0c;则将其所在行和列的所有元素都设为 0 。请使用 原地 算法。 **输入&#xff1a;matrix [[1,1,1],[1,0,1],[1,1,1]] 输出&#xff1a;[[1,0,1],[0,0,0],[1,0,1]] 两次遍历&#xff0c;第一…

如何用SSH连接

以gitlab的SSH来举例&#xff0c;包括配置与克隆的过程&#xff1a; Git 是一个分布式版本控制系统&#xff0c;这意味着您可以在本地工作&#xff0c; 然后将您的更改共享或推送到服务器。在这种情况下&#xff0c;您推送到的服务器是 GitLab。 GitLab 使用 SSH 协议与 Git …

牛角表情生成器微信小程序版

1.纯前端输出&#xff0c;无需后台&#xff0c;无需域名&#xff0c;速度杠杠快&#xff01; 2.完美支持微信端和抖音端&#xff1b; 3.双端均支持配置开启流量主广告&#xff0c;包括&#xff1a;激励视频广告、插屏广告、banner广告、原生广告、封面广告等&#xff1b; 4.…

Unity URP 如何写基础的曲面细分着色器

左边是默认Cube在网格模式下经过曲面细分的结果&#xff0c;右边是原状态。 曲面细分着色器在顶点着色器、几何着色器之后&#xff0c;像素着色器之前。 它的作用时根据配置信息生成额外的顶点以切割原本的面片。 关于这部分有一个详细的英文教程&#xff0c;感兴趣可以看一…

【Linux进阶之路】HTTP协议

文章目录 一、基本概念1.HTTP2.域名3.默认端口号4.URL 二、请求与响应1.抓包工具2.基本框架3.简易实现3.1 HttpServer3.2 HttpRequest3.2.1 version13.2.2 version23.2.3 version3 总结尾序 一、基本概念 常见的应用层协议&#xff1a; HTTPS (HyperText Transfer Protocol Sec…

sqllab第五关通关笔记

知识点&#xff1a; 报错注入函数语法&#xff08;详见第二关笔记&#xff09;报错注入打印位数最多32位对于大于32位的数据最好使用截取函数进行控制&#xff1b;以保证输出完整mysql表中的重点数据库 information_schema &#xff08;mysql 5.0以上&#xff09; schemata …

采购管理系统:寻源到付款 (S2P) 流程自动化有什么好处?

企业的采购部门由各种流程和团队驱动&#xff0c;包括采购和应付账款。为实现战略目标而采用的策略流程之一是寻源到付款&#xff08;S2P&#xff09;流程。 何时使用 “寻源到付款”&#xff1f; 顾名思义&#xff0c;寻源到付款的主要目的是寻找最佳供应商以满足业务需求&a…

双场板功率型GaN HEMT中用于精确开关行为的电容建模

来源:Capacitance Modeling in Dual Field-Plate Power GaN HEMT for Accurate Switching Behavior (TED 16年) 摘要 本文提出了一种基于表面电势的紧凑模型&#xff0c;用于描述具有栅极和源极场板&#xff08;FP&#xff09;结构的AlGaN/GaN高电子迁移率晶体管&#xff08;…

5.BOM-操作浏览器(BOM、插件、本地存储)

BOM // BOM操作&#xff1a;操作浏览器(通过js的方式实现浏览器中的某些功能)// a)通过js的方式实现页面刷新效果// b)通过js的方式&#xff0c;实现浏览器的上一页、下一页// c)通过js的方式&#xff0c;实现页面的跳转Window对象 window是浏览器对象&#xff0c;又称为顶级对…

redis题库详解

1 什么是Redis Redis(Remote Dictionary Server) 是一个使用 C 语言编写的&#xff0c;开源的&#xff08;BSD许可&#xff09;高性能非关系型&#xff08;NoSQL&#xff09;的键值对数据库。 Redis 可以存储键和五种不同类型的值之间的映射。键的类型只能为字符串&#xff0c;…

C++函数 加括号与不加括号

很多时候&#xff0c;我们会看到一些在创建对象时有的加括号有的不加括号 那么&#xff0c;这是什么情况呢&#xff1f; 总结&#xff1a;函数需要加上括号&#xff0c;加上括号会对函数初始化&#xff0c;不加括号可能导致未知错误 我们来验证一下。 1.基本数据类型不带括…

二级指针作为函数参数——可以改变调用函数中传入指针的值(不是指向地址的值哦!)

主要是看这篇文章&#xff1a; 二级指针作为函数参数_二级指针做函数参数-CSDN博客 对里面的程序进行一些修改和补充&#xff0c;调试加更多说明。 1、一级指针情况&#xff1a; #include"stdio.h"int my_strlen1(const char* str) {int count 0;int i 0;if (N…

【功能大全】手机短信验证码一键注册登录流程

目录 发送验证码 注册登录 用户表设计 ​编辑申请腾讯云短信与密钥 找到云短信服务 开通腾讯云短信服务 ​编辑​​​​​创建短信签名 ​编辑​编辑创建短信正文模版​编辑​编辑 等待审核 测试短信​编辑 SDK密钥创建 SpringBoot集成腾讯云短信 pom中导入腾讯云短…

Uni-app跟学笔记(一):新建项目、运行、tabbar、全局配置

文章目录 1&#xff09;新建项目2&#xff09;项目运行3&#xff09;项目结构4&#xff09;开发规范5&#xff09;globalStyle全局外观配置6&#xff09;pages页面配置7&#xff09;tabbar8&#xff09;Condition 本博客为 uni-app 此门课的跟学笔记&#xff0c;目的是便于个人…

HTML5:七天学会基础动画网页12

“书接上回”继续对transition补充&#xff0c;在检查中找到ease后&#xff0c;鼠标放到ease前的紫色小方块就可以对运动曲线进行调整&#xff0c;这个曲线叫贝塞尔曲线&#xff0c;这里不做别的补充&#xff0c;不用了解&#xff0c;我们只要知道这个运动方式不只是有简单的匀…