一. 设计目的 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