Android四大組件——ContentProvider

ContentProvider的作用

①使用Android提供的API訪問系統(tǒng)程序中的數據,如獲取手機聯系人的數據等等。
②創(chuàng)建自己程序的內容提供者,提供外部訪問接口給其他程序。外部程序可以對其開放的數據進行增、刪、改、查。

ContentResolver類

作用:任何想要訪問內容提供器中共享的數據,都需要借助該類的實例,通過getContentResolver()方法得到。

ContentResolver的增刪改查

insert()方法
通過ContentValues類的put()方法以鍵值對的形式添加數據

    public final Uri insert(Uri url, ContentValues values) {
    }
            ContentValues values = new ContentValues();
            values.put("price", 16.95);
            getContentResolver().insert(ContactsContract.CommonDataKinds
                    .Phone.CONTENT_URI, values);

delete()方法

    public final int delete(Uri url, String where, String[] selectionArgs) {
    }

update()方法

    public final int update(Uri uri, ContentValues values, String where, String[] selectionArgs) {
    }

query()方法
注意函數的返回值為Cursor類
第一個參數指定某個程序下的一張表
第二個參數指定查詢的列名
第三個參數為where的約束條件
第四個參數為where提供具體的值
第五個參數為結果的排序方式

    public final Cursor query(Uri uri, String[] projection, String selection, 
String[] selectionArgs, String sortOrder) {
    }

訪問其他程序的數據--訪問通訊錄

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);
        contactsView = (ListView) findViewById(R.id.contacts_view);
        adapter = new ArrayAdapter<String>(this, android.R.layout.simple_list_item_1,
                contactsList);
        contactsView.setAdapter(adapter);
        //申請讀取通訊錄權限
        if (ContextCompat.checkSelfPermission(this, Manifest.permission.READ_CONTACTS)
                != PackageManager.PERMISSION_GRANTED) {
            ActivityCompat.requestPermissions(this, new String[]{
                    Manifest.permission.READ_CONTACTS
            }, 1);
        } else {
            readContacts();
        }
    }

    private void readContacts() {
        Cursor cursor = null;
        try {
            //查詢聯系人數據
            cursor = getContentResolver().query(ContactsContract.CommonDataKinds
                    .Phone.CONTENT_URI, null, null, null, null);
            if (cursor != null) {
                //使用cursor遍歷數據
                while (cursor.moveToNext()) {
                    //獲取聯系人姓名
                    String name = cursor.getString(cursor.getColumnIndex(
                            ContactsContract.CommonDataKinds.Phone.DISPLAY_NAME
                    ));
                    //獲取聯系人手機號碼
                    String phoneNumber = cursor.getString(cursor.getColumnIndex(
                            ContactsContract.CommonDataKinds.Phone.NUMBER
                    ));
                    contactsList.add(name + "\n" + phoneNumber);
                    //刷新ListView數據
                    adapter.notifyDataSetChanged();
                }
            }
        } catch (Exception e) {
            e.printStackTrace();
        } finally {
            if (cursor != null) {
                //關閉游標
                cursor.close();
            }
        }
    }

    //權限申請結果回調
    @Override
    public void onRequestPermissionsResult(int requestCode, @NonNull String[] permissions, @NonNull int[] grantResults) {
        switch (requestCode) {
            case 1:
                if (grantResults.length > 0 && grantResults[0] == PackageManager
                        .PERMISSION_GRANTED) {
                    //申請權限成功執(zhí)行的業(yè)務邏輯
                    readContacts();
                } else {
                    //申請權限失敗執(zhí)行的業(yè)務邏輯
                    Toast.makeText(this, "you denied the permission", Toast.LENGTH_SHORT).show();
                }
                break;
            default:
                break;
        }
    }
}
圖片.png

自定義ContentProvider

public class MyContentProvider extends ContentProvider {
    //要暴露給其他程序訪問的數據表
    public static final int TABLE_STUDENT = 0;
    public static final int TABLE_BOOK = 1;

    private static UriMatcher uriMatcher;
    

    static {
        uriMatcher = new UriMatcher(UriMatcher.NO_MATCH);
        //第一個參數為authority,第二個參數為path,第三個參數為對應表的常量
        uriMatcher.addURI("com.example.shaw.application", "table1", TABLE_STUDENT);
        uriMatcher.addURI("com.example.shaw.application", "table2/#", TABLE_BOOK);
    }

    /**
     *
     * @param uri
     * @param selection
     * @param selectionArgs
     * @return 被刪除的行數
     */
    @Override
    public int delete(Uri uri, String selection, String[] selectionArgs) {
        switch (uriMatcher.match(uri)) {
            //對TABLE_BOOK表的操作
            case TABLE_BOOK:
                break;
            //對TABLE_STUDENT的操作
            case TABLE_STUDENT:
                break;
        }
        return ;
    }

    /**
     * 根據傳入的內容URI來返回相遇的MIME類型
     * MIME字符串:以vnd開頭;如果內容URI以路徑結尾,則后接android.cursor.dir/,
     * 如果URI以id結尾,則后接android.cursor.item/;最后接上vnd.<authority>.<path>
     */
    @Override
    public String getType(Uri uri) {
        switch (uriMatcher.match(uri)) {
            case TABLE_STUDENT:
                //由static可得出
                return "vnd.android.cursor.dir/vnd.com.example.shaw.application.table1";
            case TABLE_BOOK:
                return "vnd.android.cursor.item/vnd.com.example.shaw.application.table2";
        }
        return null;
    }

    /**
     *
     * @param uri
     * @param values
     * @return 一個用于表示這條新紀錄的URI
     * uri格式:content://<authority>/path/新數據
     * 使用Uri.parse()方法拼接參數作為返回值
     */
    @Override
    public Uri insert(Uri uri, ContentValues values) {
        switch (uriMatcher.match(uri)){
            case TABLE_BOOK:
                break;
        }
    }

    @Override
    public boolean onCreate() {
        //數據初始化,數據庫的創(chuàng)建升級等操作
    }

    /**
     *
     * @param uri
     * @param projection
     * @param selection
     * @param selectionArgs
     * @param sortOrder
     * @return 查詢結果,存放在cursor中
     */
    @Override
    public Cursor query(Uri uri, String[] projection, String selection,
                        String[] selectionArgs, String sortOrder) {
        switch (uriMatcher.match(uri)){
            //使用數據庫的查詢方法
            case TABLE_BOOK:
        }
    }

    /**
     *
     * @param uri
     * @param values
     * @param selection
     * @param selectionArgs
     * @return 受影響的行數
     */
    @Override
    public int update(Uri uri, ContentValues values, String selection,
                      String[] selectionArgs) {
        //使用數據庫的更新方法
        switch (uriMatcher.match(uri)){
            case TABLE_BOOK:
        }
    }
}

在其他程序中訪問

    Uri uri=Uri.parse("content://authority.path/table");
    Cursor cursor=getContentResolver().query(uri,null,null,null,null,null);
    ContentValues contentValues=new ContentValues();
    contentValues.put("","");
    Uri uri=getContentResolver.insert(uri,contentValues);
    getContentResolver.update(uri,....);
    getContentResolver.delete(uri,....);
最后編輯于
?著作權歸作者所有,轉載或內容合作請聯系作者
【社區(qū)內容提示】社區(qū)部分內容疑似由AI輔助生成,瀏覽時請結合常識與多方信息審慎甄別。
平臺聲明:文章內容(如有圖片或視頻亦包括在內)由作者上傳并發(fā)布,文章內容僅代表作者本人觀點,簡書系信息發(fā)布平臺,僅提供信息存儲服務。

相關閱讀更多精彩內容

友情鏈接更多精彩內容