نمایش نتایج جستجوی قابل مرور

همه برنامه ها باید از جستجوی صوتی پشتیبانی کنند. این صفحه نحوه بهبود بیشتر تجربه جستجو را با پشتیبانی از شروع جستجوهای بدون صدا و با نمایش لیستی از نتایج جستجو توضیح می دهد تا کاربران بتوانند نتیجه دیگری را انتخاب کنند. برای مثال، اگر نتیجه پیشنهادی مرتبط ترین نباشد.

برنامه رسانه شما می‌تواند نتایج جستجوی متنی را در Android Auto و Android Automotive OS (AAOS) ارائه دهد. این نتایج زمانی ظاهر می شوند که کاربر یک پرس و جوی جستجو را آغاز کند یا نتایج آخرین جستجو را مشاهده کند.

برای فعال کردن و ارائه این نتایج جستجو:

  • پشتیبانی جستجو را در روش onGetRoot سرویس خود اعلام کنید.

  • برای مدیریت عبارات جستجوی کاربر، روش onSearch را در سرویس مرورگر رسانه خود لغو کنید.

  • برای بهبود قابلیت مرور، نتایج جستجو را با استفاده از موارد عنوان سازماندهی کنید.

برنامه شما می تواند نتایج جستجوی متنی را ارائه دهد که هنگام شروع یک عبارت جستجو ظاهر می شوند. Android Auto و AAOS این نتایج را از طریق رابط‌های جستجو یا از طریق هزینه‌هایی که بر روی عبارت‌های قبلی انجام شده است نشان می‌دهند. برای کسب اطلاعات بیشتر، به عملکردهای صوتی پشتیبانی مراجعه کنید.

نمایش پخش با گزینه **نتایج جستجو** برای مشاهده آیتم های رسانه مربوط به جستجوی صوتی کاربر است

شکل 1. نمای پخش با گزینه نتایج جستجو برای مشاهده موارد رسانه ای مربوط به جستجوی صوتی کاربر.

برای نشان دادن اینکه برنامه شما از نمایش نتایج جستجو پشتیبانی می‌کند، کلید ثابت BROWSER_SERVICE_EXTRAS_KEY_SEARCH_SUPPORTED را در بسته اضافی که با روش onGetRoot سرویس شما برگردانده شده است، قرار دهید، با نگاشت به Boolean true .

کاتلین

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

جاوا

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);
}

برای ارائه نتایج جستجو، روش onSearch را در سرویس مرورگر رسانه خود لغو کنید. Android Auto و AAOS زمانی که کاربر یک واسط عبارت جستجو یا استطاعت نتایج جستجو را فراخوانی می‌کند، عبارات جستجوی کاربر را به این روش ارسال می‌کنند.

برای مرور بیشتر نتایج جستجو، می‌توانید از موارد عنوان استفاده کنید. به عنوان مثال، اگر برنامه شما موسیقی پخش می کند، می توانید نتایج جستجو را بر اساس آلبوم، هنرمند و آهنگ سازماندهی کنید. این قطعه کد پیاده سازی روش onSearch را نشان می دهد:

کاتلین

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

جاوا

@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&lt;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&lt;MediaItem> resultsToFill) {
    // Implement this method.
}