Ringkasan Data Layer API

Node berbasis cloud dikontrol oleh server milik Google
Gambar 1. Contoh jaringan node dengan perangkat genggam dan Wear OS.

Wearable Data Layer API, yang merupakan bagian dari layanan Google Play, menyediakan saluran komunikasi antara perangkat wearable (seperti smartwatch) dan perangkat genggam yang terhubung (biasanya smartphone). Fitur ini adalah cara untuk menyinkronkan dan mentransfer data antar-perangkat.

Catatan: API ini hanya tersedia di smartwatch Wear OS dan perangkat Android yang tersambung. Untuk smartwatch Wear OS yang disambungkan dengan ponsel iOS, aplikasi dapat mengkueri API berbasis cloud lainnya jika konektivitas internet tersedia. Untuk mengetahui informasi selengkapnya tentang API lainnya ini, buka Akses dan sinkronisasi jaringan di Wear OS.

Perhatian: Karena API lapisan data didesain untuk komunikasi antara perangkat genggam dan wearable, API ini adalah satu-satunya API yang dapat Anda gunakan untuk menyiapkan komunikasi antara perangkat tersebut. Misalnya, jangan mencoba membuka soket level rendah untuk membuat saluran komunikasi.

Kasus penggunaan umum

Data Layer API sangat berguna untuk kasus penggunaan kebugaran dan media.

Aplikasi kebugaran

Mengirim data latihan dari aplikasi Wear OS ke aplikasi seluler Aplikasi kebugaran sering kali perlu menulis data latihan yang direkam oleh smartwatch ke aplikasi seluler atau ke Health Connect. Jika menggunakan Data Layer API untuk mentransfer data, gunakan klien pesan untuk mengirim data latihan dari aplikasi Wear OS ke aplikasi seluler agar dapat menulis ke Health Connect.

Streaming data langsung ke perangkat seluler selama latihan di rumah

Skenario latihan di rumah yang umum adalah streaming data detak jantung dari perangkat Wear OS ke perangkat seluler dan menampilkan informasi detak jantung terbaru kepada pengguna di layar perangkat seluler mereka. Untuk melakukan streaming data ini, gunakan klien saluran.

Aplikasi media

Untuk mengontrol pemutar media melalui tindakan jeda/lanjutkan/mulai/akhiri dari smartwatch ke ponsel, gunakan klien pesan.

Opsi untuk komunikasi

Data ditransfer dengan salah satu cara berikut:

  1. Secara langsung, saat ada koneksi Bluetooth antara perangkat Wear OS dan perangkat lain.
  2. Melalui jaringan yang tersedia, seperti LTE atau Wi-Fi, menggunakan node jaringan di server Google sebagai perantara.

Semua klien Lapisan Data dapat bertukar data menggunakan Bluetooth atau cloud, bergantung pada koneksi yang tersedia untuk perangkat. Asumsikan bahwa data yang dikirim menggunakan Lapisan Data suatu saat mungkin menggunakan server milik Google.

Bluetooth

Jika perangkat terhubung menggunakan Bluetooth, Lapisan Data akan menggunakan koneksi ini. Ada satu saluran terenkripsi di antara perangkat, menggunakan enkripsi Bluetooth standar, yang dikelola oleh layanan Google Play.

Cloud

Data otomatis dirutekan melalui Google Cloud saat Bluetooth tidak tersedia. Semua data yang ditransfer melalui Google Cloud dienkripsi end-to-end.

Keamanan komunikasi

Layanan Google Play menerapkan batasan berikut untuk menyediakan komunikasi yang lebih aman antara aplikasi yang diinstal di perangkat Wear OS dan aplikasi yang sama yang diinstal di perangkat genggam di sekitar:

  • Nama paket harus cocok di seluruh perangkat.
  • Tanda tangan paket harus cocok di seluruh perangkat.

Tidak ada aplikasi lain yang memiliki akses ke data, terlepas dari jenis koneksi.

Penyiapan

Data Layer API Wearable memiliki dependensi berikut:

Sertakan dependensi berikut dalam file build.gradle modul Wear Anda:

dependencies {
    ...
    implementation("com.google.android.gms:play-services-wearable:19.0.0")
}

Memfasilitasi proses penyambungan awal

Horologist menyediakan beberapa library pembantu di atas API platform. Library ini mencakup library lapisan data yang membantu membuat koneksi antara perangkat seluler dan perangkat Wear OS. Selain itu, library ini menyediakan API yang mudah digunakan untuk melakukan hal berikut:

  • Instal aplikasi di perangkat lain.
  • Luncurkan aplikasi di perangkat lain.
  • Luncurkan aktivitas tertentu di perangkat lain.
  • Luncurkan aplikasi pendamping.

Mengakses lapisan data

Untuk memanggil Data Layer API, gunakan class Wearable untuk mendapatkan instance dari berbagai class klien, seperti DataClient dan MessageClient.

Untuk mengetahui informasi selengkapnya, lihat contoh DataLayer.

Menggunakan klien minimal

Untuk membuat klien, lihat contoh kode berikut:

Kotlin

val dataClient: DataClient = Wearable.getDataClient(context)

Java

DataClient dataClient = Wearable.getDataClient(context);

Konteks dapat berupa konteks Android mana pun yang valid. Jika Anda menggunakan API dalam cakupan Activity, gunakan metode getDataClient() dari class Wearable. Hal ini memungkinkan interaksi tertentu muncul sebagai dialog, bukan sebagai notifikasi, seperti saat pengguna diminta mengupdate versi layanan Google Play.

Secara default, callback ke pemroses dibuat di UI thread utama aplikasi. Agar callback dibuat pada thread lain, gunakan objek WearableOptions untuk menentukan Looper kustom:

Kotlin

runBlocking {
    Wearable.getDataClient(context, options)
}

Java

WearableOptions options = new WearableOptions.Builder().setLooper(myLooper).build();
DataClient dataClient = Wearable.getDataClient(context, options);

Untuk informasi selengkapnya, lihat referensi WearableOptions.Builder.

Buat ulang instance klien sesuai kebutuhan

Klien Wearable API, seperti DataClient dan MessageClient, tidak mahal untuk dibuat. Jadi, alih-alih mempertahankan klien, buat ulang klien sesuai kebutuhan Anda, menggunakan gaya yang sesuai dengan aplikasi Anda.

Status klien, seperti sekumpulan pemroses terdaftar, dibagikan ke seluruh klien dan dipertahankan jika layanan Google Play diupdate saat aplikasi sedang berjalan.