Auf dieser Seite erfahren Sie, wie Sie ein QuickContactBadge
zu Ihrer UI hinzufügen.
und wie Daten daran gebunden werden. Ein QuickContactBadge
ist ein Widget, das anfangs als Thumbnail angezeigt wird. Sie können zwar jedes Bitmap
für das Thumbnail verwenden, in der Regel wird jedoch ein Bitmap
verwendet, das aus dem Thumbnail-Bild des Kontakts decodiert wurde.
Das kleine Bild dient als Steuerelement. wenn Nutzende auf das Bild tippen,
QuickContactBadge
wird zu einem Dialogfeld mit Folgendem erweitert:
- Ein großes Bild
- Das große Bild, das mit dem Kontakt verknüpft ist, oder, falls kein Bild verfügbar ist, ein Platzhalter Grafik.
- App-Symbole
- Ein App-Symbol für jedes Detaildatenelement, das von einer integrierten App verarbeitet werden kann. Wenn die Details des Kontakts beispielsweise eine oder mehrere E-Mail-Adressen enthalten, wird ein E-Mail-Symbol angezeigt. Wenn ein Nutzer auf das Symbol tippt, werden alle E-Mail-Adressen des Kontakts angezeigt. Wenn Nutzer auf eine der Adressen tippen, wird in der E-Mail-App ein Bildschirm zum Verfassen einer Nachricht an die ausgewählte E-Mail-Adresse angezeigt.
In der Ansicht QuickContactBadge
können Sie sofort auf die Details eines Kontakts zugreifen und schnell mit ihm kommunizieren. Nutzer müssen keinen Kontakt suchen, Informationen finden und kopieren und dann in die entsprechende App einfügen. Stattdessen können sie auf QuickContactBadge
tippen, die gewünschte Kommunikationsmethode auswählen und die Informationen für diese Methode direkt an die entsprechende App senden.
QuickContactBadge-Ansicht hinzufügen
Um ein QuickContactBadge
hinzuzufügen, fügen Sie ein
<QuickContactBadge>
-Element in Ihrem Layout verwenden, wie im folgenden Beispiel gezeigt:
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android" android:layout_width="match_parent" android:layout_height="match_parent"> ... <QuickContactBadge android:id=@+id/quickbadge android:layout_height="wrap_content" android:layout_width="wrap_content" android:scaleType="centerCrop"/> ... </RelativeLayout>
Anbieterdaten abrufen
Wenn Sie einen Kontakt in der QuickContactBadge
anzeigen lassen möchten, benötigen Sie einen Inhalts-URI für den Kontakt und einen Bitmap
für das kleine Bild. Sie generieren
sowohl der Inhalts-URI als auch die Bitmap
aus den Spalten, die aus dem
Kontaktanbieter. Geben Sie diese Spalten als Teil der Projektion an, in die Sie Daten laden.
Cursor
Fügen Sie für Android 3.0 (API-Level 11) und höher die folgenden Spalten in Ihre Projektion ein:
Verwenden Sie ab Android 2.3.3 (API-Level 10) die folgenden Spalten:
Bei den Beispielen auf dieser Seite wird davon ausgegangen,
Cursor
, die diese und alle anderen ausgewählten Spalten enthalten
Spalten wurden geladen. Informationen zum Abrufen von Spalten in einem Cursor
finden Sie unter
Liste von Kontakten abrufen
Kontakt-URI und Thumbnail festlegen
Sobald Sie die erforderlichen Spalten haben, können Sie Daten an die QuickContactBadge
binden.
Kontakt-URI festlegen
Um den Inhalts-URI für den Kontakt festzulegen, rufen Sie
getLookupUri(id,lookupKey)
bis
CONTENT_LOOKUP_URI
erhalten, dann
assignContactUri()
aufrufen, um
Kontakt. Dies wird im folgenden Beispiel gezeigt:
Kotlin
// The Cursor that contains contact rows var cursor: Cursor? = null // The index of the _ID column in the Cursor var idColumn: Int = 0 // The index of the LOOKUP_KEY column in the Cursor var lookupKeyColumn: Int = 0 // A content URI for the desired contact var contactUri: Uri? = null // A handle to the QuickContactBadge view ... cursor?.let { cursor -> /* * Insert code here to move to the desired cursor row */ // Gets the _ID column index idColumn = cursor.getColumnIndex(ContactsContract.Contacts._ID) // Gets the LOOKUP_KEY index lookupKeyColumn = cursor.getColumnIndex(ContactsContract.Contacts.LOOKUP_KEY) // Gets a content URI for the contact contactUri = ContactsContract.Contacts.getLookupUri( cursor.getLong(idColumn), cursor.getString(lookupKeyColumn) ) binding.badge.assignContactUri(contactUri) }
Java
// The Cursor that contains contact rows Cursor cursor; // The index of the _ID column in the Cursor int idColumn; // The index of the LOOKUP_KEY column in the Cursor int lookupKeyColumn; // A content URI for the desired contact Uri contactUri; ... /* * Insert code here to move to the desired cursor row */ // Gets the _ID column index idColumn = cursor.getColumnIndex(ContactsContract.Contacts._ID); // Gets the LOOKUP_KEY index lookupKeyColumn = cursor.getColumnIndex(ContactsContract.Contacts.LOOKUP_KEY); // Gets a content URI for the contact contactUri = Contacts.getLookupUri( cursor.getLong(idColumn), cursor.getString(lookupKeyColumn) ); binding.badge.assignContactUri(contactUri);
Wenn Nutzer auf das Symbol QuickContactBadge
tippen, werden die Details des Kontakts im Dialogfeld angezeigt.
Miniaturansicht des Fotos festlegen
Wenn Sie den Kontakt-URI für die QuickContactBadge
festlegen, wird das Miniaturbild des Kontakts nicht automatisch geladen. Um das Foto zu laden, rufen Sie einen URI für das Foto aus der
Zeile Cursor
des Kontakts haben, öffnen Sie damit die Datei mit der komprimierten Datei.
Miniaturansicht und lesen Sie die Datei in ein Bitmap
.
Hinweis: Die Spalte PHOTO_THUMBNAIL_URI
ist in Plattformversionen vor 3.0 nicht verfügbar. Für diese Versionen müssen Sie den URI abrufen.
aus der untergeordneten Tabelle Contacts.Photo
.
Legen Sie zuerst Variablen für den Zugriff auf die Cursor
mit den Spalten Contacts._ID
und Contacts.LOOKUP_KEY
fest:
Kotlin
// The column in which to find the thumbnail ID var thumbnailColumn: Int = 0 /* * The thumbnail URI, expressed as a String. * Contacts Provider stores URIs as String values. */ var thumbnailUri: String? = null ... cursor?.let { cursor -> /* * Gets the photo thumbnail column index if * platform version >= Honeycomb */ thumbnailColumn = if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.HONEYCOMB) { cursor.getColumnIndex(ContactsContract.Contacts.PHOTO_THUMBNAIL_URI) // Otherwise, sets the thumbnail column to the _ID column } else { idColumn } /* * Assuming the current Cursor position is the contact you want, * gets the thumbnail ID */ thumbnailUri = cursor.getString(thumbnailColumn) }
Java
// The column in which to find the thumbnail ID int thumbnailColumn; /* * The thumbnail URI, expressed as a String. * Contacts Provider stores URIs as String values. */ String thumbnailUri; ... /* * Gets the photo thumbnail column index if * platform version >= Honeycomb */ if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.HONEYCOMB) { thumbnailColumn = cursor.getColumnIndex(ContactsContract.Contacts.PHOTO_THUMBNAIL_URI); // Otherwise, sets the thumbnail column to the _ID column } else { thumbnailColumn = idColumn; } /* * Assuming the current Cursor position is the contact you want, * gets the thumbnail ID */ thumbnailUri = cursor.getString(thumbnailColumn); ...
Definieren Sie eine Methode, die fotobezogene Daten für den Kontakt und die Abmessungen für die
Zielansicht und gibt die Miniaturansicht in der richtigen Größe
Bitmap
Erstellen Sie zuerst einen URI, der auf die
Miniaturansicht:
Kotlin
/** * Load a contact photo thumbnail and return it as a Bitmap, * resizing the image to the provided image dimensions as needed. * @param photoData photo ID Prior to Honeycomb, the contact's _ID value. * For Honeycomb and later, the value of PHOTO_THUMBNAIL_URI. * @return A thumbnail Bitmap, sized to the provided width and height. * Returns null if the thumbnail is not found. */ private fun loadContactPhotoThumbnail(photoData: String): Bitmap? { // Creates an asset file descriptor for the thumbnail file var afd: AssetFileDescriptor? = null // try-catch block for file not found try { // Creates a holder for the URI val thumbUri: Uri = if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.HONEYCOMB) { // If Android 3.0 or later, // sets the URI from the incoming PHOTO_THUMBNAIL_URI Uri.parse(photoData) } else { // Prior to Android 3.0, constructs a photo Uri using _ID /* * Creates a contact URI from the Contacts content URI * incoming photoData (_ID) */ val contactUri: Uri = Uri.withAppendedPath(ContactsContract.Contacts.CONTENT_URI, photoData) /* * Creates a photo URI by appending the content URI of * Contacts.Photo */ Uri.withAppendedPath(contactUri, ContactsContract.Contacts.Photo.CONTENT_DIRECTORY) } /* * Retrieves an AssetFileDescriptor object for the thumbnail URI * using ContentResolver.openAssetFileDescriptor */ afd = activity?.contentResolver?.openAssetFileDescriptor(thumbUri, "r") /* * Gets a file descriptor from the asset file descriptor. * This object can be used across processes. */ return afd?.fileDescriptor?.let {fileDescriptor -> // Decodes the photo file and returns the result as a Bitmap // if the file descriptor is valid BitmapFactory.decodeFileDescriptor(fileDescriptor, null, null) } } catch (e: FileNotFoundException) { /* * Handle file not found errors */ null } finally { // In all cases, close the asset file descriptor try { afd?.close() } catch (e: IOException) { } } }
Java
/** * Load a contact photo thumbnail and return it as a Bitmap, * resizing the image to the provided image dimensions as needed. * @param photoData photo ID Prior to Honeycomb, the contact's _ID value. * For Honeycomb and later, the value of PHOTO_THUMBNAIL_URI. * @return A thumbnail Bitmap, sized to the provided width and height. * Returns null if the thumbnail is not found. */ private Bitmap loadContactPhotoThumbnail(String photoData) { // Creates an asset file descriptor for the thumbnail file AssetFileDescriptor afd = null; // try-catch block for file not found try { // Creates a holder for the URI Uri thumbUri; // If Android 3.0 or later if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.HONEYCOMB) { // Sets the URI from the incoming PHOTO_THUMBNAIL_URI thumbUri = Uri.parse(photoData); } else { // Prior to Android 3.0, constructs a photo Uri using _ID /* * Creates a contact URI from the Contacts content URI * incoming photoData (_ID) */ final Uri contactUri = Uri.withAppendedPath( ContactsContract.Contacts.CONTENT_URI, photoData); /* * Creates a photo URI by appending the content URI of * Contacts.Photo */ thumbUri = Uri.withAppendedPath( contactUri, ContactsContract.Contacts.Photo.CONTENT_DIRECTORY); } /* * Retrieves an AssetFileDescriptor object for the thumbnail URI * using ContentResolver.openAssetFileDescriptor */ afd = getActivity().getContentResolver(). openAssetFileDescriptor(thumbUri, "r"); /* * Gets a file descriptor from the asset file descriptor. * This object can be used across processes. */ FileDescriptor fileDescriptor = afd.getFileDescriptor(); // Decodes the photo file and returns the result as a Bitmap // if the file descriptor is valid if (fileDescriptor != null) { // Decodes the bitmap return BitmapFactory.decodeFileDescriptor( fileDescriptor, null, null); } // If the file isn't found } catch (FileNotFoundException e) { /* * Handle file not found errors */ // In all cases, close the asset file descriptor } finally { if (afd != null) { try { afd.close(); } catch (IOException e) {} } } return null; }
Rufe in deinem Code die loadContactPhotoThumbnail()
-Methode auf, um die Miniaturansicht Bitmap
zu erhalten, und verwende das Ergebnis, um die Fotominiaturansicht in deiner QuickContactBadge
festzulegen:
Kotlin
... /* * Decodes the thumbnail file to a Bitmap */ mThumbnailUri?.also { thumbnailUri -> loadContactPhotoThumbnail(thumbnailUri).also { thumbnail -> /* * Sets the image in the QuickContactBadge. * QuickContactBadge inherits from ImageView. */ badge.setImageBitmap(thumbnail) } }
Java
... /* * Decodes the thumbnail file to a Bitmap */ Bitmap mThumbnail = loadContactPhotoThumbnail(thumbnailUri); /* * Sets the image in the QuickContactBadge. * QuickContactBadge inherits from ImageView. */ badge.setImageBitmap(mThumbnail);
ListView ein QuickContactBadge hinzufügen
Eine QuickContactBadge
ist eine nützliche Ergänzung zu einer ListView
, in der eine Liste mit Kontakten angezeigt wird. Mit der QuickContactBadge
können Sie ein Thumbnail-Foto für jeden Kontakt anzeigen. Wenn Nutzer auf das Thumbnail tippen, wird das Dialogfeld QuickContactBadge
angezeigt.
QuickContactBadge-Element hinzufügen
Fügen Sie Ihrem Elementlayout zuerst ein QuickContactBadge
-Ansichtselement hinzu
Wenn Sie beispielsweise ein QuickContactBadge
und einen Namen für
Fügen Sie für jeden abgerufenen Kontakt die folgende XML-Datei in eine Layoutdatei ein:
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android" android:layout_width="match_parent" android:layout_height="wrap_content"> <QuickContactBadge android:id="@+id/quickcontact" android:layout_height="wrap_content" android:layout_width="wrap_content" android:scaleType="centerCrop"/> <TextView android:id="@+id/displayname" android:layout_width="match_parent" android:layout_height="wrap_content" android:layout_toRightOf="@+id/quickcontact" android:gravity="center_vertical" android:layout_alignParentRight="true" android:layout_alignParentTop="true"/> </RelativeLayout>
In den folgenden Abschnitten wird diese Datei als contact_item_layout.xml
bezeichnet.
Benutzerdefinierten CursorAdapter einrichten
So binden Sie ein CursorAdapter
an ein ListView
QuickContactBadge
enthält, definieren Sie einen benutzerdefinierten Adapter,
verlängert CursorAdapter
. Mit diesem Ansatz können Sie die Daten in der Cursor
verarbeiten, bevor Sie sie an die QuickContactBadge
binden. Bei diesem Ansatz können Sie auch mehrere
Cursor
-Spalten zu QuickContactBadge
. Keine dieser Aktionen ist in einem regulären CursorAdapter
möglich.
Die von Ihnen definierte Unterklasse von CursorAdapter
muss die folgenden Methoden überschreiben:
CursorAdapter.newView()
-
Lüftet ein neues
View
-Objekt auf, das das Element-Layout enthält. In der Überschreibung speichern Sie Ziehpunkte für die untergeordnetenView
-Objekte des Layouts. einschließlich des untergeordnetenQuickContactBadge
. So müssen Sie nicht jedes Mal, wenn Sie ein neues Layout aufblähen, Handles für die untergeordnetenView
-Objekte abrufen.Du musst diese Methode überschreiben, um Handles für das einzelne untergeordnete Element abzurufen
View
-Objekte. Mit dieser Technik können Sie die BindungCursorAdapter.bindView()
CursorAdapter.bindView()
-
Verschiebt Daten aus der aktuellen
Cursor
-Zeile in die untergeordneteView
-Objekte des Elementlayouts. Sie müssen diese Methode überschreiben, können Sie sowohl den URI des Kontakts als auch die Miniaturansicht an dasQuickContactBadge
Die Standardimplementierung erlaubt nur eine Eins-zu-eins-Zuordnung zwischen einer Spalte und einerView
.
Das folgende Code-Snippet enthält ein Beispiel für eine benutzerdefinierte Unterklasse von CursorAdapter
:
Benutzerdefinierten Listenadapter definieren
Definieren Sie die untergeordnete Klasse von CursorAdapter
, einschließlich ihres Konstruktors, und überschreiben Sie newView()
und bindView()
:
Kotlin
/** * Defines a class that holds resource IDs of each item layout * row to prevent having to look them up each time data is * bound to a row */ private data class ViewHolder( internal var displayname: TextView? = null, internal var quickcontact: QuickContactBadge? = null ) /** * * */ private inner class ContactsAdapter( context: Context, val inflater: LayoutInflater = LayoutInflater.from(context) ) : CursorAdapter(context, null, 0) { ... override fun newView( context: Context, cursor: Cursor, viewGroup: ViewGroup ): View { /* Inflates the item layout. Stores view references * in a ViewHolder class to prevent having to look * them up each time bindView() is called. */ return ContactListLayoutBinding.inflate(inflater, viewGroup, false).also { binding -> view.tag = ViewHolder().apply { displayname = binding.displayname quickcontact = binding.quickcontact } }.root } ... override fun bindView(view: View?, context: Context?, cursor: Cursor?) { (view?.tag as? ViewHolder)?.also { holder -> cursor?.apply { ... // Sets the display name in the layout holder.displayname?.text = getString(displayNameIndex) ... /* * Generates a contact URI for the QuickContactBadge */ ContactsContract.Contacts.getLookupUri( getLong(idIndex), cursor.getString(lookupKeyIndex) ).also { contactUri -> holder.quickcontact?.assignContactUri(contactUri) } getString(photoDataIndex)?.also {photoData -> /* * Decodes the thumbnail file to a Bitmap. * The method loadContactPhotoThumbnail() is defined * in the section "Set the contact URI and thumbnail." */ loadContactPhotoThumbnail(photoData)?.also { thumbnailBitmap -> /* * Sets the image in the QuickContactBadge. * QuickContactBadge inherits from ImageView. */ holder.quickcontact?.setImageBitmap(thumbnailBitmap) } } } } } }
Java
private class ContactsAdapter extends CursorAdapter { private LayoutInflater inflater; ... public ContactsAdapter(Context context) { super(context, null, 0); /* * Gets an inflater that can instantiate * the ListView layout from the file */ inflater = LayoutInflater.from(context); ... } ... /** * Defines a class that holds resource IDs of each item layout * row to prevent having to look them up each time data is * bound to a row */ private class ViewHolder { TextView displayname; QuickContactBadge quickcontact; } ... @Override public View newView( Context context, Cursor cursor, ViewGroup viewGroup) { /* Inflates the item layout. Stores view references * in a ViewHolder class to prevent having to look * them up each time bindView() is called. */ final ContactListLayoutBinding binding = ContactListLayoutBinding.inflate(inflater, viewGroup, false); final ViewHolder holder = new ViewHolder(); holder.displayname = binding.displayName; holder.quickcontact = binding.quickContact; view.setTag(holder); return binding.root; } ... @Override public void bindView( View view, Context context, Cursor cursor) { final ViewHolder holder = (ViewHolder) view.getTag(); final String photoData = cursor.getString(photoDataIndex); final String displayName = cursor.getString(displayNameIndex); ... // Sets the display name in the layout holder.displayname = cursor.getString(displayNameIndex); ... /* * Generates a contact URI for the QuickContactBadge */ final Uri contactUri = Contacts.getLookupUri( cursor.getLong(idIndex), cursor.getString(lookupKeyIndex)); holder.quickcontact.assignContactUri(contactUri); String photoData = cursor.getString(photoDataIndex); /* * Decodes the thumbnail file to a Bitmap. * The method loadContactPhotoThumbnail() is defined * in the section "Set the contact URI and thumbnail." */ Bitmap thumbnailBitmap = loadContactPhotoThumbnail(photoData); /* * Sets the image in the QuickContactBadge. * QuickContactBadge inherits from ImageView. */ holder.quickcontact.setImageBitmap(thumbnailBitmap); }
Variablen einrichten
Erstellen Sie in Ihrem Code Variablen, einschließlich einer Cursor
-Projektion mit den erforderlichen Spalten, wie im folgenden Beispiel gezeigt.
Hinweis:In den folgenden Code-Snippets wird die Methode
loadContactPhotoThumbnail()
definiert in der
Bereich Kontakt-URI und Miniaturansicht festlegen
Kotlin
/* * Defines a projection based on platform version. This ensures * that you retrieve the correct columns. */ private val PROJECTION: Array<out String> = arrayOf( ContactsContract.Contacts._ID, ContactsContract.Contacts.LOOKUP_KEY, if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.HONEYCOMB) { ContactsContract.Contacts.DISPLAY_NAME_PRIMARY } else { ContactsContract.Contacts.DISPLAY_NAME }, if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.HONEYCOMB) { ContactsContract.Contacts.PHOTO_FILE_ID } else { /* * Although it's not necessary to include the * column twice, this keeps the number of * columns the same regardless of version */ ContactsContract.Contacts._ID } ) ... class ContactsFragment : Fragment(), LoaderManager.LoaderCallbacks<Cursor> { ... // Defines a ListView private val listView: ListView? = null // Defines a ContactsAdapter private val adapter: ContactsAdapter? = null ... // Defines a Cursor to contain the retrieved data private val cursor: Cursor? = null /* * As a shortcut, defines constants for the * column indexes in the Cursor. The index is * 0-based and always matches the column order * in the projection. */ // Column index of the _ID column private val idIndex = 0 // Column index of the LOOKUP_KEY column private val lookupKeyIndex = 1 // Column index of the display name column private val displayNameIndex = 3 /* * Column index of the photo data column. * It's PHOTO_THUMBNAIL_URI for Honeycomb and later, * and _ID for previous versions. */ private val photoDataIndex: Int = if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.HONEYCOMB) 3 else 0 ...
Java
public class ContactsFragment extends Fragment implements LoaderManager.LoaderCallbacks<Cursor> { ... // Defines a ListView private ListView listView; // Defines a ContactsAdapter private ContactsAdapter adapter; ... // Defines a Cursor to contain the retrieved data private Cursor cursor; /* * Defines a projection based on platform version. This ensures * that you retrieve the correct columns. */ private static final String[] PROJECTION = { ContactsContract.Contacts._ID, ContactsContract.Contacts.LOOKUP_KEY, (Build.VERSION.SDK_INT >= Build.VERSION_CODES.HONEYCOMB) ? ContactsContract.Contacts.DISPLAY_NAME_PRIMARY : ContactsContract.Contacts.DISPLAY_NAME (Build.VERSION.SDK_INT >= Build.VERSION_CODES.HONEYCOMB) ? ContactsContract.Contacts.PHOTO_FILE_ID : /* * Although it's not necessary to include the * column twice, this keeps the number of * columns the same regardless of version */ ContactsContract.Contacts._ID }; /* * As a shortcut, defines constants for the * column indexes in the Cursor. The index is * 0-based and always matches the column order * in the projection. */ // Column index of the _ID column private int idIndex = 0; // Column index of the LOOKUP_KEY column private int lookupKeyIndex = 1; // Column index of the display name column private int displayNameIndex = 3; /* * Column index of the photo data column. * It's PHOTO_THUMBNAIL_URI for Honeycomb and later, * and _ID for previous versions. */ private int photoDataIndex = Build.VERSION.SDK_INT >= Build.VERSION_CODES.HONEYCOMB ? 3 : 0; ...
Listenansicht einrichten
Instanziieren Sie in Fragment.onCreate()
den benutzerdefinierten
Cursor-Adapter und rufen Sie ein Handle auf ListView
ab:
Kotlin
override fun onCreateView( inflater: LayoutInflater, container: ViewGroup?, savedInstanceState: Bundle? ): View? { return FragmentListViewBinding.inflate(...).let { binding -> ... /* * Gets a handle to the ListView in the file * contact_list_layout.xml */ listView = binding.contactList mAdapter?.also { listView?.adapter = it } ... }.root } ...
Java
@Override public View onCreateView(LayoutInflater inflater, ViewGroup container, Bundle savedInstanceState) { FragmentListViewBinding binding = FragmentListViewBinding.inflate(...) ... /* * Gets a handle to the ListView in the file * contact_list_layout.xml */ if (binding.contactListView != null && adapter != null) { binding.contactListView.setAdapter(adapter); } ... } ...
Binden Sie in onViewCreated()
die ContactsAdapter
an die ListView
:
Kotlin
override fun onViewCreated(view: View, savedInstanceState: Bundle?) { super.onViewCreated(view, savedInstanceState) /* * Instantiates the subclass of * CursorAdapter */ mAdapter = activity?.let { ContactsAdapter(it).also { adapter -> // Sets up the adapter for the ListView listView?.adapter = adapter } } }
Java
@Override public void onViewCreated(@NonNull View view, @Nullable Bundle savedInstanceState) { ... /* * Instantiates the subclass of * CursorAdapter */ mAdapter = new ContactsAdapter(getActivity()); // Sets up the adapter for the ListView if (listView != null && mAdapter != null) { listView.setAdapter(mAdapter); } ... } ...
Wenn Sie eine Cursor
mit den Kontaktdaten erhalten, die sich normalerweise in onLoadFinished()
befindet, rufen Sie swapCursor()
auf, um die Cursor
-Daten in die ListView
zu verschieben. Dadurch wird für jeden Eintrag in der Kontaktliste die QuickContactBadge
angezeigt.
Kotlin
override fun onLoadFinished(loader: Loader<Cursor>, cursor: Cursor) { // When the loader has completed, swap the cursor into the adapter mAdapter?.swapCursor(cursor) }
Java
public void onLoadFinished(Loader<Cursor> loader, Cursor cursor) { // When the loader has completed, swap the cursor into the adapter mAdapter.swapCursor(cursor); }
Wenn Sie ein Cursor
an ein
ListView
mit CursorAdapter
(oder abgeleitete Klasse) erstellt werden, und Sie verwenden CursorLoader
, um die
Cursor
, immer eindeutige Verweise auf Cursor
bei der Implementierung von
onLoaderReset()
Das ist im folgenden Beispiel zu sehen:
Kotlin
override fun onLoaderReset(loader: Loader<Cursor>) { // Removes remaining reference to the previous Cursor adapter?.swapCursor(null) }
Java
@Override public void onLoaderReset(Loader<Cursor> loader) { // Removes remaining reference to the previous Cursor adapter.swapCursor(null); }