Skip to main content

Content Provider in Android (Part 1)


 Today, I will introduce about Content Provider in Android.

What's is Content Provider?

- Content Provider store and retrieve data. Content Provider will make data accessible to all applications. This is unique way to share data across applications.
- Android provide a number of Content Provider for common data types (audio, video, images, bookmarks, contact,...). Query these providers for the data contained. (although, for some, must acquire the proper permission to read/write data).

There're 2 ways to make data public:

- Create your own Content Provider.
- Add your data to existing Content Provider.

Example 1: Displays Bookmark of System Browser.

- Permission is required to access Browser Content. Declare 2 below lines in AndroidManifest.xml file:

<uses-permission android:name="com.android.browser.permission.READ_HISTORY_BOOKMARKS">
<uses-permission android:name="com.android.broswer.permission.WRITE_HISTORY_BOOKMARKS"> 

 - Retrieve data and display them in List view. Create a ListActivity:

package com.jbohn.contentprovider;

import android.app.ListActivity;
import android.database.Cursor;
import android.os.Bundle;
import android.provider.Browser;
import android.widget.SimpleCursorAdapter;

public class ContentProviderBrowserActivity extends ListActivity
{

 @Override
 public void onCreate( Bundle savedInstanceState )
 {
  super.onCreate( savedInstanceState );
  setContentView( R.layout.activitybrowser );
  
  //Projection for the interesting columns of a Bookmark
  String[] projection = new String[] { Browser.BookmarkColumns._ID,
    Browser.BookmarkColumns.TITLE, Browser.BookmarkColumns.URL };
  
  //Do query to retrieve data(bookmarks) from Browser
  Cursor cursor = managedQuery( android.provider.Browser.BOOKMARKS_URI,
    projection, null, null, null );
  
  //Put data to a List Activity
  String[] displayFields = new String[] { Browser.BookmarkColumns.TITLE,
    Browser.BookmarkColumns.URL };
  int[] displayViews = new int[] { android.R.id.text1, android.R.id.text2 };
    
  setListAdapter( new SimpleCursorAdapter( this,
    android.R.layout.simple_list_item_2, cursor, displayFields,
    displayViews ) );
 }
}
Tobe continue... 
(http://jbohn.blogspot.com) 

Comments

Popular posts from this blog

How to Install SQL Server on MacOS with docker

 I'm writing a small tut for who need to install SQL Server on macOS using docker Step 1: Download the SQL Server Image sudo docker pull mcr.microsoft.com/mssql/server:2019-latest Step 2: Launch the SQL Server Image in Docker docker run -d --name example_sql_server -e 'ACCEPT_EULA=Y' -e 'SA_PASSWORD=Pass.word-123' -p 1433:1433 mcr.microsoft.com/mssql/server:2019-latest Step 3: Check the SQL Server Docker Container docker ps -a Step 4: Install SQL Server Command-Line Tool sudo npm install -g sql-cli Step 5: Connect to SQL Server  5.1 Using Command mssql -u sa -p Pass.word-123 5.2: Using VSCode to connect to sql server Using the extension SQL Server (mssql)

Create Grid using React native

After fist post about react native I feel I'm getting familiar with react native, this framework quite easy to use, today I continue with another tutorial about create a simple grid card in react native. Let see the our final result first:                             Let's start... Analytics Assump our data has below structure: We have an array of rows and each row has an array of columns, then I decided to use FlatList to display object in cloumns array in horizontal direction, you can imaging like below image. Gridcard design Card Item each card has a logo and a text. I'm using the Icon from lib react-native-vector-icons To have a flatlist in horizontal we use  horizontal = {true} property, and to make sure the width of flatlist is same as screen with we use  contentContainerStyle={{ flexGrow: 1, justifyContent: 'center' }} Grid Now the implementation quite easy now, just need to...