栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 软件开发 > 移动开发 > Android

Android个人手机通讯录开发详解

Android 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

Android个人手机通讯录开发详解

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

数据存储:SQLite 数据库

开发工具:Android Studio

二、Phone Module 简介

1. 界面展示

2. 文件结构简单分析

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

1. 清单文件 (AndroidManifest.xml)




 
  
   
    

    
   
  
 

2. MainActivity.java (主文件)



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 (数据库文件)



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

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

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

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

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

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

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

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

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

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

联系人查询重点代码:

//查询联系人

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

转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/155031.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号