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
| --- |
|---|