最近在做一个项目,涉及到iPhone设备和手表传输数据、控制彼此界面跳转,在网上找了很多资料,发现国内的网站这方面介绍的不多,而国外的网站写的也不是很全,所以在这写这篇博客,给大家参考一下,望大神指点一二。

iPhone和iWatch配对这个不需要多说,百度搜索答案一大堆,这个是前提。

iPhone与iWatch交互的代码有两种情况,取决于iWatch的系统。iWatch OS1与OS2、3的方法不同,在OS1的系统中,iWatch发送数据的代码如下

let userInfo:[String:String] = ["key":"value"]
WKInterfaceController.openParentApplication(userInfo) { (replyInfo, error) -> Void in
}

这个函数是发送消息,同时也是接收消息,接收到iPhone的回复是replyInfo。在iPhone端的AppDelegate中,接收消息的代码:

func application(application: UIApplication, handleWatchKitExtensionRequest userInfo: [NSObject : AnyObject]?, reply: (([NSObject : AnyObject]!) -> Void)!) {
}

接收到的消息是userInfo,回复给iWatch的数据是reply。

以上的代码仅适用于watchOS1,之后的系统就没有这个API了,对于OS2或OS3,使用的框架是WatchConnectivity,在这里,我将直接提供我写的类,并给出介绍和使用方法,大家可以直接复制代码,在我注释的地方写自己的功能便可。

以下是iPhone端的代码:

import UIKit
import WatchConnectivity class IwatchSessionUtil: NSObject, WCSessionDelegate {
//静态单例
static let shareManager = IwatchSessionUtil() //初始化
private override init()
{
super.init()
} // 连接机制
private let session:WCSession? = WCSession.isSupported() ? WCSession.default() : nil // 激活会话对象
func startSession(){
session?.delegate = self
session?.activate()
} // 检测到watch端app
func session(_ session: WCSession, activationDidCompleteWith activationState: WCSessionActivationState, error: Error?) {
print("AppleWatch匹配完成")
} // 通信完成会话对象开始闲置
func sessionDidBecomeInactive(_ session: WCSession) {
} // 通信完成会话对象释放
func sessionDidDeactivate(_ session: WCSession) {
} // watch侧发送数据过来,iPhone接收到数据并回复数据过去
// message: watch侧发送过来的信息
// replyHandler: iPhone回复过去的信息
func session(_ session: WCSession, didReceiveMessage message: [String : Any], replyHandler: @escaping ([String : Any]) -> Void) {
// 在这里,我们接收到watch发送过来的数据,可以用代理、代码块或者通知中心传值到ViewController,做出一系列操作。
// 注!!:watch侧发送过来信息,iPhone回复直接在这个函数里回复replyHandler([String : Any])(replyHandler(数据)),这样watch侧发送数据的函数对应的reply才能接收到数据,别跟sendMessage这个函数混淆了。如果用sendMessage回复,那watch侧接收到信息就是didReceiveMessage的函数。
} // iPhone向watch发送数据
// key: 数据的key值
// value: 数据内容
func sendMessageToWatch(key:String,value:Any) {
session?.sendMessage([key : value], replyHandler: { (dict:Dictionary) in
// 这里是发送数据后的操作,比如写个alert提示发送成功
   // replyHandler是watch侧didReceiveMessage函数接收到信息后reply回复过来的内容,这里可以编辑自己需要的功能
}, errorHandler: { (Error) in
// 发送失败,一般是蓝牙没开,或手机开了飞行模式
})
}
}

调用方法:1、首先在iPhone的AppDelegate的didFinishLaunchingWithOptions函数中添加代码IwatchSessionUtil.shareManager.startSession(),确保WCSession能匹配到watch侧的App

2、发送消息:调用方法IwatchSessionUtil.shareManager.sendMessageToWatch(key: , value: )即可,发送后接收到watch侧的回复后的操作,直接在类sendMessage函数中编辑就行

3、watch侧sendMessage发送信息给iPhone,iPhone侧didReceiveMessage接收到信息,一系列操作上面已经注释写到。

iPhone端的介绍完毕,下面写watch端的代码,其实跟iPhone的没什么区别,这里只是为了把这部分内容写完全。

import WatchKit
import WatchConnectivity class WatchSessionUtil: NSObject,WCSessionDelegate {
// 静态单例
static let sharedManager = WatchSessionUtil() // 初始化
private override init()
{
super.init()
} // 连接机制
private let session:WCSession? = WCSession.isSupported() ? WCSession.default() : nil // 激活机制
func startSession(){
session?.delegate=self
session?.activate()
} // 检测到iPhone的父应用
func session(_ session: WCSession, activationDidCompleteWith activationState: WCSessionActivationState, error: Error?) {
}
    // 通信完成会话对象开始闲置
func sessionDidBecomeInactive(_ session: WCSession) {
} // 通信完成会话对象释放
func sessionDidDeactivate(_ session: WCSession) {
}
  // 接收到iPhone端发送过来的信息
// message: iPhone端发送过来的信息
// replyHandler: watch端回复给iPhone的内容
func session(_ session: WCSession, didReceiveMessage message: [String : Any], replyHandler: @escaping ([String : Any]) -> Void) {
// 这里也可以通过通知中心发送通知给InterfaceController,进行页面操作,至于用什么方法大家随意。注意事项iPhone的代码里提到了,一样的性质,这里就不写了。
} // 向iPhone侧发送信息
func sendMessage(key:String, value:Any){
session?.sendMessage([key : value], replyHandler: { (reply: [String : Any]) in
// 信息发送之后,收到iPhone端回复的操作
}, errorHandler: { (Error) in
// 发送失败
})
}
}

watch的类添加在Extension的文件夹中,调用方法:

1、ExtensionDelegate文件的applicationDidFinishLaunching函数里写上WatchSessionUtil.sharedManager.startSession()

2、发送消息:调用方法IwatchSessionUtil.shareManager.sendMessageToWatch(key: , value: )即可,发送后接收到iPhone侧的回复后的操作,直接在类sendMessage函数中编辑就行

3、iPhone侧sendMessage发送信息给watch,watch侧didReceiveMessage接收到信息,一系列操作上面已经注释写到。

内容就这么多,已经很全了,这里给出的是Swift代码,OC的代码我给个网址大家参照一下:http://blog.csdn.net/shenjie12345678/article/details/61913968

iPhone与iWatch连接、控制、数据传递(Swift)的更多相关文章

  1. [Swift实际操作]八、实用进阶-(8)使用performSegue在故事板页面之间进行数据传递

    本文将演示故事板页面之间的数据传递.首先在一个空白项目中,打开项目自带的故事板文件(Main.storyboard).故事板中已经拥有了一个视图控制器,点击选择该视图控制器.然后依此点击[Editor ...

  2. JSP Servlet SQL 三者之间数据传递

    前言: 最近一直在做WEB开发,现总结一下这一段时间的体会和感触. 切记,web开发重点在于前台数据交互,页面美化而不要太沉溺于底层数据. 浏览器时代来到,向我们召唤出更炫.更简洁.更方便.更大气的网 ...

  3. Dubbo协议与连接控制

    协议参考手册 (+) (#) 推荐使用Dubbo协议 性能测试报告各协议的性能情况,请参见:性能测试报告 (+) dubbo:// (+) (#) Dubbo缺省协议采用单一长连接和NIO异步通讯,适 ...

  4. 3.2 PCI设备的数据传递

    PCI设备的数据传递使用地址译码方式,当一个存储器读写总线事务到达PCI总线时,在这条总线上的所有PCI设备将进行地址译码,如果当前总线事务使用的地址在某个PCI设备的BAR空间中时,该PCI设备将使 ...

  5. (Android数据传递)Intent消息传递机制 “Intent”“数据传递”

    Intent类的继承关系:   需要注意的是,该类实现了Parcelable(用于数据传递)和Cloneable接口. Intent是一种(系统级别的)消息传递机制,可以在应用程序内使用,也可以在应用 ...

  6. JSP、servlet、SQL三者之间的数据传递

    JSP.servlet.SQL三者之间的数据传递 博客分类: web开发 JSPservletSQL数据库连接池web开发  前言: 最近一直在做WEB开发,现总结一下这一段时间的体会和感触. 切记, ...

  7. 七天学会ASP.NET MVC (二)——ASP.NET MVC 数据传递

    通过第一天的学习之后,我们相信您已经对MVC有一些基本了解. 本节所讲的内容是在上节的基础之上,因此需要确保您是否掌握了上一节的内容.本章的目标是在今天学习结束时利用最佳实践解决方案创建一个小型的MV ...

  8. MVC数据传递

    一.数据传递 1.ViewData[]: 用法:action中:ViewData["key"]="aaa";,V层接收ViewData["key&qu ...

  9. MVC数据传递和多表单

    1.数据传递(1)session和TempData 全局变量,可以将值从一个动作传递到另一个动作,也可以从控制层传递到视图层. TempData取一遍值后自动销毁. session使用: //控制器中 ...

随机推荐

  1. CountDownLatch类的使用

    java.util.concurrent.CountDownLatch是一个并发构造,它允许多个线程等候特定的操作完成. CountDownLatch用一个数字初始化,通过调用countDown()方 ...

  2. devexpress chartcontrol实现非连续点数据的显示

    1.先上图: 其中暗红的曲线中数据不连续的,在实际开发中可能也会遇到这种情况,由于断电或其他原因导致部分日期数据无法采集,如果按一般情况来显示可能会显示如下图所示: 图中可以看出非连续曲线中,3月5号 ...

  3. 纪中集训 Day 8 & Last Day

    好吧回到家一直玩到现在才来写冏= = 然后今天终于在最后一场比赛中AK了= = 虽然有两人AK,另一个是初二牛ORZ 其实都是水题+模板题 第一题是DP,第二题是模拟,第三题是可持久化TREAP(其实 ...

  4. Struts2初步接触

      使用idea快速搭建Struts2的Maven项目    首先使用intelij idea部署Maven项目 1.jar包引入 pom.xml 我们用的是阿里云 我用的是最新版的Struts2核心 ...

  5. Kettle 5.0源码编译

    下载源码请参考上一篇博文Kettle4.4.2源码分析 Kettle 5.0以前的库文件通过ant管理,5.0+的库文件通过ant+ivy管理.Eclipse一般都是安装ant插件,不安装ivy插件, ...

  6. Hibernate一级缓存(基于查询分析)

    首先我们应该弄清什么是hibernate缓存:hibernate缓存是指为了降低应用程序对物理数据源的访问频次,从而提高应用程序的运行性能的一种策略.我们要将这个跟计算机内存或者cpu的缓存区分开. ...

  7. Memcached·Redis缓存的基本操作

    Memcached Memcached 是一个高性能的分布式内存对象缓存系统,用于动态Web应用以减轻数据库负载.它通过在内存中缓存数据和对象来减少读取数据库的次数,从而提高动态.数据库驱动网站的速度 ...

  8. 好公司、行业、领导?应届生应根据什么选offer?

    两个年轻人大学毕业了,一个去了收入更高的大企业工作,一个去了收入较低的小作坊式工厂工作.你们说他们谁的青春时光最能升值呢?表面上看应该是大企业,可是大企业是做马车制造的,小作坊是做汽车的.现在人们都知 ...

  9. [HDU]1016 DFS入门题

    题目的意思就是在1到n的所有序列之间,找出所有相邻的数相加是素数的序列.Ps:题目是环,所以头和尾也要算哦~ 典型的dfs,然后剪枝. 这题目有意思的就是用java跑回在tle的边缘,第一次提交就tl ...

  10. 自定义cell设置现价,原价(加横线)

    原价,现价分别是连个label.这两个label不能直接限制死他们的宽度,因为他们的宽度不确定,而由于lable的特殊性,不设置它的宽度约束时,宽度取决于文字的内容,所以两个lable的约束设置好一些 ...