Quantcast
Channel: iOS – TechNetExperts
Viewing all articles
Browse latest Browse all 34

Watch Connectivity Framework – iOS

$
0
0

The Watch Connectivity framework ( WatchConnectivity.framework ) acts as a two-way communication channel between an iOS app and a WatchKit extension on a paired Apple Watch. Apple iOS apps make use of this framework to pass files and data back and forth. If the receiving app is inactive, then on waking up, the receiving app user is notified of any data that is received when it was inactive. When both the apps are active, live communication between the two is possible.

So in this tutorial, lets take a quick look of Watch Connectivity Framework that is used to develop Apple watch apps.

Classes of WatchConnectivity.framework

  • WCSession
  • WCSessionFile
  • WCSessionFileTransfer
  • WCSessionUserInfoTransfer

The two processes get a chance to communicate with each other by sending messages when both the session objects are active. In case if only one session is active, the active session can send updates and files transfer will also take place. These types of transfers happen in the background.

  • To configure and activate the session, the user needs to assign a delegate to the default session object and call that object’s activateSession method.
  • The session must be configured and activated before sending messages or obtaining information about the state of the connection. We can transfer data in background mode and foreground mode.
  • Before activating the session, you have to call the isSupported method to make sure that current device can use the Watch Connectivity framework. So in your ViewController.m file on button action method write following code,

Before sending message we can check for confirmation whether session is reachable or not.

- (IBAction)sendMsgToWatchTap:(id)sender{

	 if ([[WCSession defaultSession] isReachable]) {

   	  	  NSLog(@"watch is reachable");
		   [[WCSession defaultSession]sendMessage:@{@"msg":self.textfield.text} 					replyHandler:^(NSDictionary<NSString *,id> * _Nonnull replyMessage) {
            
          	  NSLog(@"%@reply message@",replyMessage);
        	} errorHandler:^(NSError * _Nonnull error) {
            	NSLog(@"error = %@",error.description);
       }];

  	  } else {
      		  NSLog(@"watch is not reachable");
  	  }
}

To get received message we have to call this method.

-(void)session:(nonnull WCSession *)session didReceiveMessage:(nonnull NSDictionary<NSString *,id> *)message replyHandler:(nonnull void (^)(NSDictionary<NSString *,id> * __nonnull))replyHandler{
    
    dispatch_async(dispatch_get_main_queue(), ^{
        // code here
        NSLog(@"didReceiveMessage called in iphone");
        [self.label setText:[message valueForKey:@"msg"]];
        
            UIAlertAction *act1 = [UIAlertAction actionWithTitle:@"OK" style:UIAlertActionStyleDefault handler:^(UIAlertAction *action){
            }];
        
            UIAlertController *alert =[UIAlertController alertControllerWithTitle:@"Watch Demo" message:[message valueForKey:@"msg"] preferredStyle:UIAlertControllerStyleAlert];
            [alert addAction:act1];
        
            [self presentViewController:alert animated:YES completion:nil];
        
    });
    
    NSDictionary *temp = @{@"reply":@"reply from iphone"};
    replyHandler(temp);
}

In InterfaceController.m file you have to activateSession. So write following code in willActivate method in InterfaceController class.

- (void)willActivate {
    // This method is called when watch view controller is about to be visible to user
    [super willActivate];
    
    if ([WCSession isSupported]) {
        
        WCSession* session = [WCSession defaultSession];
        session.delegate = self;
        [session activateSession];
    } else {
        NSLog(@"not supported session in watch");
    }
}

- (IBAction)sendMessageToiPhoneTap {

// send message to iphone
  [[WCSession defaultSession]sendMessage:@{@"msg":@"howdy from watch...."}  replyHandler:^(NSDictionary *reply){
            
            NSLog(@"%@",[reply valueForKey:@"reply"]);
            
        }errorHandler:^(NSError *error){
            NSLog(@"%@",error.description);
        }];
}

To get received message,

- (void)session:(WCSession *)session didReceiveMessage:(NSDictionary<NSString *, id> *)message{
    NSLog(@"didReceiveMessage called");
    [self.labelText setText:[message valueForKey:@"msg"]];
}

You can also send data or information with other methods.

- (BOOL)updateApplicationContext:(NSDictionary<NSString *, id> *)applicationContext error:(NSError **)error;

- (void)session:(WCSession *)session didReceiveApplicationContext:(NSDictionary<NSString *, id> *)applicationContext;

above method is user to send small amounts of state information to a counterpart app and this method is communicate in background with counterpart app.

- (void)session:(WCSession *)session didReceiveUserInfo:(NSDictionary<NSString *, id> *)userInfo;
- (WCSessionUserInfoTransfer *)transferUserInfo:(NSDictionary<NSString *, id> *)userInfo;

I have also created a video for better visualizing and understanding of Watch Connectivity framework and how does it work. Here it is for your reference.

So this was the high level overview about using Watch Connectivity framework to develop Apple Watch apps.


Author : HardikJB


Viewing all articles
Browse latest Browse all 34

Trending Articles