Saltar al contenido

Crear una aplicación de reloj watchOS

Esta guía te guía a través de la creación de una aplicación de compañero de reloj de watchOS desde cero, incluyendo la configuración del proyecto en Xcode, la integración del CapgoWatchSDK y la creación de una aplicación de reloj funcional con SwiftUI.

Antes de comenzar, asegúrate de tener:

  • Xcode 15 o posterior (descargar desde Mac App Store)
  • macOS Sonoma o posterior (para el último watchOS SDK)
  • Un proyecto iOS Capacitor existente (ejecutar npx cap add ios si no lo has hecho)
  • Cuenta de desarrollador de Apple (una cuenta gratuita funciona para el desarrollo)

Después de completar esta guía, tu proyecto tendrá esta estructura:

  • Directorioios/
    • DirectorioApp/
      • DirectorioApp/ (su aplicación principal de iOS)
      • App.xcodeproj
      • App.xcworkspace (utilice esto para abrir el proyecto)
      • Podfile
    • DirectorioMiReloj/ (nueva aplicación de reloj)
      • DirectorioMiReloj/ (fuente de la aplicación de reloj)
        • MyWatchApp.swift
        • ContentView.swift
        • DirectorioAssets.xcassets/
      • MyWatch.xcodeproj
  1. Navegue a su proyecto Capacitor ios/App carpeta
  2. Abrir App.xcworkspace no .xcodeproj) haciendo doble clic en él
  3. Espera a que Xcode indexe el proyecto
  1. En Xcode, vaya a Archivo → Nuevo → Objetivo…

  2. En el selector de plantillas:

    • Seleccione pantalla de watchOS pestaña en la parte superior
    • Seleccione Aplicación
    • Haga clic Siguiente
  3. Configure su aplicación de reloj:

    • Nombre del producto: MyWatch (o el nombre que prefieras)
    • Equipo: Selecciona tu equipo de desarrollador de Apple
    • Identificador de la organización: Debe coincidir con tu aplicación iOS (por ejemplo, app.capgo)
    • Identificador de la aplicación: Se generará automáticamente (por ejemplo, app.capgo.myapp.watchkitapp)
    • Idioma: Swift
    • Interfaz de usuario: SwiftUI
    • Tipo de aplicación de reloj: Aplicación (no aplicación para la aplicación de iOS existente)
    • Deshacer Incluir escena de notificación (a menos que lo necesite)
    • Deshacer Incluir complicación (a menos que lo necesite)
  4. Hacer clic Finalizar

  5. Cuando se le pregunte “Activar ‘MiReloj’ esquema?”, haga clic Activar

Paso 3: Configura Configuración de la Aplicación de Reloj

Sección titulada “Paso 3: Configura Configuración de la Aplicación de Reloj”
  1. En el Navegador de Proyectos (barra lateral izquierda), selecciona tu proyecto (el icono azul en la parte superior)

  2. Selecciona tu objetivo de reloj (por ejemplo, “Mi Reloj”) de la lista de objetivos

  3. Vaya a la página general: Nombre de la Pantalla

    • : El nombre que se muestra debajo del icono de la aplicación (por ejemplo, “Mi Aplicación”)Identificador de la Caja
    • : Debe terminar conVersión .watchkitapp
    • __CAPGO_KEEP_0__: Sincronice la versión de su aplicación iOS
    • Compilar: Sincronice el número de compilación de su aplicación iOS
  4. Ir a Firma y Capabilities pestaña:

    • Habilitar Administrar automáticamente la firma
    • Seleccione su Equipo
    • Xcode creará perfiles de configuración automáticamente
  5. Configurar Información de Despliegue:

    • Despliegues Mínimos: watchOS 9.0 o posterior

Paso 4: Agregar CapgoWatchSDK mediante Gestor de Paquetes de Swift

Sección titulada “Paso 4: Agregar CapgoWatchSDK mediante Gestor de Paquetes de Swift”

El CapgoWatchSDK proporciona una clase lista para su uso WatchConnector para la comunicación.

  1. En Xcode, vaya a Archivo → Agregar Dependencias de Paquetes…

  2. En el campo de búsqueda, ingrese:

    https://github.com/Cap-go/capacitor-watch.git
  3. Presione Enter y espere a que Xcode cargue el paquete

  4. Configura el paquete:

    • Regla de dependencia: “Hasta la próxima versión mayor” con “8.0.0”
    • Hacer clic Agregar paquete
  5. Elige qué productos agregar:

    • IMPORTANTE: Solo selecciona CapgoWatchSDK
    • Asegúrate de que esté agregado a tu watch target (por ejemplo, “MiWatch”), no la aplicación de iOS
    • Hacer clic Agregar Paquete

Ahora, crémos la aplicación de reloj code. Reemplaza los archivos generados automáticamente con los siguientes:

Editar MyWatch/MyWatchApp.swift:

import SwiftUI
import CapgoWatchSDK
@main
struct MyWatchApp: App {
init() {
// Activate WatchConnectivity when app launches
WatchConnector.shared.activate()
}
var body: some Scene {
WindowGroup {
ContentView()
}
}
}

Editar MyWatch/ContentView.swift:

import SwiftUI
import CapgoWatchSDK
struct ContentView: View {
// Observe the WatchConnector for automatic UI updates
@ObservedObject var connector = WatchConnector.shared
// Local state
@State private var messageText = ""
@State private var statusMessage = "Ready"
var body: some View {
ScrollView {
VStack(spacing: 16) {
// Connection Status
ConnectionStatusView(connector: connector)
Divider()
// Message Input
TextField("Message", text: $messageText)
.textFieldStyle(.roundedBorder)
// Send Buttons
HStack {
Button("Send") {
sendMessage()
}
.disabled(!connector.isReachable || messageText.isEmpty)
Button("Request") {
sendWithReply()
}
.disabled(!connector.isReachable || messageText.isEmpty)
}
Divider()
// Status
Text(statusMessage)
.font(.caption)
.foregroundColor(.secondary)
// Last Received Message
if !connector.lastMessage.isEmpty {
VStack(alignment: .leading) {
Text("Last Message:")
.font(.caption)
.foregroundColor(.secondary)
Text(formatMessage(connector.lastMessage))
.font(.caption2)
}
.frame(maxWidth: .infinity, alignment: .leading)
}
}
.padding()
}
}
private func sendMessage() {
connector.sendMessage(["text": messageText, "timestamp": Date().timeIntervalSince1970])
statusMessage = "Message sent"
messageText = ""
}
private func sendWithReply() {
connector.sendMessage(["text": messageText, "needsReply": true]) { reply in
DispatchQueue.main.async {
statusMessage = "Reply: \(formatMessage(reply))"
}
}
messageText = ""
}
private func formatMessage(_ message: [String: Any]) -> String {
message.map { "\($0.key): \($0.value)" }.joined(separator: ", ")
}
}
// Separate view for connection status
struct ConnectionStatusView: View {
@ObservedObject var connector: WatchConnector
var body: some View {
HStack {
Circle()
.fill(connector.isReachable ? Color.green : Color.red)
.frame(width: 12, height: 12)
Text(connector.isReachable ? "Connected" : "Disconnected")
.font(.headline)
Spacer()
if connector.isActivated {
Image(systemName: "checkmark.circle.fill")
.foregroundColor(.green)
}
}
}
}
#Preview {
ContentView()
}

Paso 6: Configura la aplicación de iOS para WatchConnectivity

Sección titulada “Paso 6: Configura la aplicación de iOS para WatchConnectivity”

También necesita la capacidad de WatchConnectivity tu aplicación de iOS.

  1. En el Navegador de Proyectos, selecciona tu proyecto

  2. Selecciona tu Objetivo de aplicación de iOS (no el objetivo de reloj)

  3. Ir a Registro y capacidades pestaña

  4. Haga clic + Capacidad

  5. Buscar y agregar WatchConnectivity (si está disponible) o puede ser agregado automáticamente

  6. El plugin Capacitor maneja el lado iOS automáticamente, pero asegúrese de que su Info.plist tenga:

    <key>WKCompanionAppBundleIdentifier</key>
    <string>app.capgo.myapp.watchkitapp</string>
  1. Seleccione el esquema de reloj desde el selector de esquemas (parte superior de la ventana de Xcode)

  2. Seleccione un simulador de reloj:

    • Haga clic en el selector de dispositivo junto al esquema
    • Seleccione un simulador de Apple Watch (por ejemplo, “Apple Watch Series 9 (45mm)”)
  3. Haga clic en el botón Ejecutar o presione Cmd + R

  4. El simulador de iOS se lanzará con ambos iPhone y Apple Watch

  1. Conecta tu iPhone mediante USB

  2. Asegúrate de que tu reloj Apple esté pairado con ese iPhone

  3. Selecciona tu esquema de reloj

  4. Selecciona tu reloj Apple físico desde la lista de dispositivos

  5. Hacer clic Ejecutar

  6. Primera vez: Puede que debas confiar en tu computadora en ambos dispositivos

En tu aplicación Capacitor:

import { CapgoWatch } from '@capgo/capacitor-watch';
// Check connection
const info = await CapgoWatch.getInfo();
console.log('Watch reachable:', info.isReachable);
// Send a message
if (info.isReachable) {
await CapgoWatch.sendMessage({
data: { action: 'update', value: 'Hello from iPhone!' }
});
}

La aplicación del reloj utiliza WatchConnector:

// Send message (fire and forget)
WatchConnector.shared.sendMessage(["action": "buttonTapped"])
// Send message with reply
WatchConnector.shared.sendMessage(["request": "getData"]) { reply in
print("Got reply: \(reply)")
}
// Listen for messages from watch
await CapgoWatch.addListener('messageReceived', (event) => {
console.log('Message from watch:', event.message);
// { action: 'buttonTapped' }
});
// Handle messages that need a reply
await CapgoWatch.addListener('messageReceivedWithReply', async (event) => {
console.log('Request from watch:', event.message);
// Send reply back
await CapgoWatch.replyToMessage({
callbackId: event.callbackId,
data: { status: 'success', items: ['item1', 'item2'] }
});
});

Avanzado: Delegado personalizado para más control

Sección titulada “Avanzado: Delegado personalizado para más control”

Si necesita más control, implemente WatchConnectorDelegate:

import SwiftUI
import CapgoWatchSDK
class WatchHandler: WatchConnectorDelegate {
func didReceiveMessage(_ message: [String: Any]) {
print("Received: \(message)")
// Handle incoming message
}
func didReceiveMessageWithReply(_ message: [String: Any],
replyHandler: @escaping ([String: Any]) -> Void) {
print("Received request: \(message)")
// Process and send reply
replyHandler(["status": "processed"])
}
func didReceiveApplicationContext(_ context: [String: Any]) {
print("Context updated: \(context)")
}
func didReceiveUserInfo(_ userInfo: [String: Any]) {
print("User info received: \(userInfo)")
}
func reachabilityDidChange(_ isReachable: Bool) {
print("Reachability changed: \(isReachable)")
}
func activationDidComplete(with state: WCSessionActivationState) {
print("Activation completed: \(state.rawValue)")
}
}
// In your app setup:
let handler = WatchHandler()
WatchConnector.shared.delegate = handler
WatchConnector.shared.activate()
  1. Asegúrese de que los IDs de paquete estén relacionados correctamente (el ID de paquete de la aplicación de reloj debe ser el ID de paquete de la aplicación de iOS + .watchkitapp)
  2. Verifique que ambas aplicaciones estén firmadas con el mismo equipo
  3. En dispositivo físico: Abra la aplicación de reloj en el iPhone → Mi reloj → desplácese para encontrar su aplicación → active ON
  1. Verificar que ambas aplicaciones tengan activada la sesión WC
  2. Comprobar isReachable antes de enviar mensajes
  3. Para una entrega garantizada, utilice transferUserInfo en lugar de sendMessage
  4. Asegurarse de que los oyentes estén registrados antes de que el otro dispositivo envíe mensajes
  1. Llamar WatchConnector.shared.activate() temprano en el ciclo de vida de la aplicación
  2. En iOS, el plugin se activa automáticamente - asegúrese de que el plugin esté importado
  3. Verifique que la capacidad de WatchConnectivity se haya agregado al objetivo iOS
  1. Asegúrese de que el paquete se agregue al target de reloj, no al objetivo iOS
  2. Eliminar carpeta de compilación: Producto → Eliminar Carpeta de Compilación (Cmd + Shift + K)
  3. Reiniciar cachés de paquetes: Archivo → Paquetes → Reiniciar Cachés de Paquetes
  1. Reiniciar los simuladores: Dispositivo → Borrar todo el contenido y ajustes
  2. Asegúrese de que los simuladores de iOS y watchOS sean pares compatibles
  3. Ambos simuladores deben estar en ejecución para que la comunicación funcione