对联系人进行增删改查

我已经将联系人操作的方法进行了封装,暴露了几个重要的方法,方便以后调用。

1. public void printContactsList() // 获取到的联系人列表(用于测试用)

2. public ArrayList<ContactBean> getContactsList() // 得到手机和SIM卡中的联系人列表(姓名 + 电话号码)

3. public void add(String name, String phoneNumber) // 添加一个新的联系人数据

4. public boolean delete(String name) // 删除单个联系人数据

5. public boolean update(String name, String phoneNumber) // 更新联系人数据

6. public boolean findNameByPhoneNumber(String phoneNumber) // 根据电话号码查询姓名

 

增删改查通讯录:http://blog.csdn.net/xiazdong/article/details/7713419

监听联系人的改变:http://www.eoeandroid.com/thread-234378-1-1.html

 

全部代码:

package com.kale.contatctest;

import java.util.ArrayList;
import java.util.Collection;

import android.content.ContentResolver;
import android.content.ContentUris;
import android.content.ContentValues;
import android.content.Context;
import android.database.Cursor;
import android.net.Uri;
import android.provider.ContactsContract.CommonDataKinds.Phone;
import android.provider.ContactsContract.Contacts.Data;
import android.text.TextUtils;
import android.util.Log;
import android.widget.Toast;

public class ContactsManager {

    private Context mContext = null;

    public ContactsManager(Context context) {
        mContext = context;
    }

    /**
     * @description 打印获取到的联系人列表(用于测试用)
     *
     */
    public void printContactsList() {
        System.out.println("showContactsList----------------->" + getContactsList().size());
        for (int i = 0; i < getContactsList().size(); i++) {
            ContactBean cb = new ContactBean();
            cb = getContactsList().get(i);
            System.out.println(i + 1 + "  " + cb.getContactName() + "  " + cb.getPhoneNumber());
        }
    }

    /**
     * @description 得到手机和SIM卡中的联系人列表(姓名 + 电话号码)
     *
     * @return
     */
    public ArrayList<ContactBean> getContactsList() {
        ArrayList<ContactBean> contactsList = new ArrayList<ContactBean>();
        Collection<ContactBean> collection = getPhoneList();
        contactsList.addAll(collection);

        collection.clear();
        collection = getSIMList();
        contactsList.addAll(collection);

        return contactsList;
    }

    /**
     * 将“手机通讯录”联系人添加到list中
     */
    private ArrayList<ContactBean> getPhoneList() {
        Uri uri = Phone.CONTENT_URI;
        return getContactsList(uri);
    }

    /**
     * 将“手机SIM”联系人添加到list中
     */
    private ArrayList<ContactBean> getSIMList() {
        Uri uri = Uri.parse("content://icc/adn");
        return getContactsList(uri);
    }

    /**
     * @param uri
     * @return 根据URL来得到手机/SIM卡中的联系人列表
     */
    private ArrayList<ContactBean> getContactsList(Uri uri) {
        ArrayList<ContactBean> list = new ArrayList<ContactBean>();
        ContentResolver resolver = mContext.getContentResolver();
        /*
         * 获取库Phone表字段,仅仅获取电话号码联系
         * 它所指向的其实是“content://com.android.contacts/data/phones”。
         * 这个URL对应着contacts表 和 raw_contacts表 以及 data表 所以说我们的数据都是从这三个表中获取的。
         */
        String[] PHONES_PROJECTION = new String[] { Phone.DISPLAY_NAME, Phone.NUMBER, Phone.CONTACT_ID };
        Cursor phoneCursor = resolver.query(uri, PHONES_PROJECTION, null, null, null);
        if (phoneCursor != null) {
            while (phoneCursor.moveToNext()) {
                // 得到手机号码
                String phoneNumber = phoneCursor.getString(1);
                // 当手机号码为空的或者为空字段 跳过当前循环,即使这个联系人有名字也跳出循环
                if (TextUtils.isEmpty(phoneNumber)) {
                    continue;
                }
                // 如果有电话好么,那么就得到联系人名称
                String contactName = phoneCursor.getString(0);

                ContactBean cb = new ContactBean();
                cb.setContactName(contactName);
                cb.setPhoneNumber(phoneNumber);
                list.add(cb);
            }
            phoneCursor.close(); // 关闭指针
        }
        return list;
    }

    /**
     * 添加一个新的联系人数据
     * 
     * @param name
     * @param phoneNumber
     * @return 是否添加成功
     */
    public void add(String name, String phoneNumber) {
        // 根据号码找数据,如果存在则不添加,因为有号码但无名字是不允许的
        // if (!findNameByPhoneNumber(phoneNumber)) {
        // 插入raw_contacts表,并获取_id属性
        Uri uri = Uri.parse("content://com.android.contacts/raw_contacts");
        ContentResolver resolver = mContext.getContentResolver();
        ContentValues values = new ContentValues();
        long contact_id = ContentUris.parseId(resolver.insert(uri, values));
        // 插入data表
        uri = Uri.parse("content://com.android.contacts/data");
        // 添加姓名
        values.put("raw_contact_id", contact_id);
        values.put(Data.MIMETYPE, "vnd.android.cursor.item/name");
        values.put("data2", name);
        // values.put("data1", "Jack");
        resolver.insert(uri, values);
        values.clear();
        // 添加手机号码
        values.put("raw_contact_id", contact_id);
        values.put(Data.MIMETYPE, "vnd.android.cursor.item/phone_v2");
        values.put("data2", "2"); // 2表示手机
        values.put("data1", phoneNumber);
        resolver.insert(uri, values);
        values.clear();

    }

    /**
     * 删除单个联系人数据
     * 
     * @param name
     * @return 是否删除成功
     */
    public boolean delete(String name) {
        try {
            // 根据姓名求id
            Uri uri = Uri.parse("content://com.android.contacts/raw_contacts");
            ContentResolver resolver = mContext.getContentResolver();
            Cursor cursor = resolver.query(uri, new String[] { Data._ID }, "display_name = ?", new String[] { name }, null);
            if (cursor.moveToFirst()) {
                int id = cursor.getInt(0);
                // 根据id删除data中的相应数据
                resolver.delete(uri, "display_name = ?", new String[] { name });
                uri = Uri.parse("content://com.android.contacts/data");
                resolver.delete(uri, "raw_contact_id = ?", new String[] { id + "" });
                return true;
            }
        } catch (Exception e) {
            e.printStackTrace();
        }
        Toast.makeText(mContext, "删除失败", Toast.LENGTH_SHORT).show();
        return false;
    }

    /*
     * // 删除全部联系人,十分耗时间。有错误 public boolean deleteAllContact() { ContentResolver
     * resolver = mContext .getContentResolver(); Cursor contactsCur =
     * resolver.query(ContactsContract.Contacts.CONTENT_URI, null, null, null,
     * null); while(contactsCur.moveToNext()){ //获取ID String rawId =
     * contactsCur.
     * getString(contactsCur.getColumnIndex(ContactsContract.Contacts._ID));
     * //删除 String where = ContactsContract.Data._ID + " =?"; String[]
     * whereparams = new String[]{rawId};
     * resolver.delete(ContactsContract.RawContacts.CONTENT_URI, where,
     * whereparams); } if(contactsCur.moveToNext() == false){ return true; }
     * return false; }
     */
    /*
     * //删除全部数据 public boolean deleteAll(){ getContentResolver().delete(
     * ContentUris.withAppendedId(RawContacts.CONTENT_URI, rawContactId), null,
     * null); try { ContentResolver resolver = mContext .getContentResolver();
     * Uri uri = Uri.parse("content://com.android.contacts/raw_contacts");
     * resolver.delete(uri, "display_name= true", new String[]{"true"}); uri =
     * Uri.parse("content://com.android.contacts/data"); resolver.delete(uri,
     * "raw_contact_id= true", new String[]{"true"});
     * 
     * } catch (Exception e) { Toast.makeText(mContext, "删除失败",
     * Toast.LENGTH_SHORT).show(); e.printStackTrace(); } return false; }
     */

    /**
     * @description 更新联系人数据
     * 
     * @param name
     * @param phoneNumber
     * @return 是否更新成功
     */
    public boolean update(String name, String phoneNumber) {
        try {
            // 根据姓名求id,再根据id删除
            Uri uri = Uri.parse("content://com.android.contacts/raw_contacts");
            ContentResolver resolver = mContext.getContentResolver();
            Cursor cursor = resolver.query(uri, new String[] { Data._ID }, "display_name = ?", new String[] { name }, null);
            if (cursor.moveToFirst()) {
                int id = cursor.getInt(0);
                Uri mUri = Uri.parse("content://com.android.contacts/data");// 对data表的所有数据操作
                ContentResolver mResolver = mContext.getContentResolver();
                ContentValues values = new ContentValues();
                values.put("data1", phoneNumber);
                mResolver.update(mUri, values, "mimetype=? and raw_contact_id=?", 
                        new String[] { "vnd.android.cursor.item/phone_v2", id + "" });
                return true;
            }
        } catch (Exception e) {
            e.printStackTrace();
        }
        Toast.makeText(mContext, "修改失败", Toast.LENGTH_SHORT).show();
        return false;
    }

    /**
     * @description 根据电话号码查询姓名
     *
     * @param phoneNumber
     * @return 查询是否成功
     */
    public boolean findNameByPhoneNumber(String phoneNumber) {
        // URI = content://com.android.contacts/data/phones/filter/#
        Uri uri = Uri.parse("content://com.android.contacts/data/phones/filter/" + phoneNumber);
        ContentResolver resolver = mContext.getContentResolver();
        // 从raw_contact表中返回display_name
        Cursor cursor = resolver.query(uri, new String[] { Data.DATA4 }, null, null, null); 
        if (cursor.moveToFirst()) {
            Log.d("ContactsManager", "找到这个号码");
            return true;
        } else {
            Log.e("ContactsManager", "没找到这个号码");
            return false;
        }
    }

}

 

  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
*:手机通讯录联系人分类: 亲人 同事 朋友 其他 *:手机通讯录里面所有的联系人底层都装进一个集合对象里面 -》 ArrayList *:亲人 同事 朋友 其他类型里面所有的属性: char szm;->首字母 String name->联系人名字 int age->联系人年龄 char gender->联系人性别 long phone->手机号码 String zuoJi->座机号码 -》类似: 0531-6661760 *:创建联系人对象的时候: szm name age gender phone是必填内容 zuoJi可填可不填 *:如果创建联系人对象的时候 用户如果没有提供zuoJi属性值 那么将zuoJi变量赋值为"无座机号码" *:如果创建联系人对象的时候 用户如果提供zuoJi属性值了 那么直接将zuoJi变量赋值为用户输入的值 *:所有类里面的属性要求封装 //一个模块一个模块写 写完测试 测试通过写下一个模块 刚进入cmd里面的主界面 -》 6个小模块 A:显示所有联系人 B:查找某一位联系人 C:添加联系人 D:删除联系人 E:修改联系人 F:结束当前所有操作 显示所有联系人 如果用户选择是A 那么有两种选择: 输入校验: 用户可能输进去的不是a/b 要求重新输入 所有的输入都需要进行校验 a:按照首字母进行显示分类: [效果如下:] A 阿磊 1555950427 W 王刚美 18322009876 X 小明 18756789000 Z 张三 15555555555 周凯 18765432189 .... b:按照类别进行分类显示: [效果如下:] 朋友 张三 15555555555 小明 18756789000 周树人 17499990427 张三 15555445555 亲人 王刚美 18322009876 周凯 18765432189 同事 阿磊 1555950427 ... 查找某一位联系人 如果用户选择的是B: cmd面板显示下面这句话: 请问你是通过联系人名字进行精确查找/手机号码模糊查询 这里用户有两种选择: 用户可以直接的输入要查找联系人的名字 如果集合里面没有该用户 直接显示: 不好意思 当前用户不存在 如果集合里面有该用户 需要将用户的基本信息进行展示: [效果如下:] [输入]张三 [显示] 用户的基本信息联系人姓名:张三 联系人电话:15555555555 联系人座机号码:0531-6661760 用户的基本信息联系人姓名:张三 联系人电话:15555445555 联系人座机号码:无座机号码 用户还可以直接输入一段电话号码-》出现几个数字就可以 如果集合里面没有用户的号码出现这几个数字的 直接显示: 不好意思 当前用户不存在 如果查找到有这个用户存在 显示下面: [效果如下:] [输入]555555 [显示] 用户的基本信息联系人姓名:张三 联系人电话:15555555555 联系人座机号码:0531-6661760 添加联系人 如果用户选择的是C: 需要进行输入校验: 1:输入的大写首字母可能不是大写首字母 是数字 是其他的汉字 2:性别选择的不是A/B 3:注册用户名字的时候 应国家要求 关键字需要屏蔽(...) 4: 输入电话号码的时候 非11为数字 不是数字 不是以138 130 137 158 155 188. .开头 5:输入的年龄非数字 6:选择的分类可能不是亲人 朋友 同事 其他 7:座机可能不是按照 区号-号码的形式传进去的 座机号码的区号只能出现0564 0531 0532 cmd里面直接出现下面的内容: 请选择联系人的分类A:亲人 B:同事 C:朋友 D:其他 请输入联系人名字大写首字母: 请输入联系人的姓名: 请输入联系人的年龄: 请选择联系人性别:A:男 B:女 请输入联系人的电话: 请输入联系人座机号码(没有请回复N):N/区号-座机号 当用户依次输入所有的信息之后 产生一个联系人 但是需要判断集合里面是否已经存在该用户 如果存在(只要手机号码相同就认为是同一个联系人) 这个联系人存在不能继续添加进通讯录里面 cmd里面显示:对不起 当前用户已经存在 同一个用户不能添加多次 如果不存在 将当前联系人添加进集合里面 cmd里面显示:添加成功 删除联系人 如果用户选择的是D: 直接在cmd里面先以表的形式将所有联系人信息显示出来: [效果如下:] 编号 姓名 年龄 电话 0 张三 22 155****5555 1 小明 18 187****9000 2 王刚美 28 183****9876 3 阿磊 24 155****4278 4 周凯 38 187****2189 5 周树人 99 174****0427 6 张三 22 155****5555 cmd里面显示:请问你要删除联系人的编号: 输入校验: 需要对当前输入的编码进行判断 是不是数字 如果不是 需要重新输入(从新输进去的内容还是需要进行输入校验) 如果集合里面有该编码对象的元素 从集合里面将当前编号的联系人删除 并在cmd里面显示删除成功 如果集合里面没有该编号对应的联系人 cmd里面显示:对不起 没有该编码对应的联系人 修改联系人 如果用户选择的是E: 输入校验: 修改之后的姓名还是不能出现关键字 修改之后的电话号码还是只能以155 159...开头 修改后的大写首字母还是要判断是否合法 可能用户不是按照格式正确输入 XXX-XXX-XXX(无论是修改前的输入还是修改后的输入格式需要正确) [效果如下] 请输入你要修改联系人的姓名大写首字母 姓名 联系电话(中间-隔开):Z-张三-15555555555 请输入修改后的联系人的姓名大写首字母 姓名 联系电话(中间-隔开):L-李四-18900000000 找到集合里面对应的联系人信息修改掉 修改完毕 显示修改成功 如果集合里面没有找到叫张三的联系人 显示修改失败 没有查找到该联系人 结束当前所有操作 如果用户选择的是F: 直接结束当前所有的操作 -》 break

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值