期末课设报告

一. 设计目的 4

二. 需求分析 4

2.1技术可行性分析: 4

2.2应用可行性分析 4

通讯录是人们生活中必不可少的应用软件;有了通讯录寻找联系人或者是及时修改联系人信息都是很方便的;所以我通过自己本学期所学编制了这个简易的通讯录应用,希望可以在以后能够实现一个更加完整的通讯录系统。 4

2.3 UML 4

2.3.1 用例分析 4

到通讯录界面。 4

4.通讯录界面:在此界面可输入通讯录的信息如姓名、手机号以及地址信 4

2.3.2uml需求用例图 5

三. 总体设计 6

3.1 系统结构图 6

3.2 UI图 7

1.首页 7

2.登录及注册界面 7

3.通讯录界面 7

四.系统测试 10

4.1 测试添加信息能否添加到数据库 10

4.2测试查询按钮能否查询数据库 11

4.3测试修改按钮能否修改数据库信息 12

4.5测试删除按钮是否能删除数据库信息 13

五. 系统实现以及重要代码 13

5.1 增删改查界面实现 13

5.2 创建数据库 17

5.3 listview 18

六. 项目总结 19

一.设计目的

(1).熟悉androidstutio工具及相关java组件的灵活应用,对本学期老师所讲内容进行熟练操作并且得以巩固。

(2).通过此次作业编制一个基础能运行的小的应用程序,对此进行基本的增删改查练习,为以后能够编制完整的程序打下一个基础。

(3).提高自身实践操作的能力,把理论现实相结合进行操作。提高自己的编程水平。

二.需求分析

2.1技术可行性分析:

利用我们本学期所学过的Android开发的一些简单知识运行环境Android studio并进行虚拟机的演示。

2.2应用可行性分析

通讯录是人们生活中必不可少的应用软件;有了通讯录寻找联系人或者是及时修改联系人信息都是很方便的;所以我通过自己本学期所学编制了这个简易的通讯录应用,希望可以在以后能够实现一个更加完整的通讯录系统。

2.3 UML

2.3.1 用例分析

1.首页:进入登录界面或者选择直接退出应用。

2.登录界面:有账号可以登录,没有账号注册登录。

3.注册界面:对使用者的手机号、账号以及密码进行注册;成功后可进入到通讯录界面。

4.通讯录界面:在此界面可输入通讯录的信息如姓名、手机号以及地址并且在此界面能进行增删改查的操作。点击添加可以添加填好的联系

人信息;点击查询可以直接查询出所添加的信息;更改

信息根据联系人姓名对信息进行更改,改过后可以直接查询信

息;删除界面是通过联系人姓名进行删除操作;删除后也可在

界面进行信息查询。

2.3.2uml需求用例图

三. 总体设计

 3.1 系统结构图

3.2 UI图

1.首页

2.登录及注册界面

登录界面,在点击注册后进入注册界面然后可以输入手机号等信息。

3.通讯录界面

通讯录操作初始界面。

通讯录添加信息界面

通讯录查询界面

(采用了listview)

通讯录修改以及修改后查询界面

删除界面

删除界面是按照通讯录添加的姓名进行删除

四.系统测试

本次课程设计所用的开发环境为:androidstudio3.4.1

开发技术:Android

数据库:SQLite数据库

4.1 测试添加信息能否添加到数据库

添加成功

4.2测试查询按钮能否查询数据库

查询成功

4.3测试修改按钮能否修改数据库信息

修改成功 测试正常。

4.5测试删除按钮是否能删除数据库信息

通过删除后查询可见,想删除的刘子璇信息已经删除,测试成功。

五.系统实现以及重要代码

5.1 增删改查界面实现

该通讯录的添加、查询、修改、删除的操作都在同一界面显示;所以java代码的展示如下:

package com.example.zix;
import androidx.appcompat.app.AlertDialog;
import androidx.appcompat.app.AppCompatActivity;

import android.content.ContentValues;
import android.content.DialogInterface;
import android.database.Cursor;
import android.database.sqlite.SQLiteDatabase;
import android.os.Bundle;
import android.util.Log;
import android.view.View;
import android.widget.Button;
import android.widget.EditText;
import android.widget.ListView;
import android.widget.Toast;

import com.example.zix.R;
import com.example.zix.mydbhelp;

import java.util.ArrayList;
import java.util.List;
public class MainActivity extends AppCompatActivity implements View.OnClickListener {
    private EditText et_n,et_p,et_nu;
    private ListView listView;
    private String name,price,number;
    private mydbhelp mydb;
    private SQLiteDatabase db;
    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);
        def();

}
    public  void def(){
        et_n = (EditText)findViewById(R.id.et_name);
        et_p =  (EditText)findViewById(R.id.et_price);
        et_nu =  (EditText) findViewById(R.id.et_number);
        listView = (ListView)findViewById(R.id.listView);
        Button add = (Button)findViewById(R.id.add);
        Button query =(Button) findViewById(R.id.query);
        Button update =(Button) findViewById(R.id.update);
        Button delete = (Button)findViewById(R.id.delete);
        add.setOnClickListener(this);
        query.setOnClickListener(this);
        update.setOnClickListener(this);
        delete.setOnClickListener(this);
        mydb = new mydbhelp(this);

}
    @Override
    public void onClick(View v) {
        switch (v.getId()){
            case R.id.add:
                db = mydb.getWritableDatabase();
                name = et_n.getText().toString();
                price = et_p.getText().toString();
                number = et_nu.getText().toString();
                ContentValues values = new ContentValues();
                values.put("name", name);
                values.put("price", price);
                values.put("number", number);
                db.insert("cart", null, values);
                db.close();
                Toast.makeText(this, "已添加通讯录", Toast.LENGTH_SHORT).show();
                break;
            case R.id.query:
                List<dxl> list = new ArrayList();
                db = mydb.getWritableDatabase();
                Cursor cursor = db.query("cart", null, null, null, null,
                        null, null);
                if (cursor.getCount() == 0) {
                    Toast.makeText(this, "联系人不存在", Toast.LENGTH_SHORT).show();
                } else {
                    while (cursor.moveToNext()) {
                        dxl dy = new dxl();
                        int nameIndex = cursor.getColumnIndex("name");
                        int priceIndex = cursor.getColumnIndex("price");
                        int numberIndex = cursor.getColumnIndex("number");
                        String name = cursor.getString(nameIndex);
                        String price = cursor.getString(priceIndex);
                        String number = cursor.getString(numberIndex);
                        dy.setName(name);
                        dy.setPrice(price);
                        dy.setNumber(number);
                        list.add(dy);
                    }
                    myadapter adapter = new myadapter(MainActivity.this,list);
                    listView.setAdapter(adapter);
                    adapter.notifyDataSetChanged();
                }
                cursor.close();
                db.close();
                break;
            case  R.id.update:
                name = et_n.getText().toString();
                price = et_p.getText().toString();
                number = et_nu.getText().toString();
                db = mydb.getWritableDatabase();
                values = new ContentValues();
                values.put("number",number);
                values.put("price",price);
                db.update("cart", values, "name=?",
                        new String[]{name});
                db.close();
                Toast.makeText(this, "联系人信息已经修改", Toast.LENGTH_SHORT).show();
                break;
            case R.id.delete:
                AlertDialog dialog;
                final EditText editText=new EditText(MainActivity.this);
                editText.setText("");
                editText.setEnabled(true);

AlertDialog.Builder builder=newAlertDialog.Builder(MainActivity.this).setTitle("请输入删除联系人姓名   ").setView(editText).setIcon(R.drawable.bs).setPositiveButton("确定", new DialogInterface.OnClickListener() {
 @Override
     public void onClick(DialogInterface dialog, int which) {
        String hgu=editText.getText().toString();
                        //删除实现
        db = mydb.getWritableDatabase();
                       // db.execSQL("delete * from cart where name ="+hgu);

         db.delete("cart", "name =?",new String[]{hgu});
         db.close() dialog.dismiss();}
                }).setNegativeButton("取消", new DialogInterface.OnClickListener() {
 @Override
      public void onClick(DialogInterface dialog, int which) {
                        dialog.dismiss();
                    }
                });
                dialog=builder.create();
                dialog.show();
                List<dxl> list2 = new ArrayList();
                myadapter adapter = new myadapter(MainActivity.this,list2);
                listView.setAdapter(adapter);
                adapter.notifyDataSetChanged();
                Toast.makeText(this, "已删除联系人", Toast.LENGTH_SHORT).show();
                break;
        }
    }
}

5.2 创建数据库

cart表:


_Id


Name


Price


Number


主键_id


无外键

 

package com.example.zix;

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

import androidx.annotation.Nullable;

public class mydbhelp extends SQLiteOpenHelper {
    public mydbhelp(@Nullable Context context) {
        super(context, "jwc.db", null, 1);
    }
    @Override
    public void onCreate(SQLiteDatabase db) {
        String sql = "CREATE TABLE cart(_id INTEGER PRIMARY KEY AUTOINCREMENT, name VARCHAR(20),  price VARCHAR(20), number VARCHAR(20))";
        db.execSQL(sql);
    }
    @Override
    public void onUpgrade(SQLiteDatabase db, int oldVersion, int newVersion) {
    }

 

5.3 listview

package com.example.zix;

import android.content.Context;
import android.util.Log;
import android.view.LayoutInflater;
import android.view.View;
import android.view.ViewGroup;
import android.widget.BaseAdapter;
import android.widget.TextView;

import java.util.List;

public class myadapter extends BaseAdapter {
    private List<dxl> list;
    private LayoutInflater layoutInflater;
    public myadapter(Context context, List<dxl> list){
        this.layoutInflater = LayoutInflater.from(context);
        this.list = list;
    }
    @Override
    public int getCount() {
        Log.e("yanwenhua","list.size()--"+list.size());
        return list.size();
    }

@Override
    public Object getItem(int position) {
        return null;
    }

@Override
    public long getItemId(int position) {
        return 0;
    }

@Override
    public View getView(int position, View convertView, ViewGroup parent) {
        ViewHolder viewHolder;
        if (convertView==null){
            convertView=layoutInflater.inflate(R.layout.list,null);
            viewHolder=new ViewHolder(convertView);
            convertView.setTag(viewHolder);
        }else {
            viewHolder=(ViewHolder) convertView.getTag();
        }
        dxl dxl = list.get(position);
        viewHolder.tv_name.setText("联系人姓名:"+dxl.getName());
        viewHolder.tv_price.setText("联系人手机号:"+dxl.getPrice());
        viewHolder.tv_number.setText("联系人住址:"+dxl.getNumber());
        Log.e("yanwenhua","cartBean.getName()-"+dxl.getName()+"  "+dxl.getPrice()+"  "+dxl.getNumber());
        return convertView;
    }
    class ViewHolder{
        TextView tv_name;
        TextView tv_price;
        TextView tv_number;
        public ViewHolder(View view){
            tv_name = (TextView) view.findViewById(R.id.tv_name);
            tv_price = (TextView) view.findViewById(R.id.tv_price);
            tv_number = (TextView) view.findViewById(R.id.tv_number);
        }
    }

}

六.项目总结

此次课程设计,我通过本学期课上所学的Android以及之前所学java等知识实现了一个通讯录的运行;但是功能仅限于添加、查询、修改以及删除,我会在以后继续学习编程的知识熟练自己技术去完善这个项目;当然,对一门新的android开发领域,在课堂以及自己学习过程中,比想象要困难的多。为了在短时间内投入到开发,完成项目,需要花大量的时间去学习,动手编程,掌握开发中的各种控件的使用,理解了Android开发框架,学习SQLite数据库的使用。

在完成课设的路上,我遇到了许多困难,比如在搭建界面时候各个控件的使用,如何合理设置布局让界面变的美观;还有就是listview的使用,通过查询书籍和网络搜索得到解决;在我进行删除按钮实现的时候不知如何才能按名字删除信息,询问了身边的同学,协助我将问题解决并成功实现。

编程时思路一定要清楚。因为编程本身就是一个严密的逻辑过程,实现每一步的操作需要那些命令,哪些条件都是清清楚楚,明明了了的,来不得半点遗漏。这次课程设计是对自己的一个挑战,,在经过努力,遇到的问题最终一步步都解决了。完成课程设计,受益匪浅,我相信它会对我以后的人生和工作起到很好的促进作用,有着积极的影响。

原文地址:https://www.cnblogs.com/akaxuan/p/12034427.html

时间: 2024-10-08 09:13:05

期末课设报告的相关文章

私厨--课设报告

Android应用程序开发 课程设计报告 (2019—2020学年 第Ⅰ学期) 基于Android的家庭菜谱系统 系    别            信息与控制工程 专    业           计算机科学与技术 班    级                1701 姓    名              荣瑞瑞 指导教师                郭 丹 目录 TOC \o "1-2" \h \u 一.摘要 1 二.课设题目 1 三.系统设计 2 四.系统测试 6 五.系统实

Java期末课设课前学习

Java课设课前学习 1.Markdown的使用 2.MySQL数据库的使用 MySQL数据库软件 1.安装 2.卸载 3.配置 *MySQL服务启动 1. 使用管理员打开cmd * net start mysql : 启动mysql的服务 * net stop mysql : 关闭mysql的服务 *MySQL登陆 1.mysql -uroot -proot mysql -uroot -p 输入密码 2.mysql -hip -uroot -p连接目标的密码 3.mysql --host=12

安卓课设报告

                                                                                              安卓课程设计报告                                                                                                  记账管理系统                                            

Android课设报告 123 赵乾

基于Android的天喵购物系统设计与实现 一,选题目的及意义 随着智能手机的普及,基于Android平台的应用软件需求也越来越多.通过计算机系统的设计与开发,验证和扩展本科前三年所学相关课程的理论知识,在实践中深入理解其中的重点和难点,提高基本理论水平,巩固基础知识体系,掌握计算机系统设计与开发的基本技能,培养灵活运用理论知识分析和解决实际问题的能力. 当下我们处于大数据网络时代,无疑,网上购物脱颖而出,即马云阿里巴巴成立以来,网上购物成为人民日益需求的购物来源,而其简单便捷,足不出户便能买到

学生管理系统课设报告

一. 课程设计概述 1.1任务背景 学生信息管理是学校管理中异常重要的一个环节,作为学校,除了育人,就是育知,学生信息管理的计算机化是整个学校教务管理中的重要一部分,能否实现这一步关系到学校办学整体效率的高低,由于它的重要性,学生信息管理系统的开发与应用就逐渐提入议程,并占着越来越重要的份量.  运用学生信息管理系统可以减轻学院教学人员的工作量,缩小开支,提高工作效率与准确率,能够合理安排时间,能够尽快的知道自己的考试成绩,投入新的课程的学习或复习这次没有考过的课程.而学生信息管理系统的应用也为

排序算法及其比较--数据结构课设

 排序算法及其比较 课程设计报告 一. 设计内容 编程实现希尔.快速.堆排序.归并排序算法,并利用程序统计每种算法的执行时间.要求随机产生10000(或50000. 100000. 200000,由用户选择)个数据存入数据文件,然后读数据文件,分别采用不同排序方法进行排序,将结果存入另一个文件中. 二. 设计思想描述 1.  总思想 本程序采用模块化设计思想,分为产生随机数模块,计时模块,写入磁盘模块,读出磁盘模块,希尔排序模块,快速排序模块,堆排序模块,归并排序模块,计时模块.对常见的4 种经

软件课设第二十二天 9.9

今天完成的任务: 1.完成了部分课设报告的内容: 2.在supervisely上完成了人像图片的标注,规定了训练代码的参数. 明天的计划: 1.完成训练权重的校对和测试部分的图片集标注: 2.对训练好的权重进行校对和测试. 每日小结: 今天正式开始了书写课设报告的工作,通过博客园上每天的随笔,我们回顾了过去半个多月来我们的工作历程,我的工作就是将其中最重要的部分放到课设报告中,希望最终的报告能对得起我们这半个多月来的努力. 原文地址:https://www.cnblogs.com/yoona56

编译原理课设参考

期末到了,忙课设好久了,在编译原理的课设上面走了好多的弯路,也好久没有碰前端的东西了,心感惭愧,那我就把我最近忙的一些东西贡献出来,希望可以帮助到那些感觉这门科目很难的同学,祝大家可以学好每一门学科~ 下面是我们学校的学习要求,我全部已经完成,时间仓促,大家仅供参考.转载请注明出处. 基本内容(成绩范围:“中”.“及格”或“不及格”) (1)扩充赋值运算:+=,-=, *= 和 /= (2)扩充语句(Pascal的FOR语句): FOR <变量>:=<表达式>STEP<表达式

由课设和面向对象想到的一些东西 2015-05-29

前些天草草的把Java课本(学校老师自编课本)浏览了一遍,最近正在看<Java核心技术>,感觉书有点儿难度.正在努力理解接口和异常. 我 刚接触编程时,就已经听说了“面向对象编程”这个概念,但完全不能理解.百度相关信息,只能得到一些“哲学答案”,比如“万物皆对象”等等.我问学长学 姐,他们给我的答案也都模棱两可.现在学完C语言后,终于能初步感受到面向对象的思想了.所以我的感受是,有些不懂的东西不需要太着急,可能是自己还没有 学会基础的东西,学着学着慢慢就懂了.同时我也觉得C语言入门虽然难且艰辛