期末课设报告

Posted akaxuan

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了期末课设报告相关的知识,希望对你有一定的参考价值。

一. 设计目的 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的使用,通过查询书籍和网络搜索得到解决;在我进行删除按钮实现的时候不知如何才能按名字删除信息,询问了身边的同学,协助我将问题解决并成功实现。

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

以上是关于期末课设报告的主要内容,如果未能解决你的问题,请参考以下文章

Java期末课设课前学习

期末结转

数据结构课设之家谱管理系统暴肝四万字,看完你也可以

哀嚎遍野!学妹跟学弟分手了,因为JavaEE期末课设SSM太难了!呜呼哀哉!

哀嚎遍野!学妹跟学弟分手了,因为JavaEE期末课设SSM太难了!呜呼哀哉!

大二下小结与暑假展望