Mengintegrasikan isi otomatis dengan IME dan layanan isi otomatis

Mulai di Android 11, keyboard dan editor metode input (IME) lainnya dapat menampilkan saran isi otomatis inline, di strip saran, atau sesuatu yang serupa, bukan sistem yang menampilkan saran di menu. Karena saran isi otomatis ini dapat berisi data pribadi, seperti sandi atau informasi kartu kredit, saran tersebut akan disembunyikan dari IME sampai pengguna memilih salah satunya. Update IME dan layanan isi otomatis, seperti pengelola sandi, untuk memanfaatkan fitur ini. Jika IME atau layanan isi otomatis tidak mendukung isi otomatis inline, saran akan ditampilkan dalam menu, seperti pada versi yang lebih lama dari 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 berupa platform atau layanan isi otomatis.

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

  2. Platform mengkueri IME saat ini dan penyedia saran yang sesuai untuk melihat apakah IME mendukung isi otomatis inline. Jika IME atau penyedia saran tidak mendukung isi otomatis inline, saran akan ditampilkan dalam menu, seperti pada Android 10 dan yang lebih lama.

  3. Platform meminta IME untuk menyediakan permintaan saran. Permintaan saran ini menentukan jumlah maksimum saran yang akan ditampilkan dan juga memberikan 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 apa yang ada pada tahap ini.

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

Bagian berikut menjelaskan cara mengonfigurasi IME atau layanan isi otomatis untuk mendukung isi otomatis 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 inline, platform secara default akan menampilkan saran isi otomatis dalam 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 disajikan.

Jika memiliki saran, platform akan memanggil metode onInlineSuggestionsResponse() IME, dengan meneruskan InlineSuggestionsResponse yang berisi saran. Anda harus mengimplementasikan metode ini. Dalam implementasi Anda, 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 inline. Jika aplikasi Anda tidak mendukung isi otomatis inline, platform 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, seperti yang dilakukan pada 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.