Android开发14——监听内容提供者ContentProvider的数据变化

 

一、提出需求

有A,B,C三个应用,B中的数据需要被共享,所以B中定义了内容提供者ContentProvider;A应用修改了B应用的数据,插入了一条数据。有这样一个需求,此时C应用需要得到数据被修改的通知并处理相应操作。

 

 

二、示例代码

A应用
/**
 * 对内容提供者进行操作
 *
 * @author XY
 *
 */
public class MainActivity extends Activity
{

	@Override
	public void onCreate(Bundle savedInstanceState)
	{
		super.onCreate(savedInstanceState);
		setContentView(R.layout.main);
	}

	public void insert(View v)
	{
		Uri uri = Uri.parse("content://cn.xyCompany.providers.personProvider/person");
		ContentResolver resolver = this.getContentResolver();
		ContentValues values = new ContentValues();
		values.put("name", "xy_new_new");
		values.put("phone", "xy_new_111");
		resolver.insert(uri, values);
	}
}

B应用
package cn.xy.cotentProvider.app.providers;
import android.content.ContentProvider;
import android.content.ContentUris;
import android.content.ContentValues;
import android.content.UriMatcher;
import android.database.Cursor;
import android.database.sqlite.SQLiteDatabase;
import android.net.Uri;
import android.util.Log;
import cn.xy.cotentProvider.service.DBOpeningHelper;

/**
 * @author XY
 *
 */
public class PersonProvider extends ContentProvider
{
	private DBOpeningHelper dbHelper;

	// 若不匹配采用UriMatcher.NO_MATCH(-1)返回
	private static final UriMatcher MATCHER = new UriMatcher(UriMatcher.NO_MATCH);

	// 匹配码
	private static final int CODE_NOPARAM = 1;
	private static final int CODE_PARAM = 2;

	static
	{
		// 对等待匹配的URI进行匹配操作,必须符合cn.xyCompany.providers.personProvider/person格式
		// 匹配返回CODE_NOPARAM,不匹配返回-1
		MATCHER.addURI("cn.xyCompany.providers.personProvider", "person", CODE_NOPARAM);

		// #表示数字 cn.xyCompany.providers.personProvider/person/10
		// 匹配返回CODE_PARAM,不匹配返回-1
		MATCHER.addURI("cn.xyCompany.providers.personProvider", "person/#", CODE_PARAM);
	}

	@Override
	public boolean onCreate()
	{
		dbHelper = new DBOpeningHelper(this.getContext());
		return true;
	}

	/**
	 * 外部应用向本应用插入数据
	 */
	@Override
	public Uri insert(Uri uri, ContentValues values)
	{
		SQLiteDatabase db = dbHelper.getWritableDatabase();
		switch (MATCHER.match(uri))
		{
			case CODE_NOPARAM:
				// 若主键值是自增长的id值则返回值为主键值,否则为行号,但行号并不是RecNo列
				long id = db.insert("person", "name", values);
				Uri insertUri = ContentUris.withAppendedId(uri, id);
				// 发出变化通知(非必须)设监听者为null。
				// 若设置某个监听者则不管有多少个监听者,该监听者一定可以获得该通知
				getContext().getContentResolver().notifyChange(uri, null);
				return insertUri;
			default:
				throw new IllegalArgumentException("this is unkown uri:" + uri);
		}
	}
	......
}

C应用
package cn.xt.contentProvider.lisenter;
import android.app.Activity;
import android.content.ContentResolver;
import android.database.ContentObserver;
import android.database.Cursor;
import android.net.Uri;
import android.os.Bundle;
import android.os.Handler;
import android.util.Log;

public class MainActivity extends Activity
{
	@Override
	public void onCreate(Bundle savedInstanceState)
	{
		super.onCreate(savedInstanceState);
		setContentView(R.layout.main);
		Uri uri = Uri.parse("content://cn.xyCompany.providers.personProvider/person");
		ContentResolver resolver = this.getContentResolver();
		resolver.registerContentObserver(uri, true, new PersonContentObserver(new Handler()));
	}

	private class PersonContentObserver extends ContentObserver
	{
		public PersonContentObserver(Handler handler)
		{
			super(handler);
		}

		// 得到数据的变化通知,该方法只能粗略知道数据的改变,并不能判断是哪个业务操作进行的改变
		@Override
		public void onChange(boolean selfChange)
		{
			// select * from person order by id desc limit 1 // 取得最近插入的值(序号大——>小并取第一个)
			Uri uri = Uri.parse("content://cn.xyCompany.providers.personProvider/person");
			ContentResolver resolver = MainActivity.this.getContentResolver();
			Cursor cursor = resolver.query(uri, null, null, null, "id desc limit 1");
			if(cursor.moveToFirst())
			{
				String name = cursor.getString(cursor.getColumnIndex("name"));
				Log.i("lisenter", name);
			}
		}
	}
}

关于contentProvider的基本使用,请参看本博客博文《Android开发13——内容提供者ContentProvider的基本使用》

 

时间: 2025-01-01 23:06:23

Android开发14——监听内容提供者ContentProvider的数据变化的相关文章

android开发界面监听和跳转,求教两个程序有版图

问题描述 android开发界面监听和跳转,求教两个程序有版图 在编辑输入什么 上面就显示:您输入的是"输入的内容" 我只会写 点各个按钮出现相应的字 按钮变不了 这页面跳转 只会一点点 求程序 解决方案 第一个问题: android中有监听ExitText输入内容变化的监听函数: exitText.addTextChangedListener(new TextWatcher() { @Override public void onTextChanged(CharSequence s,

android开发,监听事件不触发

问题描述 android开发,监听事件不触发 登入界面在TextView中输入密码,触发TextView的监听事件(继承TextWatcher),当程序再次返回登入界面时,在TextView控件中输入内容,监听事件并不触发? 监听返回按钮的源代码: public boolean onKeyDown(int keyCode,KeyEvent event){ if(keyCode == KeyEvent.KEYCODE_BACK && event.getAction() == KeyEvent

android开发鼠标监听事件运行错误

问题描述 android开发鼠标监听事件运行错误 解决方案 mainactivity 中27行 空指针了,....写的很明显了.. 解决方案二: 看一下MainActivity.java的第27行代码,有对象为null,所以报空指针异常. 解决方案三: 亲,学会看logcat报异常哦,有时候异常原因写在中间

Android开发-之监听button点击事件的多种方法_Android

 在Android下,事件的发生是在监听器下进行,android系统可以响应按键事件和触摸屏事件,本文主要介绍了button点击事件的方法 一.实现button点击事件的方法 实现button点击事件的监听方法有很多种,这里总结了常用的四种方法: 1.匿名内部类 2.外部类(独立类) 3.实现OnClickListener接口 4.添加XML属性 每一种方法都有它的优点也有它的不足,那么接下来就来详细的讲解这四个实现方法  二.具体实现 1.匿名内部类: 在Android开发中我们会经常看到各种

Android开发-之监听button点击事件的多种方法

在Android下,事件的发生是在监听器下进行,android系统可以响应按键事件和触摸屏事件,本文主要介绍了button点击事件的方法 一.实现button点击事件的方法 实现button点击事件的监听方法有很多种,这里总结了常用的四种方法: 1.匿名内部类 2.外部类(独立类) 3.实现OnClickListener接口 4.添加XML属性 每一种方法都有它的优点也有它的不足,那么接下来就来详细的讲解这四个实现方法 二.具体实现 1.匿名内部类: 在Android开发中我们会经常看到各种匿名

基于Android 监听ContentProvider 中数据变化的相关介绍_Android

如果ContentProvider的访问者需要知道ContentProvider中的数据的变化情况,可以在ContentProvider发生数据变化时调用getContentResolver().notifyChange(uri,null)来通知注册在此URI上的访问者. 复制代码 代码如下: public class PersonContentProvider extends ContentProvider[ public Uri insert(Uri uri,ContentValues va

Android内容提供者ContentProvider用法实例分析_Android

本文实例讲述了Android内容提供者ContentProvider用法.分享给大家供大家参考,具体如下: PersonContentProvider内容提供者类 package com.ljq.db; import android.content.ContentProvider; import android.content.ContentUris; import android.content.ContentValues; import android.content.UriMatcher;

Android零基础入门第34节:Android中基于监听的事件处理

原文:Android零基础入门第34节:Android中基于监听的事件处理    上一期我们学习了Android中的事件处理,也详细学习了Android中基于监听的事件处理,同时学会了匿名内部类形式,那么本期继续来学习其他四种事件监听器.     一.使用内部类作为事件监听器       和上面的匿名内部类不同,使用内部类可以在当前类中复用该监听器类:因为监听器类是外部类的内部类,所以可以自由访问外部类的所有界面组件,这也是内部类的两个优势.     接下来通过一个简单的示例程序来学习Andro

Android EditText 实现监听实例_Android

我们要实现:当EditText的Text改变时,我们希望得到通知,但是可惜的是Android并没有这个监听器,也就无从得知变化了,但我们可以使用TextWatcher类可以帮助我们来实现这个功能. 现有一个id = edit的EditText. 1.定义一个TextWatcher的实例. private TextWatcher watcher = new TextWatcher(){ @Override public void afterTextChanged(Editable s) { //