Pular para o conteúdo principal

Exemplo do Android ContentProvider

Este é um tutorial "Fornecedor de Conteúdos". Através de vários exemplos, você aprenderá como utilizar o provedor de conteúdo para carregar dados de um dispositivo andróide. O "ContentProvider" é um dos componentes fundamentais do andróide, juntamente com a "atividade", "serviço", "aplicação" e "provedor de conteúdos". Como tal, é importante para sua jornada de desenvolvimento do andróide.

Exemplo 1 - Como carregar os contatos do dispositivo.

Este exemplo examina como utilizar o "provedor de conteúdo" para carregar contatos de qualquer dispositivo andróide.

Passo 1: Dependências

Não é necessária a dependência de terceiros.

Passo 2: Adicionar permissões

Para ler os contatos de um dispositivo do usuário, você precisa da permissão do usuário. Assim, você precisa adicionar a permissão `READ_CONTACTS' que será mostrada ao usuário quando o usuário estiver instalando seu aplicativo.

<uses-permission android:name="android.permission.READ_CONTACTS"/>

Passo 3: Design UI

A UI compreenderá um botão de visualização de lista. O usuário pressiona o botão e os contatos são buscados e carregados na visualização de lista.

**activity_main.xml***

<?xml version="1.0" encoding="utf-8"?>
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:tools="http://schemas.android.com/tools"
android:layout_width="match_parent"
android:layout_height="match_parent"
tools:context="com.parag.contentprovidersample.MainActivity">

<Button
android:id="@+id/btn"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:text="Get contact names"
android:layout_margin="10dp"
/>

<ListView
android:id="@+id/listview"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:layout_below="@+id/btn"
android:layout_margin="10dp"/>

</RelativeLayout>

Passo 3: Escrever Código

O código está em java, mas pode ser convertido para kotlin.

**MainActivity.java***

Adicionar importações, incluindo o LoaderManager' e o cursorLoader':

import android.app.LoaderManager;
import android.content.CursorLoader;
import android.content.Loader;
import android.database.Cursor;
import android.net.Uri;
import android.provider.ContactsContract;
import android.support.v7.app.AppCompatActivity;
import android.os.Bundle;
import android.util.Log;
import android.view.View;
import android.widget.ArrayAdapter;
import android.widget.Button;
import android.widget.ListView;

import java.util.ArrayList;

Ampliar a appcompactividade e implementar várias interfaces incluindo o LoaderManager.LoaderCallbacks<Cursor>:

public class MainActivity extends AppCompatActivity implements View.OnClickListener,LoaderManager.LoaderCallbacks<Cursor>{

Declarar nossos widgets UI, bem como a projeção:

    Button button;
ListView listView;
String[] projection = {ContactsContract.Contacts.DISPLAY_NAME};
boolean hasLoaded;

Aqui está o resto do código:

    @Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
button = (Button)findViewById(R.id.btn);
listView = (ListView)findViewById(R.id.listview);
button.setOnClickListener(this);

}

@Override
public Loader<Cursor> onCreateLoader(int i, Bundle bundle) { // CursorLoader instance
Uri uri = ContactsContract.Contacts.CONTENT_URI;
String orderBy = ContactsContract.Contacts.DISPLAY_NAME_PRIMARY;
if(i == 1) {
return new CursorLoader(this,uri ,projection,null,null,orderBy);
}
else
{
return null;
}
}

@Override
public void onLoadFinished(Loader<Cursor> loader, Cursor cursor) {

ArrayList<String> contactList = new ArrayList<>();
if(cursor != null && cursor.getCount() > 0)
{
while(cursor.moveToNext())
{
contactList.add(cursor.getString(0));
}
ArrayAdapter<String> contactArrayAdapter = new ArrayAdapter<>(this,android.R.layout.simple_list_item_1,contactList);
listView.setAdapter(contactArrayAdapter);
}
}

@Override
public void onLoaderReset(Loader<Cursor> loader) {

}

@Override
public void onClick(View view) {
switch (view.getId())
{
case R.id.btn:
if(!hasLoaded)
{
getLoaderManager().initLoader(1,null,this);
hasLoaded = true;
}
else
{
getLoaderManager().restartLoader(1,null,this);
}
}
}
}

Referência

---