来自:http://www.apkbus.com/android-16352-1-1.html
在自己的android应用中存储数据,可以用SQLite数据库。不过,如果需要在多个应用中共享数据,在Android中,只有通过Content provider机制。
下面用一个最简单(不完整)的示例来说明Content Provider的创建。在界面中使用这个示例显示的效果:
显示帝王姓名、登基年份和朝代。
在这个简单示例中,包括两部分:
- 创建一个Content Provider;
- 使用这个Content Provider(目前是在同一个应用中,可以在其他应用中以相同方式调用)。
创建一个简陋的Content Provider
content provider通过抽象一致的接口,供其他开发者使用Content provider,而实现Content provider,既可以用sqlite3这样的android内置数据库,也可以使用文件系统,甚至可以自己写其他的实现,只要实现规定的接口即可。
实现一个Content provider,需要做:
- 继承ContentProvider,实现该类的几个抽象方法;
- 在manifest文件中声明这个Content provider。
实现的Content provider代码:
- package com.easymorse.cp;
-
- import android.content.ContentProvider;
- import android.content.ContentValues;
- import android.content.Context;
- import android.database.Cursor;
- import android.database.sqlite.SQLiteDatabase;
- import android.database.sqlite.SQLiteStatement;
- import android.net.Uri;
-
- public class MyContentProvider extends ContentProvider {
-
- public static final Uri CONTENT_URI = Uri.parse("content://com.easymorse.cp.mycp");
-
- public static final String _ID = "id";
-
- public static final String NAME = "name";
-
- public static final String DYNASTY = "dynasty";
-
- public static final String START_YEAR = "start_year";
-
- private static SQLiteDatabase database;
-
- private static void createTablesIfNotExists() {
- database.execSQL("create table if not exists emperors("
- + " id integer primary key autoincrement," + " name text,"
- + "dynasty text," + "start_year text" + ");");
-
- SQLiteStatement statement = database
- .compileStatement("insert into emperors(name,dynasty,start_year) values(?,?,?)");
- int index = 1;
- statement.bindString(index++, "朱元璋");
- statement.bindString(index++, "明");
- statement.bindString(index++, "1398");
- statement.execute();
-
- index = 1;
- statement.bindString(index++, "玄烨");
- statement.bindString(index++, "清");
- statement.bindString(index++, "1722");
- statement.execute();
-
- statement.close();
- }
-
- @Override
- public int delete(Uri uri, String selection, String[] selectionArgs) {
- return 0;
- }
-
- @Override
- public String getType(Uri uri) {
- return null;
- }
-
- @Override
- public Uri insert(Uri uri, ContentValues contentValues) {
- // TODO Auto-generated method stub
- return null;
- }
-
- @Override
- public boolean onCreate() {
- if (database == null) {
- database = this.getContext().openOrCreateDatabase("emperors",
- Context.MODE_PRIVATE, null);
- createTablesIfNotExists();
- }
- return database != null;
- }
-
- @Override
- public Cursor query(Uri uri, String[] projection, String selection,
- String[] selectionArgs, String sortOrder) {
- Cursor cursor = database.rawQuery("select * from emperors", null);
- return cursor;
- }
-
- @Override
- public int update(Uri uri, ContentValues contentValues, String selection,
- String[] selectionArgs) {
- // TODO Auto-generated method stub
- return 0;
- }
-
- }
复制代码
需要实现的方法是:
- query() <<
- insert()
- update()
- delete()
- getType()
- onCreate()<<
复制代码
在本例中值实现了标注<<的方法。onCreate方法是创建Content provider时,android调用的。创建Content provider时,本例检查是否创建emperors表,没有就创建一个,并且插入了2条记录。query方法实现的很简单,只是返回表的所有结果集。做完这些还不够,还需要声明一些常量:
- public static final Uri CONTENT_URI = Uri.parse("content://com.easymorse.cp.mycp");
-
- public static final String _ID = "id";
-
- public static final String NAME = "name";
-
- public static final String DYNASTY = "dynasty";
-
- public static final String START_YEAR = "start_year";
复制代码
CONTENT_URI 是便于Content provider使用者引用的,下面使用Content provider的时候能看到。另外,要有一个_ID常量,值是具体表的id列名称。其他几个常量是表中列的对应名称常量。目前没有真的使用。在manifest文件中的声明:
- <application android:icon="@drawable/icon" android:label="@string/app_name">
- <activity android:name=".UseContactActivity" android:label="@string/app_name">
- <intent-filter>
- <action android:name="android.intent.action.MAIN" />
- <category android:name="android.intent.category.LAUNCHER" />
- </intent-filter>
- </activity>
- <provider android:name="com.easymorse.cp.MyContentProvider"
- android:authorities="com.easymorse.cp.mycp"></provider>
- </application>
复制代码
这里的android:name是ContentProvider实现类的类名,android:authorities是CONTENT_URI的值。使用创建的Content Provider代码在一个Activity中,通过TextView显示出emperors表中的数据:
- package com.easymorse.cp;
-
- import android.app.Activity;
- import android.database.Cursor;
- import android.os.Bundle;
- import android.widget.TextView;
-
- public class UseContactActivity extends Activity {
- /** Called when the activity is first created. */
- @Override
- public void onCreate(Bundle savedInstanceState) {
- super.onCreate(savedInstanceState);
-
- TextView textView = new TextView(this);
- textView.setText(getContentProviderValues());
- this.setContentView(textView);
- }
-
- private String getContentProviderValues() {
- StringBuilder builder = new StringBuilder();
-
- Cursor cursor = managedQuery(MyContentProvider.CONTENT_URI, null, null,
- null, null);
- while (cursor.moveToNext()) {
- builder
- .append(
- cursor.getString(cursor
- .getColumnIndex(MyContentProvider.NAME)))
- .append(" | ")
- .append(
- cursor
- .getString(cursor
- .getColumnIndex(MyContentProvider.START_YEAR)))
- .append(" | ")
- .append(
- cursor.getString(cursor
- .getColumnIndex(MyContentProvider.DYNASTY)))
- .append("\n");
- }
-
- return builder.toString();
- }
- }
复制代码
主要方法是getContentProviderValues()。通过managedQuery()方法获取到Cursor对象。在方法调用的参数,只用到了MyContentProvider.CONTENT_URI,通过这个参数,android可定位到具体的ContentProvider并启动它(如果没有启动的话)。后面几个参数类似SQL的SELECT子句、WHERE子句和ORDER BY子句。都不写,将返回全部的结果(其实我这个例子中的Content provider也只实现了返回全部结果的逻辑)。源代码见:
<ignore_js_op style="word-wrap: break-word; "> Content Provider安卓巴士(源代码).rar (48.5 KB, 下载次数: 99)
分享到:
相关推荐
接下来,可以尝试自己编写一个简单的Content Provider,最后结合实际项目需求,实践Content Provider的高级用法,如跨进程通信和异步数据处理。 9. **应用场景** Content Provider广泛应用于不同应用间的通讯,如...
3. **Content Provider**:为了在不同应用之间共享数据,Android引入了Content Provider机制。虽然"DateNote"可能仅用于个人记事,但Content Provider可以为未来的扩展提供便利,允许其他应用读取或写入记事数据。 ...
1. **Provider类**:继承自`android.content.ContentProvider`,这是ContentProvider的核心类,你需要在这里实现数据的增删查改方法,如`insert()`, `delete()`, `query()` 和 `update()`。 2. **UriMatcher**:这...
接下来,我们将创建一个简单的ContentProvider示例: 1. 首先,定义UriMatcher,为不同的操作添加匹配规则,如: ``` UriMatcher matcher = new UriMatcher(UriMatcher.NO_MATCH); matcher.addURI(...
开发者可以利用Java的类库来创建各种功能丰富的应用,如活动(Activity)、服务(Service)、广播接收器(Broadcast Receiver)和内容提供者(Content Provider)等。 2. UI构建:Android提供了一套基于Java的视图...
11. **Content Provider**:学习如何创建和使用Content Provider来共享数据。 12. **用户界面设计**:包括布局设计、控件使用、动画效果,以及如何响应用户交互。 - **3D动画效果**:如何实现视觉上的增强效果。 ...
在Android应用结构中,理解四大组件是关键:Activity(活动)、Service(服务)、Broadcast Receiver(广播接收器)和Content Provider(内容提供者)。Activity是用户界面的主要载体,Service则在后台运行,...
在Android中,这通常涉及创建一个新的Android项目,编写一个简单的Activity,显示一个欢迎消息。通过这个过程,你可以了解Android项目的结构,以及XML布局文件和Java代码如何交互。 四、用户界面设计 Android应用的...
编写简单的"Hello, World!"程序,了解基本的布局XML文件(如activity_main.xml)和Java或Kotlin代码(如MainActivity.java或MainActivity.kt)。 三、UI设计 Android应用的用户界面主要通过XML文件定义,包括布局、...
Android应用程序的基本结构包括Manifest文件、Activity、Service、Broadcast Receiver、Content Provider等组件。Manifest文件是Android应用的配置文件,包含了应用的元数据;Activity是用户界面的主要组件,负责...
Android应用由四大组件构成:Activity(活动)、Service(服务)、Broadcast Receiver(广播接收器)和Content Provider(内容提供者)。Activity是用户界面的核心,负责与用户交互;Service则在后台运行,执行长...
1. **Shared Preferences**:这是最简单且常用的数据存储方式,用于保存键值对,通常用于存储用户设置和轻量级数据。数据以XML格式存储在私有目录下,只能被同一应用访问。 2. **SQLite数据库**:当需要结构化的...
4. 应用程序框架:包含各种API,如Activity Manager、Content Provider、Broadcast Receiver等,供开发者构建应用程序。 5. 应用程序:用户直接交互的部分,如系统应用和第三方应用。 二、Android开发环境搭建 首先...
通过动手编写简单的Android应用程序,初学者可以逐步熟悉Android开发的各个方面,包括用户界面设计、事件处理、数据存储等。随着经验的积累,开发者可以尝试编写更复杂的应用程序,如社交媒体应用、游戏或者企业级...
读者将了解到Android应用程序的基本组成元素,如Activity、Service、Broadcast Receiver和Content Provider,并学习如何创建和管理这些组件。 接下来,进入Android开发环境的搭建,包括安装Android Studio、配置...
4. **Android基础入门PPT**:PPT通常会概述Android开发的关键概念,如Activity生命周期、Intent的使用、服务(Service)、广播接收器(Broadcast Receiver)和内容提供者(Content Provider)。这些是Android框架的...
\n\nAndroid应用程序通常由多个组件构成,包括Activity、Broadcast Intent Receiver、Service和Content Provider。Activity是用户界面的主体,负责与用户交互;Broadcast Intent Receiver用于接收和响应系统或应用...
学习Android开发,首先要掌握Java语言基础,然后熟悉Android Studio的使用,理解Android的组件模型(Activity、Service、Broadcast Receiver、Content Provider)和Intent机制。通过实践Hello, Android这样的简单...