一、Android 个人手机通讯录开发

  数据存储:SQLite 数据库

  开发工具:Android Studio

二、Phone Module 简介

1. 界面展示

              

 

2. 文件结构简单分析

 

三、个人手机通讯录代码实现

1. 清单文件 (AndroidManifest.xml)

<?xml version="1.0" encoding="utf-8"?>                                                                                

 

 2. MainActivity.java (主文件)

/** * Created by Alan J on 13/2/2019. */package com.example.alan.directory;import android.database.Cursor;import android.database.sqlite.SQLiteDatabase;import android.support.v7.app.AppCompatActivity;import android.os.Bundle;import android.text.method.ScrollingMovementMethod;import android.view.View;import android.widget.Button;import android.widget.EditText;import android.widget.TextView;import android.widget.Toast;public class MainActivity extends AppCompatActivity implements View.OnClickListener{    MyHelper myHelper;    private EditText etName;    private EditText etPhone;    private TextView tvShow;    private Button btnAdd;    private Button btnQuery;    private Button btnUpdate;    private Button btnDelete;    @Override    protected void onCreate(Bundle savedInstanceState) {        super.onCreate(savedInstanceState);        setContentView(R.layout.activity_main);        myHelper = new MyHelper(this);        init(); //初始化控件    }    private void init(){        etName = (EditText)findViewById(R.id.et_name);        etPhone = (EditText)findViewById(R.id.et_phone);        tvShow = (TextView)findViewById(R.id.tv_show);        btnAdd = (Button)findViewById(R.id.btn_add);        btnQuery = (Button)findViewById(R.id.btn_query);        btnUpdate = (Button)findViewById(R.id.btn_update);        btnDelete = (Button)findViewById(R.id.btn_delete);        btnAdd.setOnClickListener(this);          //Button控件设置监听        btnQuery.setOnClickListener(this);        btnUpdate.setOnClickListener(this);        btnDelete.setOnClickListener(this);        tvShow.setMovementMethod(ScrollingMovementMethod.getInstance());  //设置文本滚动    }    @Override    public void onClick(View v){        String name;        String phone;        SQLiteDatabase db;        switch (v.getId()){            case R.id.btn_add:       //添加联系人                name = etName.getText().toString().trim();                phone = etPhone.getText().toString().trim();                db = myHelper.getWritableDatabase();                if (name.equals("") || phone.equals("")){    //联系人信息不能为空                    Toast.makeText(this,"联系人信息添加失败",Toast.LENGTH_SHORT).show();                }                else {                    db.execSQL("insert into person (name,phone) values(?,?)", new Object[]{name, phone});                    Toast.makeText(this,"联系人信息添加成功",Toast.LENGTH_SHORT).show();                }                db.close();                break;            case R.id.btn_query:    //查询联系人                db = myHelper.getReadableDatabase();                Cursor cursor = db.rawQuery("select name,phone from person",null);                if (cursor.getCount() == 0){                    tvShow.setText("");                    Toast.makeText(this,"空目录",Toast.LENGTH_SHORT).show();                }else {                    cursor.moveToFirst();                    tvShow.setText("Name:" + cursor.getString(0) + " ; Tel:" + cursor.getString(1));                    while (cursor.moveToNext()){                        tvShow.append("\n" + "Name:" + cursor.getString(0) + " ; Tel:" + cursor.getString(1));                    }                }                cursor.close();                db.close();                break;            case R.id.btn_update:    //修改联系人                db = myHelper.getWritableDatabase();                name = etName.getText().toString().trim();                phone = etPhone.getText().toString().trim();                if (name.equals("") || phone.equals("")){    //联系人信息不能为空                    Toast.makeText(this,"联系人信息修改失败",Toast.LENGTH_SHORT).show();                }                else {                    db.execSQL("update person set name=?,phone=? where name=?", new Object[]{name, phone, name});                    Toast.makeText(this,"联系人信息修改成功",Toast.LENGTH_SHORT).show();                }                db.close();                break;            case R.id.btn_delete:   //删除联系人                db = myHelper.getWritableDatabase();                name = etName.getText().toString().trim();                phone = etPhone.getText().toString().trim();                if (name.equals("") || phone.equals("")){    //联系人信息不能为空                    Toast.makeText(this,"联系人信息删除失败",Toast.LENGTH_SHORT).show();                }                else {                    db.execSQL("delete from person where name=? and phone=?", new Object[]{name, phone});                    Toast.makeText(this,"联系人信息删除成功",Toast.LENGTH_SHORT).show();                }                db.close();                break;        }    }}

 

3. MyHelper.java (数据库文件)

/** * Created by Alan J on 13/2/2019. */package com.example.alan.directory;import android.content.Context;import android.database.sqlite.SQLiteDatabase;import android.database.sqlite.SQLiteOpenHelper;public class MyHelper extends SQLiteOpenHelper{    public MyHelper(Context context){        super(context, "alan.db", null ,2);    }    @Override    public void onCreate(SQLiteDatabase db){        db.execSQL("create table person(id integer primary key autoincrement,name varchar(20),phone varchar(20) unique)");    }    public void onUpgrade(SQLiteDatabase db, int oldVersion, int newVersion){    }}

 

4. activity_main.xml (XML Layout 布局文件)

<?xml version="1.0" encoding="utf-8"?>                                                                                    

 

5. shape.xml (Button 按钮设置)

<?xml version="1.0" encoding="utf-8" ?>                        

 

四、Android 个人通讯录功能测试

1. 添加

 分别添加联系人:姓名:小 明    电话:13888899922

         姓名:小 莉    电话:15866655588

 添加联系人功能验证:姓名:小 明    电话:13888899922

             

 

添加联系人功能验证:姓名:小 莉    电话:15866655588

            

 

 测试中的一些问题:1. 联系人电话号码不能重复添加,程序会终止退出,因为联系人的电话号码是唯一的(一个人可以有多个手机号,而一个手机号只能一个人使用 {该功能程序已经实现} )。

          2. 电话号码长度限制为11位。

          3. 联系人信息为空不能成功添加。

再次添加联系人:姓名:小 莉    电话:15866655588

                        

 

上述功能问题限制的重点代码如下:

//联系人电话号码唯一性@Overridepublic void onCreate(SQLiteDatabase db){        db.execSQL("create table person(id integer primary key autoincrement,name varchar(20),phone varchar(20) unique)");}//电话号码长度限制//联系人信息为空时的限制        case R.id.btn_add:       //添加联系人                name = etName.getText().toString().trim();                phone = etPhone.getText().toString().trim();                db = myHelper.getWritableDatabase();                if (name.equals("") || phone.equals("")){    //联系人信息不能为空                    Toast.makeText(this,"联系人信息添加失败",Toast.LENGTH_SHORT).show();                }                else {                    db.execSQL("insert into person (name,phone) values(?,?)", new Object[]{name, phone});                    Toast.makeText(this,"联系人信息添加成功",Toast.LENGTH_SHORT).show();                }                db.close();                break;

 

2. 查询

查询通讯录联系人功能验证:

            

 

联系人查询重点代码:

//查询联系人      case R.id.btn_query:                    db = myHelper.getReadableDatabase();                Cursor cursor = db.rawQuery("select name,phone from person",null);                if (cursor.getCount() == 0){                    tvShow.setText("");                    Toast.makeText(this,"空目录",Toast.LENGTH_SHORT).show();                }else {                    cursor.moveToFirst();                    tvShow.setText("Name:" + cursor.getString(0) + " ; Tel:" + cursor.getString(1));                    while (cursor.moveToNext()){                        tvShow.append("\n" + "Name:" + cursor.getString(0) + " ; Tel:" + cursor.getString(1));                    }                }                cursor.close();                db.close();                break;

 

3. 修改

修改联系人功能验证:姓名:小 明    电话:13888899922   ===》》》  姓名:小 明    电话:15888899922

注意小问题:必须输入联系人姓名和电话号码,才可以成功进行修改,在数据库中修改一句name字段值进行匹配

            

 

联系人修改重点代码:

//修改联系人      case R.id.btn_update:                    db = myHelper.getWritableDatabase();                name = etName.getText().toString().trim();                phone = etPhone.getText().toString().trim();                if (name.equals("") || phone.equals("")){    //联系人信息不能为空                    Toast.makeText(this,"联系人信息修改失败",Toast.LENGTH_SHORT).show();                }                else {                    db.execSQL("update person set name=?,phone=? where name=?", new Object[]{name, phone, name});                    Toast.makeText(this,"联系人信息修改成功",Toast.LENGTH_SHORT).show();                }                db.close();                break;

 

测试中的一些问题:联系人为空时不能进行修改

            

 

上述功能问题限制的重点代码如下:

         if (name.equals("") || phone.equals("")){    //联系人信息不能为空                    Toast.makeText(this,"联系人信息修改失败",Toast.LENGTH_SHORT).show();                }                else {                    db.execSQL("update person set name=?,phone=? where name=?", new Object[]{name, phone, name});                    Toast.makeText(this,"联系人信息修改成功",Toast.LENGTH_SHORT).show();                }

 

4. 删除

 删除联系人功能验证:姓名:小 明    电话:15888899922

                        

 

联系人删除重点代码:

//删除联系人       case R.id.btn_delete:                   db = myHelper.getWritableDatabase();                name = etName.getText().toString().trim();                phone = etPhone.getText().toString().trim();                if (name.equals("") || phone.equals("")){    //联系人信息不能为空                    Toast.makeText(this,"联系人信息删除失败",Toast.LENGTH_SHORT).show();                }                else {                    db.execSQL("delete from person where name=? and phone=?", new Object[]{name, phone});                    Toast.makeText(this,"联系人信息删除成功",Toast.LENGTH_SHORT).show();                }                db.close();                break;

 

测试中的一些问题:联系人为空时不能进行删除

 

 上述功能问题限制的重点代码如下:

         if (name.equals("") || phone.equals("")){    //联系人信息不能为空                    Toast.makeText(this,"联系人信息删除失败",Toast.LENGTH_SHORT).show();                }                else {                    db.execSQL("delete from person where name=? and phone=?", new Object[]{name, phone});                    Toast.makeText(this,"联系人信息删除成功",Toast.LENGTH_SHORT).show();                }

 

更多相关文章

  1. android 在新建短信时,加入名称为","(英文逗号)的联系人时,应用崩
  2. android webkit 打开debug调试信息
  3. Android调用系统短信功能发送短信
  4. Android(安卓)SDK Manager 更新时的“https://dl-ssl.google.com
  5. Android输入法之——如何禁止横屏时全屏http://blog.csdn.net/na
  6. android 修改系统程序图标大小
  7. Android向通讯录添加联系人的一般方法
  8. Android中日志信息的打印方式
  9. Android软件开发之获取通讯录联系人信息 + android联系人信息的

随机推荐

  1. 站在大神的肩膀上 - 简述Android应用启动
  2. 《Android(安卓)Dev Guide》系列教程10:用
  3. android的消息处理机制(图+源码分析)——Lo
  4. Android(安卓)JNI(java native interface
  5. Zipalign:一个简单的优化
  6. HelloWorld及Android项目结构介绍-JavaGG
  7. 在Android设备上搭建Web服务器的方法
  8. Android(安卓)Camera模块分析
  9. Android应用开发资源
  10. Android(安卓)Service