Muestra resultados de búsqueda explorables
Organiza tus páginas con colecciones
Guarda y categoriza el contenido según tus preferencias.
Todas las apps deben admitir búsquedas por voz. En esta página, se describe cómo mejorar aún más la experiencia de búsqueda admitiendo el inicio de búsquedas sin voz y mostrando una lista de resultados de búsqueda para que los usuarios puedan elegir otro resultado. Por ejemplo, si el resultado sugerido no es el más pertinente.
Tu app de música puede proporcionar resultados de búsqueda contextuales en Android Auto y el SO Android Automotive (AAOS). Estos resultados aparecen cuando un usuario inicia una búsqueda o ve los resultados de la búsqueda más reciente.
Para habilitar y proporcionar estos resultados de la búsqueda, haz lo siguiente:
Declara la compatibilidad con la búsqueda en el método onGetRoot
de tu servicio.
Anula el método onSearch
en tu servicio de navegador multimedia para controlar los términos de búsqueda del usuario.
Organiza los resultados de la Búsqueda con elementos de título para mejorar la capacidad de exploración.
Tu app puede proporcionar resultados de la búsqueda contextuales que aparecen cuando se inicia una búsqueda. Android Auto y AAOS muestran estos resultados a través de interfaces de búsqueda o de condiciones que cambian a partir de búsquedas realizadas con anterioridad. Para obtener más información, consulta Cómo admitir acciones de voz.

Figura 1: Vista de reproducción con la opción Resultados de la búsqueda para ver elementos multimedia relacionados con la búsqueda por voz del usuario
Para indicar que tu app admite la visualización de resultados de la búsqueda, incluye la clave constante BROWSER_SERVICE_EXTRAS_KEY_SEARCH_SUPPORTED
en el paquete de extras que devuelve el método onGetRoot
de tu servicio, que se asigna al valor booleano true
.
Kotlin
import androidx.media.utils.MediaConstants
@Nullable
override fun onGetRoot(
@NonNull clientPackageName: String,
clientUid: Int,
@Nullable rootHints: Bundle
): BrowserRoot {
val extras = Bundle()
extras.putBoolean(
MediaConstants.BROWSER_SERVICE_EXTRAS_KEY_SEARCH_SUPPORTED, true)
return BrowserRoot(ROOT_ID, extras)
}
Java
import androidx.media.utils.MediaConstants;
@Nullable
@Override
public BrowserRoot onGetRoot(
@NonNull String clientPackageName,
int clientUid,
@Nullable Bundle rootHints) {
Bundle extras = new Bundle();
extras.putBoolean(
MediaConstants.BROWSER_SERVICE_EXTRAS_KEY_SEARCH_SUPPORTED, true);
return new BrowserRoot(ROOT_ID, extras);
}
Para proporcionar resultados de la búsqueda, anula el método onSearch
en el servicio de navegador multimedia. Android Auto y AAOS reenvían los términos de búsqueda del usuario a este método cuando el usuario invoca una interfaz de búsqueda o la opción Resultados de la búsqueda.
Para que los resultados de la búsqueda sean más explorables, puedes usar elementos de título. Por ejemplo, si tu app reproduce música, puedes organizar los resultados de la búsqueda por álbum, artista y canción. En este fragmento de código, se muestra una implementación del método onSearch
:
Kotlin
fun onSearch(query: String, extras: Bundle) {
// Detach from results to unblock the caller (if a search is expensive).
result.detach()
object:AsyncTask() {
internal var searchResponse:ArrayList
internal var succeeded = false
protected fun doInBackground(vararg params:Void):Void {
searchResponse = ArrayList()
if (doSearch(query, extras, searchResponse))
{
succeeded = true
}
return null
}
protected fun onPostExecute(param:Void) {
if (succeeded)
{
// Sending an empty List informs the caller that there were no results.
result.sendResult(searchResponse)
}
else
{
// This invokes onError() on the search callback.
result.sendResult(null)
}
return null
}
}.execute()
}
// Populates resultsToFill with search results. Returns true on success or false on error.
private fun doSearch(
query: String,
extras: Bundle,
resultsToFill: ArrayList
): Boolean {
// Implement this method.
}
Java
@Override
public void onSearch(final String query, final Bundle extras,
Result<List<MediaItem>> result) {
// Detach from results to unblock the caller (if a search is expensive).
result.detach();
new AsyncTask<Void, Void, Void>() {
List>MediaItem> searchResponse;
boolean succeeded = false;
@Override
protected Void doInBackground(Void... params) {
searchResponse = new ArrayList<MediaItem>();
if (doSearch(query, extras, searchResponse)) {
succeeded = true;
}
return null;
}
@Override
protected void onPostExecute(Void param) {
if (succeeded) {
// Sending an empty List informs the caller that there were no results.
result.sendResult(searchResponse);
} else {
// This invokes onError() on the search callback.
result.sendResult(null);
}
}
}.execute()
}
/** Populates resultsToFill with search results. Returns true on success or false on error. */
private boolean doSearch(String query, Bundle extras, ArrayList<MediaItem> resultsToFill) {
// Implement this method.
}
El contenido y las muestras de código que aparecen en esta página están sujetas a las licencias que se describen en la Licencia de Contenido. Java y OpenJDK son marcas registradas de Oracle o sus afiliados.
Última actualización: 2025-08-22 (UTC)
[[["Fácil de comprender","easyToUnderstand","thumb-up"],["Resolvió mi problema","solvedMyProblem","thumb-up"],["Otro","otherUp","thumb-up"]],[["Falta la información que necesito","missingTheInformationINeed","thumb-down"],["Muy complicado o demasiados pasos","tooComplicatedTooManySteps","thumb-down"],["Desactualizado","outOfDate","thumb-down"],["Problema de traducción","translationIssue","thumb-down"],["Problema con las muestras o los códigos","samplesCodeIssue","thumb-down"],["Otro","otherDown","thumb-down"]],["Última actualización: 2025-08-22 (UTC)"],[],[],null,["# Display browsable search results\n\nAll apps must support voice searches. This page describes how to further enhance\nthe search experience by supporting the initiation of searches without voice and\nby showing a list of search results so that users can pick another result. For\nexample, if the suggested result isn't the most relevant.\n\nYour media app can provide contextual search results in Android Auto and Android\nAutomotive OS (AAOS). These results appear when a user initiates a search query\nor views the results of the most recent search.\n\nTo enable and provide these search results:\n\n- Declare search support in your service's `onGetRoot` method.\n\n- Override the `onSearch` method in your media browser service to handle user\n search terms.\n\n- Organize Search results using title items for improved browsability.\n\nYour app can provide contextual search results that appear when a search query\nis started. Android Auto and AAOS show these results through search query\ninterfaces or through affordances that pivot on queries made earlier. To learn\nmore, see the [Support voice actions](/training/cars/media/voice-actions#support_voice).\n\n**Figure 1.** Playback view with a **Search results** option to view media items\nrelated to the user's voice search.\n\nTo indicate that your app supports the display of search results, include the\nconstant key [`BROWSER_SERVICE_EXTRAS_KEY_SEARCH_SUPPORTED`](/reference/androidx/media/utils/MediaConstants#BROWSER_SERVICE_EXTRAS_KEY_SEARCH_SUPPORTED()) in the extras\nbundle returned by your service's [`onGetRoot`](/reference/androidx/media/MediaBrowserServiceCompat#onGetRoot(java.lang.String,%20int,%20android.os.Bundle)) method, mapping to the\nBoolean `true`. \n\n### Kotlin\n\n import androidx.media.utils.MediaConstants\n\n @Nullable\n override fun onGetRoot(\n @NonNull clientPackageName: String,\n clientUid: Int,\n @Nullable rootHints: Bundle\n ): BrowserRoot {\n val extras = Bundle()\n extras.putBoolean(\n MediaConstants.BROWSER_SERVICE_EXTRAS_KEY_SEARCH_SUPPORTED, true)\n return BrowserRoot(ROOT_ID, extras)\n }\n\n### Java\n\n import androidx.media.utils.MediaConstants;\n\n @Nullable\n @Override\n public BrowserRoot onGetRoot(\n @NonNull String clientPackageName,\n int clientUid,\n @Nullable Bundle rootHints) {\n Bundle extras = new Bundle();\n extras.putBoolean(\n MediaConstants.BROWSER_SERVICE_EXTRAS_KEY_SEARCH_SUPPORTED, true);\n return new BrowserRoot(ROOT_ID, extras);\n }\n\nTo provide search results, override the [`onSearch`](/reference/androidx/media/MediaBrowserServiceCompat#onSearch(java.lang.String,android.os.Bundle,androidx.media.MediaBrowserServiceCompat.Result%3Cjava.util.List%3Candroid.support.v4.media.MediaBrowserCompat.MediaItem%3E%3E)) method in your media\nbrowser service. Android Auto and AAOS forward the user's search terms to this\nmethod when a user invokes a search query interface or **Search results**\naffordance.\n\nTo make search results more browsable, you can use [title items](/training/cars/media/create-media-browser/content-styles#group-items). For\nexample, if your app plays music, you can organize search results by album,\nartist, and song. This code snippet shows an implementation of the `onSearch`\nmethod: \n\n### Kotlin\n\n fun onSearch(query: String, extras: Bundle) {\n // Detach from results to unblock the caller (if a search is expensive).\n result.detach()\n object:AsyncTask() {\n internal var searchResponse:ArrayList\n internal var succeeded = false\n protected fun doInBackground(vararg params:Void):Void {\n searchResponse = ArrayList()\n if (doSearch(query, extras, searchResponse))\n {\n succeeded = true\n }\n return null\n }\n protected fun onPostExecute(param:Void) {\n if (succeeded)\n {\n // Sending an empty List informs the caller that there were no results.\n result.sendResult(searchResponse)\n }\n else\n {\n // This invokes onError() on the search callback.\n result.sendResult(null)\n }\n return null\n }\n }.execute()\n }\n // Populates resultsToFill with search results. Returns true on success or false on error.\n private fun doSearch(\n query: String,\n extras: Bundle,\n resultsToFill: ArrayList\n ): Boolean {\n // Implement this method.\n }\n\n### Java\n\n @Override\n public void onSearch(final String query, final Bundle extras,\n Result<List<MediaItem\u003e\u003e result) {\n\n // Detach from results to unblock the caller (if a search is expensive).\n result.detach();\n\n new AsyncTask\u003cVoid, Void, Void\u003e() {\n List\u003eMediaItem\u003e searchResponse;\n boolean succeeded = false;\n @Override\n protected Void doInBackground(Void... params) {\n searchResponse = new ArrayList<MediaItem\u003e();\n if (doSearch(query, extras, searchResponse)) {\n succeeded = true;\n }\n return null;\n }\n\n @Override\n protected void onPostExecute(Void param) {\n if (succeeded) {\n // Sending an empty List informs the caller that there were no results.\n result.sendResult(searchResponse);\n } else {\n // This invokes onError() on the search callback.\n result.sendResult(null);\n }\n }\n }.execute()\n }\n\n /** Populates resultsToFill with search results. Returns true on success or false on error. */\n private boolean doSearch(String query, Bundle extras, ArrayList<MediaItem\u003e resultsToFill) {\n // Implement this method.\n }"]]