Pintasan Android memberi pengguna akses cepat metode untuk melakukan suatu tindakan atau mengakses konten dalam sebuah aplikasi. Asisten dapat secara proaktif menyarankan pintasan dinamis Android Anda kepada pengguna di di waktu yang relevan, memungkinkan pengguna untuk dengan mudah menemukan dan memutar ulang aplikasi fungsionalitas yang diaktifkan dengan suara.
Misalnya, Anda dapat mendorong pintasan untuk setiap catatan yang dibuat pengguna
aplikasi pencatat Anda. Anda membuat
link dinamis yang memenuhi syarat untuk ditampilkan di platform Google, seperti Asisten,
dengan menambahkan library Jetpack Integrasi Pintasan Google ke project Anda.
Library ini memungkinkan Asisten mengambil pintasan dinamis yang Anda tekan menggunakan
Class ShortcutManagerCompat
, yang merupakan wrapper Jetpack untuk
API ShortcutManager
.
Saat Anda menggunakan library Google Shortcuts Integration di aplikasi Anda,
pintasan yang Anda dorong ke Google dapat dilihat oleh pengguna sebagai saran pintasan suara
di aplikasi Asisten. Anda dapat mengirim pintasan dinamis dalam jumlah tak terbatas ke
Asisten menggunakan metode pushDynamicShortcut()
library ShortcutManagerCompat
.
Mengonfigurasi project pengembangan Anda
Menambahkan fungsi pintasan dinamis ke aplikasi Anda memerlukan Library Integrasi Pintasan Google, yang merupakan library Android Jetpack. Bagian ini menjelaskan cara mengonfigurasi project pengembangan aplikasi Anda untuk menyertakan {i>library<i} ini.
Untuk menambahkan library Jetpack ini dan mengonfigurasi project Anda, ikuti langkah-langkah berikut:
Update file
gradle.properties
Anda untuk menangani library Jetpack:gradle.properties
android.useAndroidX=true # Automatically convert third-party libraries to use AndroidX android.enableJetifier=true
Tambahkan dependensi library Jetpack ke
build.gradle
:app/build.gradle
dependencies { implementation "androidx.core:core:1.6.0" implementation "androidx.core:core-google-shortcuts:1.0.1" ... }
Dalam kode contoh sebelumnya, Anda mencantumkan dua library Jetpack sebagai dependensi. Library
androidx.core:core:1.6.0
berisi ClassShortcutManagerCompat
, yang Anda gunakan untuk mengirim pintasan dinamis ke Google.androidx.core:core-google-shortcuts:1.0.1
adalah library Integrasi Pintasan Google. Library ini tidak berisi API yang digunakan developer. Dengan menambahkannya sebagai dependensi, Anda memungkinkan Asisten untuk mengambil pintasan dinamis yang Anda kirim menggunakan classShortcutManagerCompat
.
Mengirim pintasan dinamis
Untuk mendorong pintasan dinamis yang memenuhi syarat untuk ditampilkan di Asisten,
pertama-tama Anda membuat pintasan menggunakan ShortcutInfoCompat.Builder()
.
Anda kemudian mendorong pintasan menggunakan
Metode ShortcutManagerCompat.pushDynamicShortcut()
. Pintasan dikirim
setiap kali pengguna menyelesaikan tindakan yang relevan di aplikasi Anda. Contoh berikut
kode mendorong pintasan setiap kali pengguna memesan di aplikasi pengiriman makanan:
ExampleOrderActivity
Kotlin
// Define the dynamic shortcut for a menu item var intent = Intent(context, DisplayOrderActivity::class.java) intent.action = Intent.ACTION_VIEW var shortcutInfo = ShortcutInfoCompat.Builder(context, id) .setShortLabel("Cappuccino") .setLongLabel("Order another cappuccino") .addCapabilityBinding( "actions.intent.ORDER_MENU_ITEM", "menuItem.name", Arrays.asList("cappuccino") ) .setIntent(intent) // Push the shortcut .build() // Push the shortcut ShortcutManagerCompat.pushDynamicShortcut(context, shortcutInfo)
Java
// Define the dynamic shortcut for a menu item Intent intent = new Intent(context, DisplayOrderActivity.class); intent.setAction(Intent.ACTION_VIEW); ShortcutInfoCompat.Builder shortcutInfo = new ShortcutInfoCompat.Builder(context, id) .setShortLabel("Cappuccino") .setLongLabel("Order another cappuccino") .addCapabilityBinding( "actions.intent.ORDER_MENU_ITEM", "menuItem.name", Arrays.asList("cappuccino")) .setIntent(intent) .build(); // Push the shortcut ShortcutManagerCompat.pushDynamicShortcut(context, shortcutInfo);
id
yang direferensikan dalam metode ShortcutInfoCompat.Builder
dalam kode contoh
sebelumnya menentukan shortcutId
objek pintasan yang dihasilkan. id
ini
harus berupa literal string yang unik. Untuk mengetahui detailnya, lihat
dokumentasi Pintasan Android.
Dalam contoh sebelumnya, metode addCapabilityBinding
mengikat pintasan dinamis
ke capability
dari android:name
yang sama yang ditentukan di
shortcuts.xml
. Metode ini memungkinkan Anda mengaitkan pintasan ke
parameter intent bawaan (BII) semantik.
Pintasan dinamis terkadang didorong tanpa parameter BII tertentu
asosiasi. Saat dipanggil oleh pengguna, Asisten akan memicu intent
yang ditentukan
di pintasan untuk memenuhi tindakan. Contoh berikut menunjukkan pintasan
dinamis tanpa pengaitan parameter:
Kotlin
var intent: Intent = Intent(context, DisplayOrderActivity::class.java) intent.setPackage(this, "com.sample.app") intent.setAction(Intent.ACTION_VIEW) var shortcutInfo: ShortcutInfoCompat = ShortcutInfoCompat.Builder(context, id) .setShortLabel("Order coffee") .setLongLabel("Order a cup of coffee") .addCapabilityBinding("actions.intent.ORDER_MENU_ITEM") .setIntent(intent) .build() ShortcutManagerCompat.pushDynamicShortcut(context, shortcutInfo);
Java
Intent intent = new Intent(context, DisplayOrderActivity.class); intent.setPackage(this, "com.sample.app"); intent.setAction(Intent.ACTION_VIEW); ShortcutInfoCompat shortcutInfo = new ShortcutInfoCompat.Builder(context, id) .setShortLabel("Order coffee") .setLongLabel("Order a cup of coffee") .addCapabilityBinding("actions.intent.ORDER_MENU_ITEM") .setIntent(intent) .build(); ShortcutManagerCompat.pushDynamicShortcut(context, shortcutInfo);
Menguji pintasan dinamis dengan Asisten
Saat Asisten Google berhasil mengambil pintasan dinamis dari aplikasi, pintasan memenuhi syarat untuk muncul sebagai saran Pintasan Suara di aplikasi Android Asisten. Aplikasi Asisten menyarankan pintasan terbaru didorong oleh aplikasi Anda.
Untuk menguji pintasan dinamis dengan Asisten, ikuti langkah-langkah berikut:
- Membuat pratinjau Action Aplikasi dan menyiapkan perangkat pengujian atau emulator untuk menguji tindakan dengan mengikuti persyaratan penyiapan seperti untuk Plugin Asisten Google.
- Buka aplikasi dan tentukan pintasan dinamis yang akan dikirim. Kemudian selesaikan tindakan. Misalnya, jika Anda mengirim pintasan setiap kali catatan dibuat di aplikasi catatan, buat catatan baru.
- Buka Pintasan di aplikasi Setelan Asisten pada perangkat Anda. Nama pintasan dinamis akan muncul dalam daftar untuk aplikasi Anda.