Aller directement au contenu

Démarrage

  1. Installez le package

    Fenêtre de terminal
    bun add @capgo/capacitor-watch
  2. Synchroniser avec les projets natifs

    Fenêtre de terminal
    bunx cap sync
  3. Configurer le plugin

    Exemple de base d'utilisation :

    import { CapgoWatch } from '@capgo/capacitor-watch';
    // Check watch connectivity status
    const info = await CapgoWatch.getInfo();
    console.log('Watch paired:', info.isPaired);
    console.log('Watch reachable:', info.isReachable);
    // Listen for messages from watch
    await CapgoWatch.addListener('messageReceived', (event) => {
    console.log('Message from watch:', event.message);
    });

    Envoyer un message à l'horloge :

    // Check if watch is reachable first
    const info = await CapgoWatch.getInfo();
    if (info.isReachable) {
    await CapgoWatch.sendMessage({
    data: { action: 'refresh', timestamp: Date.now() }
    });
    }

    Configuration requise d'iOS :

    1. Ajoutez la capacité WatchConnectivity à votre application iOS dans Xcode
    2. Créez une cible d'application watchOS dans votre projet Xcode
    3. Mettez en œuvre WatchConnectivity dans votre application watchOS (voir l'implémentation de l'application Watch ci-dessous)

    Le plugin active automatiquement la WCSession lors du chargement du plugin.

  4. Gérez les messages qui nécessitent une réponse

    // Listen for messages that need a response
    await CapgoWatch.addListener('messageReceivedWithReply', async (event) => {
    console.log('Request from watch:', event.message);
    // Process the request
    const result = await processWatchRequest(event.message);
    // Send reply back to watch
    await CapgoWatch.replyToMessage({
    callbackId: event.callbackId,
    data: { result }
    });
    });
  5. Synchronisez l'état de l'application

    // Update application context (latest value only)
    await CapgoWatch.updateApplicationContext({
    context: {
    theme: 'dark',
    userId: '123',
    lastSync: Date.now()
    }
    });
    // Listen for context updates from watch
    await CapgoWatch.addListener('applicationContextReceived', (event) => {
    console.log('Context from watch:', event.context);
    });
  6. Transférez les informations de l'utilisateur de manière fiable

    // 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 transfers
    await CapgoWatch.addListener('userInfoReceived', (event) => {
    console.log('User info from watch:', event.userInfo);
    });
  7. Surveiller la connectivité

    // Track reachability changes
    await CapgoWatch.addListener('reachabilityChanged', (event) => {
    console.log('Watch reachable:', event.isReachable);
    if (event.isReachable) {
    // Watch is now available for interactive messaging
    }
    });
    // Track session activation state
    await CapgoWatch.addListener('activationStateChanged', (event) => {
    // 0 = notActivated, 1 = inactive, 2 = activated
    console.log('Session state:', event.state);
    });

Votre application horloge doit mettre en œuvre WatchConnectivity. Voici un exemple SwiftUI :

import SwiftUI
import WatchConnectivity
@main
struct 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)")
}
}

Section intitulée “Methods”

Paramètres :

  • data : Objet - Les données à envoyer à l'horloge

Mettre à jour le contexte d'application. Seule la dernière valeur est conservée.

Paramètres :

  • context : Objet - Les données de contexte à synchroniser

File d'attente les informations sur l'utilisateur pour une livraison fiable.

Paramètres :

  • userInfo : Objet - Les informations sur l'utilisateur à transférer

Répondre à un message qui a demandé une réponse.

Paramètres :

  • callbackId: string - L'ID de rappel de l'événement messageReceivedWithReply
  • data: Objet - Les données de réponse

Obtenir l'état de la connectivité de l'horloge.

Retourne : WatchInfo un objet avec :

  • isSupported: boolean - Si WatchConnectivity est disponible
  • isPaired: boolean - Si une horloge est pairée
  • isWatchAppInstalled: boolean - Si l'application horloge est installée
  • isReachable: boolean - Si l'horloge est accessible
  • activationState: nombre - État de session (0/1/2)

Obtenez la version du plugin natif.

ÉvénementDescription
messageReceivedMessage simple de la montre
messageReceivedWithReplyMessage attendu en réponse (inclut callbackId)
applicationContextReceivedMise à jour du contexte de la montre
userInfoReceivedTransfert d'informations sur l'utilisateur de la montre
reachabilityChangedModification de la connectivité de la montre
activationStateChangedÉtat d'activation de la session modifié
  • Requis pour que l'horloge soit accessible
  • Meilleur pour la communication interactive et sensible à l'heure
  • Échoue immédiatement si l'horloge n'est pas disponible

Contexte de l'application (updateApplicationContext)

Dernière valeur uniquement - les valeurs précédentes sont effacées
  • Meilleur pour synchroniser l'état actuel de l'application
  • Envoyé lorsque l'horloge devient disponible
  • __CAPGO_KEEP_0__

Transfert d'informations de l'utilisateur (transferUserInfo)

Section intitulée « Transfert d'informations de l'utilisateur (transferUserInfo) »
  • En file d'attente et livré dans l'ordre
  • Meilleur pour les données importantes qui doivent être livrées
  • Fonctionne même lorsque l'horloge est temporairement inatteignable
  • Exige iOS 15.0 ou une version ultérieure
  • Utilise le framework WatchConnectivity
  • La session s'active automatiquement à la charge du plugin
  • Supporte la livraison de fond pour le contexte et les informations de l'utilisateur
  • Pas pris en charge (Apple Watch est uniquement iOS)
  • Toutes les méthodes rejettent avec une erreur appropriée
  • getInfo() returns isSupported: false
  • Pas pris en charge
  • Toutes les méthodes rejettent avec une erreur non disponible
  • getInfo() returns isSupported: false
  1. Synchronisation de données: Gardez vos données de téléphone et de montre synchronisées
  2. Contrôle à distance: Contrôlez les fonctionnalités de votre téléphone depuis votre montre
  3. Notifications: Envoyez des notifications personnalisées à votre montre
  4. Données de santé: Partagez vos métriques de fitness et de santé
  5. Contrôle de médias: Contrôlez la lecture de musique depuis votre montre
  6. Maison intelligente: Contrôlez les appareils de votre poignet

Montre non accessible :

  • Vérifiez que la montre est dans la zone de portée Bluetooth
  • Vérifiez que les deux applications sont en cours d'exécution
  • Vérifiez que WCSession est activé des deux côtés

Messages non reçus :

  • Vérifiez que les écouteurs sont enregistrés avant d'envoyer
  • Vérifiez que l'application de montre implémente WCSessionDelegate
  • Utilisez transferUserInfo pour une livraison garantie

La session ne s'active pas :

  • Assurez-vous que la capacité WatchConnectivity est ajoutée dans Xcode
  • Vérifiez que l'application montre une ID de bundle de l'application de compagnon
  • Vérifiez que les deux applications ciblent des versions OS compatibles