上节我们学习了怎样去读取系统短信以及插入一条短信到系统中。 本节我们学习怎样获取系统的联系人,以及插入一条联系人

好。废话不多说了,直接操作。

首先和读取短信一样,先找到联系人在数据库中的位置。

watermark/2/text/aHR0cDovL2Jsb2cuY3Nkbi5uZXQv/font/5a6L5L2T/fontsize/400/fill/I0JBQkFCMA==/dissolve/70/gravity/Center" alt="">

然后导出,查看数据库中的内容

watermark/2/text/aHR0cDovL2Jsb2cuY3Nkbi5uZXQv/font/5a6L5L2T/fontsize/400/fill/I0JBQkFCMA==/dissolve/70/gravity/Center" alt="">

上图就是怎样到数据库中找打系统的联系人数据,(看起来图画的有点乱,希望能看懂吧)

既然知道怎样能到系统的数据库找到数据。那我们就開始写代码实现吧:

public class ReadContactActivity extends Activity {

	@Override
protected void onCreate(Bundle savedInstanceState) {
// TODO Auto-generated method stub
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_readcontact); } public void readContact(View v)
{
ContentResolver cr = getContentResolver(); /*
* 先到raw_contacts表中拿到contact_id
* content://com.android.contacts/raw_contacts是raw_contacts的訪问url
* */
Cursor contactId = cr.query(Uri.parse("content://com.android.contacts/raw_contacts"), new String[]{"contact_id"}, null, null, null);
while(contactId.moveToNext())
{
/*
* 拿到contact_id接着到data表中去依据raw_contact_id获取mimetype_id和data1数据
* */
String id = contactId.getString(contactId.getColumnIndex("contact_id")); /**
* "content://com.android.contacts/data"是訪问data表的url
* 通过id也就是contact_id去data表中找,data1, raw_contact_id, mimetype_id.
* 可是, id就是raw_contact_id,所以就不用再找了。 而mimetype_id因为Android系统为我们自己优化了一些细节。当你在data表中找mimetype_id是找不到的
* android系统直接将mimetype_id转变为找mimetype了
*/
Cursor contactData = cr.query(Uri.parse("content://com.android.contacts/data"),
new String[]{"data1", "mimetype"}, "raw_contact_id = ?", new String[]{id}, null);
String email = null, phone = null, name = null;
while(contactData.moveToNext())
{
String data1 = contactData.getString(contactData.getColumnIndex("data1"));
String mimetype = contactData.getString(contactData.getColumnIndex("mimetype")); /*假设mimetype是邮箱*/
if("vnd.android.cursor.item/email_v2".equals(mimetype))
{
email = data1;
}//假设mimetype是电话
else if ("vnd.android.cursor.item/phone_v2".equals(mimetype)) {
phone = data1;
}//假设mimetype是名字
else if ("vnd.android.cursor.item/name".equals(mimetype)){
name = data1;
}
} Log.i("ReadContactActivity", id + ';' + name + ";" + phone + ";" + email);
}
}
}

打印结果为:

上图就是怎样获取联系人的操作。

注意: 读取联系人,短信等信息都须要加上权限的:

既然知道怎样从系统中获取联系人。那就应该会为系统插入一条联系人的记录。

接下来我们实现为系统插入一条联系人记录

Activity的插入的代码:

public void insertContact(View v)
{
ContentResolver cr = getContentResolver();
Cursor cursor = cr.query(Uri.parse("content://com.android.contacts/raw_contacts"), new String[]{"_id"}, null, null, null);
/*假设数据库中没有数据,则插入的就是第一条数据*/
int contactId = 1;
if(cursor.moveToLast())
{
/*假设有数据,就插入到最新的写一条*/
int id = cursor.getInt(cursor.getColumnIndex("_id"));
contactId = id + 1;
} ContentValues values = new ContentValues();
/*将新的id插入到raw_contacts表中*/
values.put("contact_id", contactId);
cr.insert(Uri.parse("content://com.android.contacts/raw_contacts"), values); /*插入名字*/
values.clear();
values.put("data1", "erlangsheng");
values.put("mimetype", "vnd.android.cursor.item/name");
values.put("raw_contact_id", contactId);
cr.insert(Uri.parse("content://com.android.contacts/data"), values); /*插入电话*/
values.clear();
values.put("data1", "00189890");
values.put("mimetype", "vnd.android.cursor.item/phone_v2");
values.put("raw_contact_id", contactId);
cr.insert(Uri.parse("content://com.android.contacts/data"), values); }
}

结果为:

以上就是给联系人插入一条记录。

Android 四大组件学习之ContentProvider四的更多相关文章

  1. Android 四大组件学习之ContentProvider五

    上几节学习了ContentProvider的实际用途,读取短信.插入短信,读取联系人.插入联系人等. 本节课在学习ContentProvider的观察者. 在生活中有第三方的软件.比方什么短信软件.此 ...

  2. Android 四大组件学习之ContentProvider二

    上节学习了什么是ContentProvider.以及ContentProvider的作用.以及什么是URL.本节就对上节学习的知识做一个实践,也就是定义自己的ContentProvider 好.实践是 ...

  3. Android 四大组件学习之ContentProvider三

    上节课学习怎样自己创建一个ContentProvider.以及用ContentResolver去操作ContentProvider. 今天我们用系统提供的ContentProvider. 先来个简单的 ...

  4. Android 四大组件学习之BroadcastReceiver四

    本节学习系统中特殊的广播接收者. 我们前面几节不是说了,当广播接受者一旦注冊到系统中,当系统发送的广播和你注冊的广播的action匹配时,系统就会启动广播接收者所在的进程.除非用户手动停止广播接收者所 ...

  5. android四大组件学习总结以及各个组件示例(1)

    android四大组件分别为activity.service.content provider.broadcast receiver. 一.android四大组件详解 1.activity (1)一个 ...

  6. Android 四大组件学习之Server一

    上次学习了Android四大组件Activity之后,我们深刻理解了Activity.这次我们学习四大组件Service. Service与Activity的级别是一样的,都是Android系统不可缺 ...

  7. Android 四大组件学习之BroadcastReceiver一

    本节课学习四大组件最后一个, 广播接受者. 顾名思义广播接受者就是接受广播呗.比方在现实社会中,曾经每一个人家都有一台收音机,这可就能够去接受广播发出来的消息.大家都知道.程序世界也是參照的显示生活设 ...

  8. Android四大组件之一:ContentProvider(内容提供者)

    Android中还提供了名为ContentProvider(内容提供者),可以向其他应用提供数据,但不常用,除非是同一公司开发的App,可以向不同应用提供数据.虽然为Android的四大组件之一,但用 ...

  9. android四大组件学习总结以及各个组件示例(2)

    上篇博文讲解了activity.content provider,此篇博文来仔细总结service.broadcast receiver: 3. Service >什么是服务?>windo ...

随机推荐

  1. 搭建本地Tomcat

    1.下载自己需要的版本我安装的Tomcat8(https://tomcat.apache.org/). 2.根据自己的电脑下载需要的系统版本.我的电脑是Windows64位的操作系统 3.选择一个目录 ...

  2. IE (6-11)版本,在使用iframe的框架时,通过a标签javascript:; 和js跳转parent.location的时候 出现在新页面打开的情况

    问题描述: 使用iframe的情况下,在子框架中,使用如下形式的跳转: <a href="javascript:;" onclick="parent.locatio ...

  3. python 小白(无编程基础,无计算机基础)的开发之路 辅助知识1 with...as

    这个语法是用来代替传统的try...finally语法的. with EXPRESSION [ as VARIABLE] WITH-BLOCK 基本思想是with所求值的对象必须有一个__enter_ ...

  4. jQuery的事件绑定命名空间

    jQuery的bind的函数在实际应用中用的不是特别多,只是他可以绑定一个事件,但不会即时触发,也可以通过unbind来解除绑定.在没有看到这篇文章之前,我一直不知道原来bind也可以有命名空间.事实 ...

  5. struts2 内容记录

    多xml文件配置 在开发过程中我们经常会将每一张表(如:user表)的struts.xml文件分开,便于管理,故需要建立struts_user.xml文件管理请求等.那么需要用到inculde标签. ...

  6. java多线程创建-Thread,Runnable,callable和threadpool

    java创建多线程的方式有许多种,这里简要做个梳理 1. 继承Thread类 继承java.lang.Thread类,创建本地多线程的类,重载run()方法,调用Thread的方法启动线程.示例代码如 ...

  7. MySQL5.6新特性

    Innodb加强项 1.Innodb全文索引 mysql> show create table film_text\G . row *************************** Tab ...

  8. centos安装maven,git,mysql

    安装maven1:下载maven包:http://mirror.bit.edu.cn/apache/maven/maven-3/3.5.0/binaries/apache-maven-3.5.0-bi ...

  9. DNS:域名系统

    概述: DNS的作用在于将域名转换为对应的IP地址. DNS名字空间和UNIX文件系统相似,也是树形结构.以"."结尾的域名称为FQDN(Full Qualified Domain ...

  10. params SqlParameter[] commandParameters(转)

    C#代码  ExecuteReader(string connectionString, CommandType commandType, string commandText, params Sql ...