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

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

数据存储:SQLite 数据库

开发工具:Android Studio

二、Phone Module 简介

1. 界面展示

2. 文件结构简单分析

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

1. 清单文件 (AndroidManifest.xml)

<?xml version="1.0" encoding="utf-8"?>
<manifest xmlns:android="http://schemas.android.com/apk/res/android"
 package="com.example.alan.directory" >

 <application
  android:allowBackup="true"
  android:icon="@drawable/icon_phone"
  android:label="@string/app_name"
  android:supportsRtl="true"
  android:theme="@style/AppTheme" >
  <activity android:name=".MainActivity" >
   <intent-filter>
    <action android:name="android.intent.action.MAIN" />

    <category android:name="android.intent.category.LAUNCHER" />
   </intent-filter>
  </activity>
 </application>

</manifest>

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"?>
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
 xmlns:tools="http://schemas.android.com/tools"
 android:layout_width="match_parent"
 android:layout_height="match_parent"
 android:background="@drawable/background"
 tools:context=".MainActivity">
 <LinearLayout
  android:layout_width="match_parent"
  android:layout_height="wrap_content"
  android:id="@+id/lineOne">
  <ImageView
   android:layout_width="wrap_content"
   android:layout_height="wrap_content"
   android:background="@drawable/head"
   android:layout_margin="30dp"/>
  <TextView
   android:layout_width="wrap_content"
   android:layout_height="wrap_content"
   android:text="通 讯 录"
   android:textSize="30dp"
   android:textStyle="bold"
   android:textColor="#BC8F8F"
   android:layout_gravity="center"
   android:layout_marginLeft="50dp"
   />
 </LinearLayout>
 <LinearLayout
  android:id="@+id/lineTwo"
  android:layout_width="match_parent"
  android:layout_height="wrap_content"
  android:layout_below="@+id/lineOne"
  android:layout_marginTop="20dp"
  android:layout_marginLeft="18dp"
  android:layout_marginRight="18dp">
  <TextView
   android:layout_width="wrap_content"
   android:layout_height="wrap_content"
   android:text="姓 名 : "
   android:textSize="18dp"
   android:textStyle="bold"/>
  <EditText
   android:id="@+id/et_name"
   android:layout_width="match_parent"
   android:layout_height="wrap_content"
   android:hint="  请输入姓名"
   android:textSize="16dp"
   android:maxLength="14"/>
 </LinearLayout>
 <LinearLayout
  android:id="@+id/lineTree"
  android:layout_width="match_parent"
  android:layout_height="wrap_content"
  android:layout_below="@+id/lineTwo"
  android:layout_marginTop="10dp"
  android:layout_marginLeft="18dp"
  android:layout_marginRight="18dp">
  <TextView
   android:layout_width="wrap_content"
   android:layout_height="wrap_content"
   android:text="电 话 : "
   android:textSize="18dp"
   android:textStyle="bold"/>
  <EditText
   android:id="@+id/et_phone"
   android:layout_width="match_parent"
   android:layout_height="wrap_content"
   android:hint="  请输入手机号码"
   android:textSize="16dp"
   android:maxLength="11"/>
 </LinearLayout>
 <LinearLayout
  android:layout_width="match_parent"
  android:layout_height="wrap_content"
  android:id="@+id/lineFour"
  android:layout_below="@+id/lineTree"
  android:layout_marginTop="30dp"
  android:layout_marginLeft="18dp"
  android:layout_marginRight="18dp"
  android:orientation="horizontal">
  <Button
   android:id="@+id/btn_add"
   android:layout_width="wrap_content"
   android:layout_height="wrap_content"
   android:background="@drawable/shape"
   android:layout_weight="1"
   android:text=" 添 加 "
   android:textSize="16dp"
   android:textColor="#c2c8ec"
   android:textStyle="bold"/>
  <Button
   android:id="@+id/btn_query"
   android:layout_width="wrap_content"
   android:layout_height="wrap_content"
   android:background="@drawable/shape"
   android:layout_weight="1"
   android:layout_marginLeft="4dp"
   android:text=" 查 询 "
   android:textSize="16dp"
   android:textColor="#c2c8ec"
   android:textStyle="bold"/>
  <Button
   android:id="@+id/btn_update"
   android:layout_width="wrap_content"
   android:layout_height="wrap_content"
   android:background="@drawable/shape"
   android:layout_weight="1"
   android:layout_marginLeft="4dp"
   android:text=" 修 改 "
   android:textSize="16dp"
   android:textColor="#c2c8ec"
   android:textStyle="bold"/>
  <Button
   android:id="@+id/btn_delete"
   android:layout_width="wrap_content"
   android:layout_height="wrap_content"
   android:background="@drawable/shape"
   android:layout_weight="1"
   android:layout_marginLeft="4dp"
   android:text=" 删 除 "
   android:textSize="16dp"
   android:textColor="#c2c8ec"
   android:textStyle="bold"/>
 </LinearLayout>
 <TextView
  android:id="@+id/tv_show"
  android:layout_width="match_parent"
  android:layout_height="180dp"
  android:scrollbars="vertical"
  android:layout_below="@+id/lineFour"
  android:layout_marginTop="20dp"
  android:layout_marginLeft="20dp"
  android:layout_marginRight="18dp"
  android:textSize="20dp"/>
</RelativeLayout>

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

<?xml version="1.0" encoding="utf-8" ?>
<shape xmlns:android="http://schemas.android.com/apk/res/android"
 android:shape="rectangle">

 <!--设置背景色-->
 <solid android:color="#BC8F8F" />

 <!--设置圆角-->
 <corners android:radius="105dip" />

 <!--设置边框线的宽度和颜色-->
 <stroke android:width="0dp" android:color="#B0C4DE" />
</shape>

四、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)");
}

//电话号码长度限制

<EditText
 android:id="@+id/et_phone"
 android:layout_width="match_parent"
 android:layout_height="wrap_content"
 android:hint="  请输入手机号码"
 android:textSize="16dp"
 android:maxLength="11"/>

//联系人信息为空时的限制

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

相关推荐

  • Android编程操作手机通讯录的方法示例

    本文实例讲述了Android编程操作手机通讯录的方法.分享给大家供大家参考,具体如下: 手机通讯录的操作是经常被用到的,例如添加联系人,删除联系人或者取得联系人信息.类似的操作还有收藏夹的操作,下面就针对通讯录的操作来做个小例子.同样的这次也会使用到内容提供者的知识. 1. 要操作通信录就要得到授权,也就是读或者写通讯录的权力.这里也需要使用Junit <?xml version="1.0" encoding="utf-8"?> <manifest

  • android如何取得本地通讯录的头像的原图的实现代码

    本文介绍了android如何取得本地通讯录的头像的原图的实现代码,分享给大家,也给自己留个笔记 如果想通讯录进入详情页,那么最重要的参数就是contactId,这个是联系人的唯一标识 getListView().setOnItemClickListener(new AdapterView.OnItemClickListener() { @Override public void onItemClick(AdapterView<?> parent, View view, int position

  • Android开发之自定义view实现通讯录列表A~Z字母提示效果【附demo源码下载】

    本文实例讲述了Android开发之自定义view实现通讯录列表A~Z字母提示效果.分享给大家供大家参考,具体如下: 开发工具:eclipse 运行环境:htc G9 android2.3.3 话不多说,先看效果图 其实左右边的A~Z是一个自定义的View,它直接覆盖在ListView上. MyLetterListView: public class MyLetterListView extends View { OnTouchingLetterChangedListener onTouching

  • Android读取手机通讯录联系人到自己项目

    本文实例为大家分享了Android读取手机通讯录联系人到项目的具体代码,供大家参考,具体内容如下 一.主界面代码如下: <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android" android:layout_width="match_parent" android:layout_height="match_parent" android:orientat

  • android仿微信通讯录搜索示例(匹配拼音,字母,索引位置)

    前言: 仿微信通讯录搜索功能,通过汉字或拼音首字母找到匹配的联系人并显示匹配的位置 一:先看效果图 字母索引 搜索匹配 二:功能分析 1:汉字转拼音 通讯录汉字转拼音(首个字符当考虑姓氏多音字), 现在转换拼音常见的有pinyin4j和tinypinyin, pinyin4j的功能强大,包含声调多音字,tinypinyin执行快占用内存少, 如果只是简单匹配通讯录,建议使用tinypinyin,用法也很简单这里不详细介绍 拼音类 public class CNPinyin <T extends

  • Android仿手机通讯录地址选择功能

    感觉比较好的一个地址选择设计,而且发现有的App中也用到了.还是先上效果图 思路: 1.效果是仿照网上大神实现的类似通讯录样式做的: 2.右边a-z是自定义的一个bar,设置了点击监听事件,以及对话框弹出 3.关键是adapter,判断了字母显示和隐藏 4.用到汉字转拼音.按首字母排序等工具类 5.3个activity的跳转是用回调来实现,每个activity都实现了回调,这样就有了从区activity直接跳转到首页的效果 6.数据是调用的我本地的接口实现的,如果大家没有数据我可以想办法给你们提

  • Android Loader的使用以及手机通讯录的获取方法

    Android的主线程中执行长时间操作,导致界面无响应,会引起ANR.如果需要执行较长时间的操作,一般会在另一个线程处理,然后将数据转交给主线程进行显示,Android本身为我们提供了一些机制处理这种情况,今天就来看看Loader.Loader主要用来在Activity和Fragment中异步加载数据,使用也非常简单. Loader的初始化非常简单,Activity提供了获取LoaderManager的接口,之后调用LoaderManager的initLoader即可.initLoader接受三

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

    一.Android 个人手机通讯录开发 数据存储:SQLite 数据库 开发工具:Android Studio 二.Phone Module 简介 1. 界面展示 2. 文件结构简单分析 三.个人手机通讯录代码实现 1. 清单文件 (AndroidManifest.xml) <?xml version="1.0" encoding="utf-8"?> <manifest xmlns:android="http://schemas.andr

  • Android 获取手机信息实例详解

    Android 获取手机信息 应用信息:包名.版本号.版本名,手机是否有Root权限 手机信息:手机屏幕宽和高.当前可用内存大小.总内存大小.IMEI号.IESI号.手机型号.手机品牌.手机MacAdd.CPU型号.CPU频率 开门见山,以下是Java代码,XML只有一个TextView显示信息. package com.example.getphoneinfo; import java.io.BufferedReader; import java.io.File; import java.io

  • Android自定义动态壁纸开发详解

    看到有些手机酷炫的动态壁纸,有没有好奇过他们是如何实现的,其实我们自己也可以实现. 一.动态壁纸原理 如果你了解使用过SurfaceView的话,那么开发一款动态壁纸对你来说其实非常简单. 动态壁纸的本质其实就是一个服务在维护一个动态壁纸引擎Engine,所以我们看到的动态效果其实是通过这个引擎画出来的.而维护这个引擎的服务,就是WallpaperService.本篇文章并不讨论内部实现原理,只是让大家知道如何去实现动态壁纸,所以就不详细说了. 二.实现动态壁纸 大体上可分为三个步骤: 创建自定

  • React-native桥接Android原生开发详解

    在开发RN的漫漫长河中,早晚有那么一天要接触到安卓的原生开发,笔者来介绍一下其中的酸甜苦辣.对于一个不懂android的小白来说,刚开始有点难,不过都是万事开头难.语言是想通的,原理也是大径若一. 开发过程中是要集成高德的导航功能,没有找到好的轮子的,只要写原生代码,然后在用JS去调用原生的导航模块. 首先注册模块 其意义在与将类注册到RN中,才能用JS去调用 public class AnExampleReactPackage implements ReactPackage { @Overri

  • Android pdf viewer在android studio应用问题说明详解

    之前一直是做.NET开发的,最近需要弄一个新闻app,能力有限,只能借助HTML5 WebAPP+android studio来完成这项工作. android studio主要用WebView来加载发布好的WebApp,打包生产APP. 其中由于显示一些pdf文档,所以研究了一下,记录一下心得,同时也希望帮助到新手们. android 显示网络pdf,基本原理:先将pdf文件通过DownloadManager下载到手机sdk某个文件夹中,然后通过android-pdf-viewer插件进行显示.

  • Android NavigationController 右滑手势详解

    苹果一直都在人机交互中尽力做到极致,在iOS7中,新增加了一个小小的功能,也就是这个api:self.navigationController.interactivePopGestureRecognizer.enabled = YES; 这个api功能就是在NavigationController堆栈内的UIViewController可以支持右滑手势,也就是不用点击右上角的返回按钮,轻轻在屏幕左边一滑,屏幕就会返回,随着ios设备屏幕的增大,这个小功能让手指短,拇指大和手残人士看到了福音. 这

  • Android的搜索框架实例详解

    基础知识 Android的搜索框架将代您管理的搜索对话框,您不需要自己去开发一个搜索框,不需要担心要把搜索框放什么位置,也不需要担心搜索框影响您当前的界面.所有的这些工作都由SearchManager类来为您处理(以下简称"搜索管理器"),它管理的Android搜索对话框的整个生命周期,并执行您的应用程序将发送的搜索请求,返回相应的搜索关键字. 当用户执行一个搜索,搜索管理器将使用一个专门的Intent把搜索查询的关键字传给您在配置文件中配置的处理搜索结果的Activity.从本质上讲

  • Android 捕获运行时异常详解

    Android 捕获运行时异常详解 Android 异常分为两类:CheckedException 和 UnCheckedException CheckException:在编译代码时就需要进行try()catch捕获的. UnCheckException:所有的运行时异常,RuntimeException类和他的子类,都是在APP运行的过程中的发生的.即:APP在运行的过程中崩溃了,这种异常我们就成为运行时异常(比如空指针),当APP崩溃的时候,给用户的体验很不好,所以我们应该捕获这个异常进行

  • Android 中ContentProvider的实例详解

    Android 中ContentProvider的实例详解 Content Provider 的简单介绍: * Android中的Content Provider 机制可支持在多个应用中存储和读取数据.这也是跨应用 共享数据的唯一方式.在Android系统中,没有一个公共的内存区域,供多个应用共享存储数据: * Android 提供了一些主要数据类型的ContentProvider ,比如:音频.视频.图片和私人通讯录等: 在android.provider 包下面找到一些android提供的C

  • Android中SQLite 使用方法详解

    Android中SQLite 使用方法详解 现在的主流移动设备像android.iPhone等都使用SQLite作为复杂数据的存储引擎,在我们为移动设备开发应用程序时,也许就要使用到SQLite来存储我们大量的数据,所以我们就需要掌握移动设备上的SQLite开发技巧.对于Android平台来说,系统内置了丰富的API来供开发人员操作SQLite,我们可以轻松的完成对数据的存取. 下面就向大家介绍一下SQLite常用的操作方法,为了方便,我将代码写在了Activity的onCreate中: @Ov

随机推荐