• Android程序设计之学生考勤管理系统


    基于安卓平台开发的学生考勤管理系统,本系统采用java语言设计,数据存储使用SQLite轻量级数据库实现

    SQLite 简介

    SQLite是一个软件库,实现了自给自足的、无服务器的、零配置的、事务性的 SQL 数据库引擎。SQLite是一个增长最快的数据库引擎,这是在普及方面的增长,与它的尺寸大小无关。SQLite 源代码不受版权限制。

    什么是 SQLite?
    SQLite是一个进程内的库,实现了自给自足的、无服务器的、零配置的、事务性的 SQL 数据库引擎。它是一个零配置的数据库,这意味着与其他数据库不一样,您不需要在系统中配置。

    就像其他数据库,SQLite 引擎不是一个独立的进程,可以按应用程序需求进行静态或动态连接。SQLite 直接访问其存储文件。

    为什么要用 SQLite?

    • 不需要一个单独的服务器进程或操作的系统(无服务器的)。

    • SQLite 不需要配置,这意味着不需要安装或管理。

    • 一个完整的 SQLite 数据库是存储在一个单一的跨平台的磁盘文件。

    • SQLite 是非常小的,是轻量级的,完全配置时小于 400KiB,省略可选功能配置时小于250KiB。

    • SQLite 是自给自足的,这意味着不需要任何外部的依赖。


    教师(管理远端): (登录,注册,班级管理,学生管理,课程管理,签到管理,请假管理,个人中心)

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

    在这里插入图片描述


    学生端: (我要请假,考勤签到)

    在这里插入图片描述

    部分核心代码

    注册页面

    /**
     * 注册
     */
    
    public class RegisterActivity extends BaseActivity {
        private static final String TAG = "RegisterActivity";
        private Toolbar mToolbar;
        private AppCompatEditText et_user_name, et_user_pswd;
        private UserDao mUserInfoDao;
    
        @Override
        protected int getLayoutId() {
            return R.layout.activity_register;
        }
    
        @Override
        protected void initViews() {
            mToolbar = findViewById(R.id.toolbar);
            et_user_name = findViewById(R.id.et_user_name);
            et_user_pswd = findViewById(R.id.et_user_pswd);
    
            if (mUserInfoDao == null) {
                mUserInfoDao = new UserDao(this);
            }
        }
    
        @Override
        protected void setListener() {
            mToolbar.setNavigationOnClickListener(new View.OnClickListener() {
                @Override
                public void onClick(View v) {
                    finish();
                }
            });
        }
    
        @Override
        protected void initData() {
    
            findViewById(R.id.btn_register).setOnClickListener(new View.OnClickListener() {
                @Override
                public void onClick(View v) {
    
                    String name = et_user_name.getText().toString().trim();
                    String pawsd = et_user_pswd.getText().toString().trim();
                    if (TextUtils.isEmpty(name)) {
                        BastToast("请输入用户名");
                    } else if (TextUtils.isEmpty(pawsd)) {
                        BastToast("请输入密码");
                    } else {
                        int insert = mUserInfoDao.insert(name, pawsd, "", "今天你微笑了吗", "90分", "上海市", "北京市", "教师", "未婚", "xxx","xxx");
    
                        if (insert != -1) {
                            BastToast("注册成功");
                            finish();
                        } else {
                            BastToast("注册失败");
                        }
                    }
                }
            });
    
        }
    }
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 17
    • 18
    • 19
    • 20
    • 21
    • 22
    • 23
    • 24
    • 25
    • 26
    • 27
    • 28
    • 29
    • 30
    • 31
    • 32
    • 33
    • 34
    • 35
    • 36
    • 37
    • 38
    • 39
    • 40
    • 41
    • 42
    • 43
    • 44
    • 45
    • 46
    • 47
    • 48
    • 49
    • 50
    • 51
    • 52
    • 53
    • 54
    • 55
    • 56
    • 57
    • 58
    • 59
    • 60
    • 61
    • 62
    • 63
    • 64

    学生管理页面

    public class StudentActivity extends BaseActivity {
        static final int CODE = 200;
        private Toolbar mToolbar;
        private RecyclerView mRecyclerView;
        private DelateDialog mDelateDialog;
        private StudentAdapter mStudentAdapter;
    
        private StudioDao mStudioDao;
    
        @Override
        protected int getLayoutId() {
            return R.layout.activity_student;
        }
    
        @Override
        protected void initViews() {
            if (mStudioDao == null) {
                mStudioDao = new StudioDao(this);
            }
    
    
            mToolbar = findViewById(R.id.toolbar);
            mRecyclerView = findViewById(R.id.recyclerView);
            mStudentAdapter = new StudentAdapter();
            mRecyclerView.setAdapter(mStudentAdapter);
    
            showLoading();
        }
    
        @Override
        protected void setListener() {
            mToolbar.setNavigationOnClickListener(new View.OnClickListener() {
                @Override
                public void onClick(View v) {
                    finish();
                }
            });
    
            findViewById(R.id.btn_add).setOnClickListener(new View.OnClickListener() {
                @Override
                public void onClick(View v) {
                    startActivityForResult(new Intent(StudentActivity.this, AddStudentActivity.class), CODE);
    
                }
            });
    
    
            mStudentAdapter.setOnItemClickListener(new OnItemClickListener() {
                @Override
                public void onItemClick(@NonNull BaseQuickAdapter<?, ?> adapter, @NonNull View view, int position) {
                    Intent intent = new Intent(StudentActivity.this, UpdateStudentActivity.class);
                    intent.putExtra("info", mStudioDao.queryAll().get(position));
                    startActivityForResult(intent, CODE);
                }
            });
    
    
            mStudentAdapter.setOnItemLongClickListener(new OnItemLongClickListener() {
                @Override
                public boolean onItemLongClick(@NonNull BaseQuickAdapter adapter, @NonNull View view, int position) {
    
                    StudentBean bean = mStudioDao.queryAll().get(position);
                    if (mDelateDialog == null) {
                        mDelateDialog = new DelateDialog(StudentActivity.this);
    
                    }
                    mDelateDialog.setDelateListener(new DelateDialog.DelateListener() {
                        @Override
                        public void delate() {
                            int delate = mStudioDao.delate(bean.getStudent_name());
                            if (delate == 1) {
                                BastToast("删除成功");
                            } else {
                                BastToast("删除失败");
                            }
                            mDelateDialog.dismiss();
                            mStudentAdapter.setNewInstance(mStudioDao.queryAll());
                        }
                    });
    
                    mDelateDialog.show();
    
    
                    return false;
                }
            });
    
    
        }
    
        @Override
        protected void initData() {
            new Handler().postDelayed(new Runnable() {
                @Override
                public void run() {
                    mStudentAdapter.setNewInstance(mStudioDao.queryAll());
                    hiddenDialog();
                }
            }, 200);
        }
    
        @Override
        protected void onActivityResult(int requestCode, int resultCode, @Nullable Intent data) {
            super.onActivityResult(requestCode, resultCode, data);
            if (data != null && resultCode == CODE) {
                mStudentAdapter.setNewInstance(mStudioDao.queryAll());
            }
    
        }
    }
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 17
    • 18
    • 19
    • 20
    • 21
    • 22
    • 23
    • 24
    • 25
    • 26
    • 27
    • 28
    • 29
    • 30
    • 31
    • 32
    • 33
    • 34
    • 35
    • 36
    • 37
    • 38
    • 39
    • 40
    • 41
    • 42
    • 43
    • 44
    • 45
    • 46
    • 47
    • 48
    • 49
    • 50
    • 51
    • 52
    • 53
    • 54
    • 55
    • 56
    • 57
    • 58
    • 59
    • 60
    • 61
    • 62
    • 63
    • 64
    • 65
    • 66
    • 67
    • 68
    • 69
    • 70
    • 71
    • 72
    • 73
    • 74
    • 75
    • 76
    • 77
    • 78
    • 79
    • 80
    • 81
    • 82
    • 83
    • 84
    • 85
    • 86
    • 87
    • 88
    • 89
    • 90
    • 91
    • 92
    • 93
    • 94
    • 95
    • 96
    • 97
    • 98
    • 99
    • 100
    • 101
    • 102
    • 103
    • 104
    • 105
    • 106
    • 107
    • 108
    • 109
    • 110

    个人中心页面

    public class CenterActivity extends BaseActivity {
        private TextView username, signature, credit, home, hometown, professional, status, school, school_scl;
        private TextView edit;
    
        @Override
        protected int getLayoutId() {
            return R.layout.activity_center;
        }
    
        @Override
        protected void initViews() {
    
            signature = findViewById(R.id.signature);
            username = findViewById(R.id.username);
            edit = findViewById(R.id.edit);
            credit = findViewById(R.id.credit);
            home = findViewById(R.id.home);
            hometown = findViewById(R.id.hometown);
            professional = findViewById(R.id.professional);
            status = findViewById(R.id.status);
            school = findViewById(R.id.school);
            school_scl = findViewById(R.id.school_scl);
    
        }
    
        @Override
        protected void setListener() {
    
            edit.setOnClickListener(new View.OnClickListener() {
                @Override
                public void onClick(View v) {
                    Intent intent = new Intent(CenterActivity.this, EditActivity.class);
                    startActivityForResult(intent, 200);
                }
            });
    
        }
    
        @SuppressLint("SetTextI18n")
        @Override
        protected void initData() {
    
            UserInfo info = SPUtils.getObject(this, "userInfo", UserInfo.class);
            if (null != info) {
                signature.setText("个性签名:" + info.getSignature());
                username.setText("用户名:" + info.getUserName());
                credit.setText("信用:" + info.getCredit());
                home.setText("所在地:" + info.getHome());
                hometown.setText("家乡:" + info.getHometown());
                professional.setText("职业:" + info.getProfessional());
                status.setText("感情状况:" + info.getStatus());
                school.setText("学校:" + info.getSchool());
                school_scl.setText("专业:" + info.getSchool_scl());
            }
    
        }
    
        @Override
        public void onActivityResult(int requestCode, int resultCode, @Nullable Intent data) {
            super.onActivityResult(requestCode, resultCode, data);
            if (null != data && resultCode == 200) {
                initData();
            }
        }
    }
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 17
    • 18
    • 19
    • 20
    • 21
    • 22
    • 23
    • 24
    • 25
    • 26
    • 27
    • 28
    • 29
    • 30
    • 31
    • 32
    • 33
    • 34
    • 35
    • 36
    • 37
    • 38
    • 39
    • 40
    • 41
    • 42
    • 43
    • 44
    • 45
    • 46
    • 47
    • 48
    • 49
    • 50
    • 51
    • 52
    • 53
    • 54
    • 55
    • 56
    • 57
    • 58
    • 59
    • 60
    • 61
    • 62
    • 63
    • 64
    • 65
  • 相关阅读:
    从编译器对指令集的要求看API设计原则
    【实战技能】单片机bootloader的CANFD,I2C,SPI和串口方式更新APP视频教程(2022-08-01)
    依赖版本界限
    罗强:腾讯新闻如何处理海量商业化数据?
    自然语言处理部分内容---NLP
    学生DW静态网页设计——html+css+javascript+jquery+bootstarp马尔代夫旅游响应式网站
    基于虚拟机源码分析move合约(一):本地变量
    2022年SQL经典面试题总结(带解析)
    LeetCode.565. 数组嵌套____暴力dfs->剪枝dfs->原地修改
    MM-Camera架构-ProcessCaptureRequest 流程分析
  • 原文地址:https://blog.csdn.net/jky_yihuangxing/article/details/127982194