Getting Started
Salin prompt pengaturan dengan langkah instalasi dan panduan markdown lengkap untuk plugin ini.
Set up this Capacitor plugin in the project.
Use the package manager already used by the project.
Install these package(s): `@capgo/capacitor-watch`
Run the required Capacitor sync/update step after installation.
Read this markdown guide for the full setup steps: https://raw.githubusercontent.com/Cap-go/website/refs/heads/main/apps/docs/src/content/docs/docs/plugins/watch/getting-started.mdx
Use that guide for platform-specific steps, native file edits, permissions, config changes, imports, and usage setup.
If that guide references other docs pages, read them too.
Pemasangan
Bagian berjudul “Pemasangan”Anda dapat menggunakan Setup Bantuan AI kami untuk menginstal plugin. Tambahkan Capgo kemampuan ke alat AI Anda menggunakan perintah berikut:
npx skills add https://github.com/Cap-go/capgo-skills --skill capacitor-pluginsLalu gunakan prompt berikut:
Use the `capacitor-plugins` skill from `Cap-go/capgo-skills` to install the `@capgo/capacitor-watch` plugin in my project.Jika Anda lebih suka Setup Manual, instal plugin dengan menjalankan perintah-perintah berikut dan ikuti instruksi spesifik platform di bawah ini:
-
Instal paket
Jendela Terminal bun add @capgo/capacitor-watch -
Sinkron dengan proyek asli
Jendela Terminal bunx cap sync -
Konfigurasi plugin
Contoh Penggunaan Dasar:
import { CapgoWatch } from '@capgo/capacitor-watch';// Check watch connectivity statusconst info = await CapgoWatch.getInfo();console.log('Watch paired:', info.isPaired);console.log('Watch reachable:', info.isReachable);// Listen for messages from watchawait CapgoWatch.addListener('messageReceived', (event) => {console.log('Message from watch:', event.message);});Kirim Pesan ke Watch:
// Check if watch is reachable firstconst info = await CapgoWatch.getInfo();if (info.isReachable) {await CapgoWatch.sendMessage({data: { action: 'refresh', timestamp: Date.now() }});}Pengaturan iOS yang Diperlukan:
- Tambahkan kemampuan WatchConnectivity ke aplikasi iOS Anda di Xcode
- Buat target aplikasi watchOS di proyek Xcode Anda
- Implementasikan WatchConnectivity di aplikasi watchOS Anda (lihat Implementasi Aplikasi Jam di bawah)
Plugin ini secara otomatis mengaktifkan WCSession ketika plugin dimuat.
Apple Watch hanya didukung pada iOS. Pada Android, semua metode akan menolak dengan pesan kesalahan “Apple Watch hanya didukung pada iOS”.
getInfo()__CAPGO_KEEP_0__isSupported: false. -
Handle pesan yang memerlukan balasan
// Listen for messages that need a responseawait CapgoWatch.addListener('messageReceivedWithReply', async (event) => {console.log('Request from watch:', event.message);// Process the requestconst result = await processWatchRequest(event.message);// Send reply back to watchawait CapgoWatch.replyToMessage({callbackId: event.callbackId,data: { result }});}); -
Sink aplikasi state
// Update application context (latest value only)await CapgoWatch.updateApplicationContext({context: {theme: 'dark',userId: '123',lastSync: Date.now()}});// Listen for context updates from watchawait CapgoWatch.addListener('applicationContextReceived', (event) => {console.log('Context from watch:', event.context);}); -
Transfer informasi pengguna secara andal
// Queue data for reliable delivery (even when watch is offline)await CapgoWatch.transferUserInfo({userInfo: {recordId: '456',action: 'created',data: { name: 'Item 1' }}});// Listen for user info transfersawait CapgoWatch.addListener('userInfoReceived', (event) => {console.log('User info from watch:', event.userInfo);}); -
Monitor koneksi
// Track reachability changesawait CapgoWatch.addListener('reachabilityChanged', (event) => {console.log('Watch reachable:', event.isReachable);if (event.isReachable) {// Watch is now available for interactive messaging}});// Track session activation stateawait CapgoWatch.addListener('activationStateChanged', (event) => {// 0 = notActivated, 1 = inactive, 2 = activatedconsole.log('Session state:', event.state);});
Implementasi Aplikasi Jam
Bagian berjudul “Implementasi Aplikasi Jam”Aplikasi watchOS Anda harus mengimplementasikan WatchConnectivity. Berikut adalah contoh SwiftUI:
import SwiftUIimport WatchConnectivity
@mainstruct MyWatchApp: App { init() { WatchViewModel.shared.activate() }
var body: some Scene { WindowGroup { ContentView() } }}
class WatchViewModel: NSObject, ObservableObject, WCSessionDelegate { static let shared = WatchViewModel()
@Published var lastMessage: [String: Any] = [:]
func activate() { guard WCSession.isSupported() else { return } WCSession.default.delegate = self WCSession.default.activate() }
// Send message to iPhone func sendToPhone(_ data: [String: Any]) { guard WCSession.default.isReachable else { print("iPhone not reachable") return } WCSession.default.sendMessage(data, replyHandler: nil) }
// Send message with reply func sendToPhoneWithReply(_ data: [String: Any], completion: @escaping ([String: Any]) -> Void) { guard WCSession.default.isReachable else { return } WCSession.default.sendMessage(data, replyHandler: completion) }
// Receive message from iPhone func session(_ session: WCSession, didReceiveMessage message: [String: Any]) { DispatchQueue.main.async { self.lastMessage = message } }
// Receive application context func session(_ session: WCSession, didReceiveApplicationContext applicationContext: [String: Any]) { DispatchQueue.main.async { self.lastMessage = applicationContext } }
// Required delegate methods func session(_ session: WCSession, activationDidCompleteWith activationState: WCSessionActivationState, error: Error?) { print("Watch session activated: \(activationState.rawValue)") }}API Referensi
Judul bagian “API Referensi”Metode
Judul bagian “Metode”sendMessage(options: SendMessageOptions)
Judul bagian “sendMessage(options: SendMessageOptions)”Kirim pesan interaktif ke jam tangan. Memerlukan jam tangan untuk dapat dijangkau.
Parameter:
data: Objek - Data yang dikirim ke jam tangan
updateApplicationContext(options: UpdateContextOptions)
Judul bagian “updateApplicationContext(options: UpdateContextOptions)”Perbarui konteks aplikasi. Hanya nilai terbaru yang disimpan.
Parameter:
context: Object - Data konteks untuk sinkronisasi
transferUserInfo(options: TransferUserInfoOptions)
Judul Bagian “transferUserInfo(options: TransferUserInfoOptions)”Tunggu informasi pengguna untuk pengiriman yang dapat diandalkan.
Parameter:
userInfo: Object - Informasi pengguna untuk ditransfer
replyToMessage(options: ReplyMessageOptions)
Judul Bagian “replyToMessage(options: ReplyMessageOptions)”Balas pesan yang meminta tanggapan.
Parameter:
callbackId: string - ID panggilan balik dari event messageReceivedWithReplydata: Object - Data balasan
getInfo()
Judul Bagian “getInfo()”Dapatkan status koneksi jam.
Returns: WatchInfo objek dengan:
isSupported: boolean - Apakah WatchConnectivity tersediaisPaired: boolean - Apakah jam terpasangisWatchAppInstalled: boolean - Apakah aplikasi jam terinstalisReachable: boolean - Apakah jam dapat dijangkauactivationState: number - Status sesi (0/1/2)
getPluginVersion()
Judul Bagian “getPluginVersion()”Dapatkan versi plugin native.
Event
Judul Bagian “Event”| Event | Deskripsi |
|---|---|
messageReceived | Pesan sederhana dari jam tangan |
messageReceivedWithReply | Pesan yang menunggu jawaban (termasuk callbackId) |
applicationContextReceived | Perbarui konteks dari jam tangan |
userInfoReceived | Transfer informasi pengguna dari jam tangan |
reachabilityChanged | Koneksi jam tangan berubah |
activationStateChanged | Status aktivasi sesi berubah |
Gaya Komunikasi
Bab berjudul “Gaya Komunikasi”Pengiriman Pesan Langsung (sendMessage)sendMessage)
Bab berjudul “Pengiriman Pesan Langsung (sendMessage)”- Memerlukan watch untuk dapat dijangkau
- Paling baik untuk komunikasi interaktif dan sensitif terhadap waktu
- Gagal segera jika watch tidak tersedia
Konteks Aplikasi ("Konteks Aplikasi (updateApplicationContext)"updateApplicationContext)
Nilai terbaru saja - nilai sebelumnya dihapus- Paling baik untuk sinkronisasi keadaan aplikasi saat ini
- Dikirim ketika watch tersedia
- Pengiriman Informasi Pengguna ("Pengiriman Informasi Pengguna (transferUserInfo)"
Ditambahkan dan dikirimkan dalam urutantransferUserInfo)
Paling baik untuk data penting yang harus dikirimkan- __CAPGO_KEEP_0__
- __CAPGO_KEEP_0__
- Bekerja bahkan ketika jam tangan tidak tersedia secara sementara
Catatan Platform
Judul Bagian “Catatan Platform”- Memerlukan iOS 15.0 atau lebih baru
- Menggunakan framework WatchConnectivity
- Sesi secara otomatis diaktifkan pada saat plugin dimuat
- Mendukung pengiriman latar belakang untuk konteks dan informasi pengguna
Android
Judul Bagian “Android”- Tidak didukung (Apple Watch hanya dapat dijalankan di iOS)
- Semua metode menolak dengan kesalahan yang sesuai
getInfo()kembaliisSupported: false
- Tidak didukung
- Semua metode menolak dengan kesalahan tidak tersedia
getInfo()kembaliisSupported: false
Penggunaan Umum
Judul Bagian “Penggunaan Umum”- Sinkron Data: Pantau data telepon dan komputer secara sinkron
- Kontrol Jarak Jauh: Mengontrol fitur ponsel dari jam tangan
- Notifikasi: Kirim notifikasi kustom ke jam tangan
- Data Kesehatan: Bagikan metrik kesehatan dan olahraga
- Pengendalian Media: Mengontrol pemutaran musik dari jam tangan
- Rumah Cerdas: Mengontrol perangkat dari lengan
Pengaturan
Bagian berjudul “Pengaturan”Jam tangan tidak dapat dijangkau:
- Pastikan watch berada dalam jangkauan Bluetooth
- Periksa bahwa kedua aplikasi berjalan
- Pastikan WCSession diaktifkan pada kedua sisi
Pesan tidak diterima:
- Periksa bahwa pendengar telah terdaftar sebelum mengirim
- Pastikan aplikasi jam tangan mengimplementasikan WCSessionDelegate
- Gunakan
transferUserInfountuk pengiriman yang terjamin
Sesi tidak aktif:
- Pastikan kemampuan WatchConnectivity ditambahkan di Xcode
- Periksa bahwa aplikasi jam tangan memiliki ID bundle kompanen
- Pastikan kedua aplikasi targetkan versi OS yang kompatibel
Teruskan dari Getting Started
Bab yang berjudul “Teruskan dari Getting Started”Jika Anda menggunakan Getting Started untuk merencanakan pekerjaan plugin native, hubungkannya dengan Menggunakan @capgo/capacitor-watch untuk kemampuan native di Menggunakan @capgo/capacitor-watch, Daftar Direktori Plugin Capgo untuk alur kerja produk di Daftar Direktori Plugin Capgo, Plugin-Plugin Capacitor oleh Capgo untuk detail implementasi di Plugin-Plugin Capacitor oleh Capgo, Menambahkan atau Mengupdate Plugin untuk detail implementasi dalam Menambahkan atau Mengupdate Plugin, dan Alternatif Plugin Enterprise Ionic untuk alur produk dalam Alternatif Plugin Enterprise Ionic.