Mengintegrasikan isi otomatis dengan IME dan layanan isi otomatis

Mulai dari Android 11, keyboard dan editor metode input (IME) lainnya dapat menampilkan saran isi otomatis secara inline, di strip saran, atau antarmuka serupa, bukan di sistem yang menampilkan saran di menu. Karena saran isi otomatis ini dapat berisi data pribadi, seperti sandi atau informasi kartu kredit, saran disembunyikan dari IME sampai pengguna memilih salah satu. Update IME dan layanan isi otomatis, seperti pengelola sandi, untuk memanfaatkan fitur ini. Jika IME atau layanan isi otomatis tidak mendukung isi otomatis secara inline, saran akan ditampilkan di menu, seperti pada versi sebelum Android 11.

Alur kerja

Dalam alur ini, IME berarti keyboard atau editor input lainnya saat ini, dan penyedia saran berarti penyedia saran isi otomatis yang sesuai. Bergantung pada kolom input dan setelan pengguna, penyedia saran mungkin merupakan platform atau layanan isi otomatis.

  1. Pengguna fokus pada kolom input yang memicu isi otomatis, seperti kolom input sandi atau kartu kredit.

  2. Platform membuat kueri IME saat ini dan penyedia saran yang sesuai untuk melihat apakah mereka mendukung isi otomatis secara inline. Jika IME atau penyedia saran tidak mendukung isi otomatis secara inline, saran akan ditampilkan di menu, seperti pada Android 10 dan yang lebih rendah.

  3. Platform meminta IME untuk menyediakan permintaan saran. Permintaan saran ini menentukan jumlah maksimum saran yang akan ditampilkan dan juga menyediakan spesifikasi presentasi untuk setiap saran. Spesifikasi presentasi menentukan hal-hal seperti ukuran maksimum, ukuran teks, warna, dan data font, sehingga penyedia saran dapat mencocokkan tampilan dan nuansa IME.

  4. Platform meminta penyedia saran untuk menyediakan hingga sejumlah saran yang diminta. Setiap saran meliputi callback untuk meng-inflate View yang berisi UI saran.

  5. Platform memberi tahu IME bahwa saran sudah siap. IME menampilkan saran dengan memanggil metode callback untuk meng-inflate setiap View saran. Untuk melindungi informasi pribadi pengguna, IME tidak melihat saran tersebut pada di tahap ini.

  6. Jika pengguna memilih salah satu saran, IME akan diberi tahu dengan cara yang sama seperti jika pengguna memilih saran dari menu sistem.

Bagian berikut menjelaskan cara mengonfigurasi IME atau layanan isi otomatis untuk mendukung isi otomatis secara inline.

Mengonfigurasi IME untuk mendukung isi otomatis inline

Bagian ini menjelaskan cara mengonfigurasi IME Anda untuk mendukung isi otomatis secara inline. Jika IME Anda tidak mendukung isi otomatis secara inline, platform secara default akan menampilkan saran isi otomatis di menu.

IME Anda harus menetapkan atribut supportsInlinedSuggestions ke true:

<input-method
    xmlns:android="http://schemas.android.com/apk/res/android"
    android:supportsInlineSuggestions="true"/>

Jika platform memerlukan saran isi otomatis, platform akan memanggil metode InputMethodService.onCreateInlineSuggestionsRequest() IME Anda. Anda harus mengimplementasikan metode ini. Tampilkan InlineSuggestionsRequest yang menentukan hal berikut:

  • Jumlah saran yang diinginkan IME Anda.
  • InlinePresentationSpec untuk setiap saran, yang menentukan cara saran harus ditampilkan.

Jika memiliki saran, platform akan memanggil metode onInlineSuggestionsResponse() IME, dengan meneruskan InlineSuggestionsResponse yang berisi saran. Anda harus mengimplementasikan metode ini. Dalam penerapan, panggil InlineSuggestionsResponse.getInlineSuggestions() untuk mendapatkan daftar saran, lalu meng-inflate setiap saran dengan memanggil metode InlineSuggestion.inflate().

Mengonfigurasi layanan isi otomatis untuk mendukung isi otomatis inline

Bagian ini menjelaskan cara mengonfigurasi layanan isi otomatis untuk mendukung isi otomatis secara inline. Jika aplikasi Anda tidak mendukung isi otomatis inline, platform ini secara default akan menampilkan saran isi otomatis dalam menu.

Layanan isi otomatis Anda harus menetapkan atribut supportsInlinedSuggestions ke true:

<autofill-service
    xmlns:android="http://schemas.android.com/apk/res/android"
    android:supportsInlineSuggestions="true"/>

Saat IME memerlukan saran isi otomatis, platform akan memanggil metode onFillRequest() layanan isi otomatis, sama seperti yang dilakukan dalam versi di bawah Android 11. Namun, layanan Anda harus memanggil metode getInlineSuggestionsRequest() objek FillRequest yang diteruskan untuk mendapatkan InlineSuggestionsRequest yang dibuat oleh IME. InlineSuggestionsRequest menentukan jumlah saran inline yang diperlukan dan cara setiap saran harus ditampilkan. Jika IME tidak mendukung saran inline, metode akan menampilkan null.

Layanan isi otomatis Anda membuat InlinePresentation objek, hingga jumlah maksimum yang diminta dalam InlineSuggestionsRequest. Presentasi Anda harus mematuhi batasan ukuran yang ditentukan oleh InlineSuggestionsRequest. Untuk menunjukkan saran Anda kepada IME, panggil Dataset.Builder.setValue() satu kali untuk setiap saran. Android 11 menyediakan versi Dataset.Builder.setValue() untuk mendukung saran inline.