Android 个人手机通讯录开发

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

  数据存储:SQLite 数据库

  开发工具:Android Studio

二、Phone Module 简介

1. 界面展示

Android 个人手机通讯录开发_第1张图片              Android 个人手机通讯录开发_第2张图片

 

2. 文件结构简单分析

Android 个人手机通讯录开发_第3张图片

 

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

1. 清单文件 (AndroidManifest.xml)




    
        
            
                

                
            
        
    

 

 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 布局文件)



    
        
        
    
    
        
        
    
    
        
        
    
    
        

 

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




    
    

    
    

    
    

 

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

1. 添加

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

         姓名:小 莉    电话:15866655588

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

Android 个人手机通讯录开发_第4张图片             Android 个人手机通讯录开发_第5张图片

 

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

Android 个人手机通讯录开发_第6张图片            Android 个人手机通讯录开发_第7张图片

 

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

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

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

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

Android 个人手机通讯录开发_第8张图片            Android 个人手机通讯录开发_第9张图片            Android 个人手机通讯录开发_第10张图片

 

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

//联系人电话号码唯一性

@Override

public 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. 查询

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

Android 个人手机通讯录开发_第11张图片            Android 个人手机通讯录开发_第12张图片

 

联系人查询重点代码:

//查询联系人

      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字段值进行匹配

Android 个人手机通讯录开发_第13张图片            Android 个人手机通讯录开发_第14张图片

 

联系人修改重点代码:

//修改联系人

      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;

 

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

Android 个人手机通讯录开发_第15张图片            

 

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

         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

Android 个人手机通讯录开发_第16张图片            Android 个人手机通讯录开发_第17张图片            Android 个人手机通讯录开发_第18张图片

 

联系人删除重点代码:

//删除联系人

       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;

 

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

Android 个人手机通讯录开发_第19张图片

 

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

         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();
                }

 

你可能感兴趣的:(Android,移动开发,Android-------@,移动开发)