ContentProvider应用间数据共享案例

本文介绍了一个使用 ContentProvider 实现跨应用数据共享的例子。通过创建一个提供数据的应用和一个消费数据的应用,展示了如何进行数据的插入、查询等操作。此示例涵盖了 ContentProvider 的基本使用方法。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

描述: contentProvider主要用在不用应用之间的数据共享

注意: 在第二个用用获取第一个应用的数据时,必须保证第一个应用是在运行着的。

效果展示

第一个应用第二个应用
完整的实例代码
应用1
  • MainActivity
package com.example.www.app2;

import android.content.ContentValues;
import android.database.Cursor;
import android.database.sqlite.SQLiteDatabase;
import android.support.v7.app.AppCompatActivity;
import android.os.Bundle;
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 {

    private MySQLiteDataBase mMySQLiteDataBase;
    private SQLiteDatabase mDb;
    private EditText mName;
    private EditText mAge;
    private TextView mContent;


    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);

        mMySQLiteDataBase = new MySQLiteDataBase(this);
        mDb = mMySQLiteDataBase.getWritableDatabase();

        mName = (EditText) findViewById(R.id.editText);
        mAge = (EditText) findViewById(R.id.editText2);
        mContent = (TextView) findViewById(R.id.textView);

    }


    public void insert(View view) {
         String name = mName.getText().toString();
        String age = mAge.getText().toString();
        if(name.isEmpty() || age.isEmpty()) {
            Toast.makeText(this, "年龄或姓名不能为空", Toast.LENGTH_SHORT).show();
            return;
        }
        ContentValues cv = new ContentValues();
        cv.put("name", name);
        cv.put("age", Integer.parseInt(age));
        long result = mDb.insert("user", null, cv);
        if(result != -1) {
            Toast.makeText(this, "插入成功", Toast.LENGTH_SHORT).show();
        } else {
            Toast.makeText(this, "插入失败", Toast.LENGTH_SHORT).show();
        }

    }

    public void query(View view) {
        Cursor cursor = mDb.query("user", null, null, null, null, null, null, null);
        StringBuffer sb = new StringBuffer();
        if(cursor.moveToFirst()) {
            do {
                sb.append("姓名: ").append(cursor.getString(cursor.getColumnIndex("name"))).append("年龄:").append(cursor.getInt(cursor.getColumnIndex("age")));

                sb.append("\n");
            } while (cursor.moveToNext());

            cursor.close();
        }

        mContent.setText(sb.toString());
    }
}

  • MyContentProvider
package com.example.www.app2;

import android.content.ContentProvider;
import android.content.ContentValues;
import android.content.UriMatcher;
import android.database.Cursor;
import android.database.sqlite.SQLiteDatabase;
import android.net.Uri;

public class MyContentProvider extends ContentProvider {

    // 1. 定义一个 urimathcher 定义路径匹配规则
    private static final UriMatcher sURIMather = new UriMatcher(UriMatcher.NO_MATCH);
    private static final int QUERYSUCCESS = 1;
    private static final int INSERTUCCESS = 2;
    private static final int UPDATESUCCESS = 3;
    private static final int DELETESUCCESS = 4;

    // 2. 定义静态代码块 添加匹配规则
    static {
        // authority 和清单文件定义的要一样
        sURIMather.addURI("com.wl.lhw", "query", QUERYSUCCESS);
        sURIMather.addURI("com.wl.lhw", "insert", INSERTUCCESS);
        sURIMather.addURI("com.wl.lhw", "update", UPDATESUCCESS);
        sURIMather.addURI("com.wl.lhw", "delete", DELETESUCCESS);
    }

    private MySQLiteDataBase mOpenHelper;


    @Override
    public boolean onCreate() {
        mOpenHelper = new MySQLiteDataBase(getContext());

        return false;
    }


    @Override
    public Cursor query(Uri uri, String[] projection, String selection, String[] selectionArgs, String sortOrder) {
        int code = sURIMather.match(uri);
        if (code == QUERYSUCCESS) {
            SQLiteDatabase db = mOpenHelper.getWritableDatabase();
            Cursor cursor = db.query("user", projection, selection, selectionArgs, null, null, null);
            return cursor;
        } else {
            throw new IllegalArgumentException("您的路径不匹配");
        }
    }

    @Override
    public String getType(Uri uri) {
        return null;
    }


    @Override
    public Uri insert(Uri uri, ContentValues values) {
        int code = sURIMather.match(uri);
        if (code == INSERTUCCESS) {
            SQLiteDatabase db = mOpenHelper.getWritableDatabase();
            long user = db.insert("user", null, values);
            Uri uri2 = Uri.parse("content://com.wl.insert/" + user);
            return uri2;
        } else {
            throw new IllegalArgumentException("您的路径不匹配");
        }
    }

    @Override
    public int delete(Uri uri, String selection, String[] selectionArgs) {
        int code = sURIMather.match(uri);
        if (code == DELETESUCCESS) {
            SQLiteDatabase db = mOpenHelper.getWritableDatabase();
            int user = db.delete("user", selection, selectionArgs);

            return user;
        } else {
            throw new IllegalArgumentException("您的路径不匹配");
        }

    }

    @Override
    public int update(Uri uri, ContentValues values, String selection, String[] selectionArgs) {
        int code = sURIMather.match(uri);
        if (code == INSERTUCCESS) {
            SQLiteDatabase db = mOpenHelper.getWritableDatabase();
            int user = db.update("user", values, selection, selectionArgs);
            return user;
        } else {
            throw new IllegalArgumentException("您的路径不匹配");
        }
    }
}


  • MySQLiteDataBase
package com.example.www.app2;

import android.content.Context;
import android.database.sqlite.SQLiteDatabase;
import android.database.sqlite.SQLiteOpenHelper;

public class MySQLiteDataBase extends SQLiteOpenHelper {
    public MySQLiteDataBase(Context context) {
        super(context, "test.db", null, 1);
    }

    @Override
    public void onCreate(SQLiteDatabase db) {
        String sql = "create table user(id INTEGER PRIMARY KEY AUTOINCREMENT, name varchar(20), age int)";
        db.execSQL(sql);
    }

    @Override
    public void onUpgrade(SQLiteDatabase db, int oldVersion, int newVersion) {

    }
}

  • activity_main.xml
<?xml version="1.0" encoding="utf-8"?>
<android.support.constraint.ConstraintLayout xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:app="http://schemas.android.com/apk/res-auto"
    xmlns:tools="http://schemas.android.com/tools"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    tools:context=".MainActivity">

    <EditText
        android:id="@+id/editText"
        android:layout_width="180dp"
        android:layout_height="wrap_content"
        android:layout_marginStart="8dp"
        android:layout_marginTop="8dp"
        android:ems="10"
        android:hint="姓名"
        android:inputType="textPersonName"
        app:layout_constraintStart_toStartOf="parent"
        app:layout_constraintTop_toTopOf="parent" />

    <android.support.constraint.Guideline
        android:id="@+id/guideline"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:orientation="vertical" />

    <EditText
        android:id="@+id/editText2"
        android:layout_width="0dp"
        android:layout_height="wrap_content"
        android:layout_marginTop="8dp"
        android:layout_marginEnd="8dp"
        android:ems="10"
        android:hint="年龄"
        android:inputType="number"
        app:layout_constraintEnd_toEndOf="parent"
        app:layout_constraintStart_toEndOf="@+id/editText"
        app:layout_constraintTop_toTopOf="parent" />

    <Button
        android:id="@+id/button"
        android:layout_width="0dp"
        android:layout_height="wrap_content"
        android:layout_marginStart="8dp"
        android:layout_marginTop="8dp"
        android:layout_marginEnd="8dp"
        android:text="插入"
        app:layout_constraintEnd_toEndOf="parent"
        app:layout_constraintStart_toStartOf="parent"
        app:layout_constraintTop_toBottomOf="@+id/editText"
        android:onClick="insert"/>

    <Button
        android:id="@+id/button2"
        android:layout_width="362dp"
        android:layout_height="wrap_content"
        android:layout_marginStart="164dp"
        android:layout_marginTop="24dp"
        android:layout_marginEnd="8dp"
        android:text="查询"
        app:layout_constraintEnd_toEndOf="parent"
        app:layout_constraintHorizontal_bias="1.0"
        app:layout_constraintStart_toStartOf="parent"
        app:layout_constraintTop_toBottomOf="@+id/button"
        android:onClick="query"/>

    <TextView
        android:id="@+id/textView"
        android:layout_width="0dp"
        android:layout_height="0dp"
        android:layout_marginStart="8dp"
        android:layout_marginTop="8dp"
        android:layout_marginEnd="8dp"
        android:layout_marginBottom="8dp"
        android:textColor="@android:color/black"
        app:layout_constraintBottom_toBottomOf="parent"
        app:layout_constraintEnd_toEndOf="parent"
        app:layout_constraintStart_toStartOf="parent"
        app:layout_constraintTop_toBottomOf="@+id/button2" />
</android.support.constraint.ConstraintLayout>
  • AndroidManifest.xml
<?xml version="1.0" encoding="utf-8"?>
<manifest xmlns:android="http://schemas.android.com/apk/res/android"
    package="com.example.www.app2">

    <application
        android:allowBackup="true"
        android:icon="@mipmap/ic_launcher"
        android:label="@string/app_name"
        android:roundIcon="@mipmap/ic_launcher_round"
        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>
        <provider
            android:name=".MyContentProvider"
            android:exported="true"
            android:authorities="com.wl.lhw">
        </provider>
    </application>

</manifest>
第二个应用
  • MainActivity
package com.example.www.providerdemo;

import android.content.ContentValues;
import android.database.Cursor;
import android.net.Uri;
import android.support.v7.app.AppCompatActivity;
import android.os.Bundle;
import android.view.View;
import android.widget.TextView;
import android.widget.Toast;

import java.net.URI;
import java.net.URL;

public class MainActivity extends AppCompatActivity {

    private TextView mTv_content;

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);

        mTv_content = (TextView) findViewById(R.id.textView);
    }

    public void query(View view) {
        Uri uri = Uri.parse("content://com.wl.lhw/query"); // 路径和 定义的路径一样(在contentProvider中定义的)
        Cursor cursor = getContentResolver().query(uri, null, null, null, null);
        StringBuffer sb = new StringBuffer();
        if (cursor.moveToFirst()) {
            do {

                String name = cursor.getString(cursor.getColumnIndex("name"));
                int age = cursor.getInt(cursor.getColumnIndex("age"));
                sb.append("姓名: ").append(name).append("----").append("年龄: ").append(age);

                sb.append("\n");

            } while (cursor.moveToNext());

            mTv_content.setText(sb.toString());
        }
    }

    public void insert(View view) {
        Uri uri = Uri.parse("content://com.wl.lhw/insert"); // 路径和 定义的路径一样(在contentProvider中定义的)
        ContentValues cv = new ContentValues();
        cv.put("name", "lhw" + Math.random());
        cv.put("age", 20);
        Uri insert = getContentResolver().insert(uri, cv);
        System.out.println("insert: " + insert);
    }

    public void update(View view) {
        Toast.makeText(this, "暂时没做更新数据", Toast.LENGTH_SHORT).show();
    }

    public void delete(View view) {
        Toast.makeText(this, "暂时没做删除数据", Toast.LENGTH_SHORT).show();
    }
}

  • activity_main.xml
<?xml version="1.0" encoding="utf-8"?>
<android.support.constraint.ConstraintLayout xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:app="http://schemas.android.com/apk/res-auto"
    xmlns:tools="http://schemas.android.com/tools"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    tools:context=".MainActivity">

    <Button
        android:id="@+id/button"
        android:layout_width="0dp"
        android:layout_height="wrap_content"
        android:layout_marginStart="8dp"
        android:layout_marginTop="8dp"
        android:layout_marginEnd="8dp"
        android:onClick="query"
        android:text="查询"
        app:layout_constraintEnd_toEndOf="parent"
        app:layout_constraintStart_toStartOf="parent"
        app:layout_constraintTop_toBottomOf="@+id/button2" />

    <TextView
        android:id="@+id/textView"
        android:layout_width="0dp"
        android:layout_height="0dp"
        android:layout_marginStart="8dp"
        android:layout_marginTop="8dp"
        android:layout_marginEnd="8dp"
        android:layout_marginBottom="8dp"
        app:layout_constraintBottom_toBottomOf="parent"
        app:layout_constraintEnd_toEndOf="parent"
        app:layout_constraintStart_toStartOf="parent"
        app:layout_constraintTop_toBottomOf="@+id/button" />

    <Button
        android:id="@+id/button2"
        android:layout_width="0dp"
        android:layout_height="wrap_content"
        android:layout_marginStart="8dp"
        android:layout_marginTop="8dp"
        android:layout_marginEnd="8dp"
        android:text="插入"
        app:layout_constraintEnd_toStartOf="@+id/button3"
        app:layout_constraintStart_toStartOf="parent"
        app:layout_constraintTop_toTopOf="parent"
        android:onClick="insert"/>

    <Button
        android:id="@+id/button3"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:layout_marginTop="8dp"
        android:layout_marginEnd="8dp"
        android:text="修改"
        app:layout_constraintEnd_toStartOf="@+id/button4"
        app:layout_constraintTop_toTopOf="parent"
        android:onClick="update"/>

    <Button
        android:id="@+id/button4"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:layout_marginTop="8dp"
        android:layout_marginEnd="8dp"
        android:text="删除"
        app:layout_constraintEnd_toEndOf="parent"
        app:layout_constraintTop_toTopOf="parent"
        android:onClick="delete"/>
</android.support.constraint.ConstraintLayout>
  • AndroidManifest.xml
<?xml version="1.0" encoding="utf-8"?>
<manifest xmlns:android="http://schemas.android.com/apk/res/android"
    package="com.example.www.providerdemo">

    <application
        android:allowBackup="true"
        android:icon="@mipmap/ic_launcher"
        android:label="@string/app_name"
        android:roundIcon="@mipmap/ic_launcher_round"
        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>
【基于QT的调色板】是一个使用Qt框架开发的色彩选择工具,类似于Windows操作系统中常见的颜色选取器。Qt是一个跨平台的应用程序开发框架,广泛应用于桌面、移动和嵌入式设备,支持C++和QML语言。这个调色板功能提供了横竖两种渐变模式,用户可以方便地选取所需的颜色值。 在Qt中,调色板(QPalette)是一个关键的类,用于管理应用程序的视觉样式。QPalette包含了一系列的颜色角色,如背景色、前景色、文本色、高亮色等,这些颜色可以根据用户的系统设置或应用程序的需求进行定制。通过自定义QPalette,开发者可以创建具有独特视觉风格的应用程序。 该调色板功能可能使用了QColorDialog,这是一个标准的Qt对话框,允许用户选择颜色。QColorDialog提供了一种简单的方式来获取用户的颜色选择,通常包括一个调色板界面,用户可以通过滑动或点击来选择RGB、HSV或其他色彩模型中的颜色。 横渐变取色可能通过QGradient实现,QGradient允许开发者创建线性或径向的色彩渐变。线性渐变(QLinearGradient)沿直线从一个点到另一个点过渡颜色,而径向渐变(QRadialGradient)则以圆心为中心向外扩散颜色。在调色板中,用户可能可以通过滑动条或鼠标拖动来改变渐变的位置,从而选取不同位置的颜色。 竖渐变取色则可能是通过调整QGradient的方向来实现的,将原本水平的渐变方向改为垂直。这种设计可以提供另一种方式来探索颜色空间,使得选取颜色更为直观和便捷。 在【colorpanelhsb】这个文件名中,我们可以推测这是与HSB(色相、饱和度、亮度)色彩模型相关的代码或资源。HSB模型是另一种常见且直观的颜色表示方式,与RGB或CMYK模型不同,它以人的感知为基础,更容易理解。在这个调色板中,用户可能可以通过调整H、S、B三个参数来选取所需的颜色。 基于QT的调色板是一个利用Qt框架和其提供的色彩管理工具,如QPalette、QColorDialog、QGradient等,构建的交互式颜色选择组件。它不仅提供了横竖渐变的色彩选取方式,还可能支持HSB色彩模型,使得用户在开发图形用户界面时能更加灵活和精准地控制色彩。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

ITzhongzi

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值