iOS8推出一个新特性,叫做Handoff。Handoff中文含义为换手(把接力棒传给下一个人),可以在一台Mac和iOS设备上开始工作,中途将工作交换到另一个Mac或iOS设备中进行。这个在iOS8和Yosemite得到支持,当然在iOS9和EI Captain中也有这个功能。

     Handoff中使用了一个“活动”的概念,它可以在多台设备间传递用户的“活动”。当用户从一台设备切换到另一台设备后,用户完全可以不中断原有的“活动”,也不需要重新配置应用程序。在这个过程中,Handoff将自动在iOS设备和Mac间保持应用程序的同步。

本应用实现了在两台iOS设备之间的协同工作。当在一台iOS设备上运行该应用时,打开另一台安装该应用的iPhone,可以快速看到同样的显示内容。可以快速实现多台设备的同步,提高了工作效率。这里我将通过Swift来实现。项目我已经上传 https://github.com/chenyufeng1991/Handoff  。

(1)创建一个iOS项目,首先在Info.plist文件中加入一个字段,NSUserActivityTypes,值可以任意,但是要唯一,我这里是:com.chenyufengweb.HandoffDemo.sync。到时候我会在代码中用到。

(2)在AppDelegate.swift中实现一个方法如下:

  1. func application(application: UIApplication, continueUserActivity userActivity: NSUserActivity, restorationHandler: ([AnyObject]?) -> Void) -> Bool {
  2. print("AppDelegate -- continueUserActivity")
  3. let topViewController = self.window?.rootViewController as! AnyObject
  4. restorationHandler([topViewController])
  5. return true
  6. }

(3)在ViewController.swift中实现如下:

  1. import UIKit
  2. class ViewController: UIViewController,NSUserActivityDelegate {
  3. @IBOutlet weak var textField: UITextField!
  4. @IBOutlet weak var switchButton: UISwitch!
  5. var str:String!
  6. var isOn:String!
  7. override func viewDidLoad() {
  8. super.viewDidLoad()
  9. let myActivity:NSUserActivity! = NSUserActivity(activityType: "com.chenyufengweb.HandoffDemo.sync")
  10. str = textField.text
  11. isOn = switchButton.on ? "on" : "off"
  12. //定义一个字典;
  13. let items = ["text":str,"switch":isOn]
  14. //配置活动参数;
  15. myActivity.userInfo = items
  16. myActivity.title = "sync"
  17. myActivity.becomeCurrent()
  18. myActivity.delegate = self
  19. myActivity.needsSave = true
  20. self.userActivity = myActivity
  21. //以代码的方式进行消息响应;
  22. //    self.textField.addTarget(self, action: "textFieldDidChange:", forControlEvents: UIControlEvents.ValueChanged)
  23. //    self.switchButton.addTarget(self, action: "onChanged", forControlEvents: UIControlEvents.ValueChanged)
  24. }
  25. func textFieldDidChange() -> Void{
  26. print("Text changed")
  27. self.userActivity?.becomeCurrent()
  28. self.userActivity?.needsSave = true
  29. }
  30. func onChanged() -> Void{
  31. print("Switch changed")
  32. self.userActivity?.becomeCurrent()
  33. self.userActivity?.needsSave = true
  34. }
  35. //以segue的方式进行控件响应,个人比较喜欢;
  36. @IBAction func textFieldDidChange(sender: AnyObject) {
  37. print("Text changed")
  38. self.userActivity?.becomeCurrent()
  39. self.userActivity?.needsSave = true
  40. }
  41. @IBAction func onChanged(sender: AnyObject) {
  42. print("Switch changed")
  43. self.userActivity?.becomeCurrent()
  44. self.userActivity?.needsSave = true
  45. }
  46. //MARK: - Handoff
  47. /*
  48. 注意:userActivityWillSave()方法和userActivityWasContinued()这两个方法在当前进行操作的设备A上执行;
  49. restoreUserActivityState()方法在打开另一个设备B上执行;
  50. */
  51. //把当前的数据存储到字典中;
  52. func userActivityWillSave(userActivity: NSUserActivity) {
  53. print("ViewController userActivityWillSave")
  54. str = textField.text
  55. isOn = switchButton.on ? "on" : "off"
  56. let items = ["text" : str,"switch" : isOn]
  57. userActivity.addUserInfoEntriesFromDictionary(items)
  58. print("userActivityWillSave:\(str),  \(isOn)")
  59. }
  60. func userActivityWasContinued(userActivity: NSUserActivity) {
  61. print("ViewController userActivityWasContinued")
  62. //
  63. //    let dictionary:NSDictionary = (userActivity.userInfo)!
  64. //    let textForKey = dictionary.objectForKey("text") as! String
  65. //    let switchForKey = dictionary.objectForKey("switch") as! String
  66. //    print("text = \(textForKey),switch = \(switchForKey)")
  67. //
  68. }
  69. //从字典中读出数据;
  70. override func restoreUserActivityState(activity: NSUserActivity) {
  71. print("ViewCOntroller restoreUserActivityState")
  72. let dictionary:NSDictionary = (activity.userInfo)!
  73. let textForKey = dictionary.objectForKey("text") as! String
  74. let switchForKey = dictionary.objectForKey("switch") as! String
  75. print("text = \(textForKey),switch = \(switchForKey)")
  76. self.textField.text = textForKey
  77. if (switchForKey == "on"){
  78. self.switchButton.on = true
  79. print("ononononon")
  80. }else{
  81. self.switchButton.on = false
  82. print("offoffoffoffoff")
  83. }
  84. }
  85. }

(4)运行效果如下:

github主页:https://github.com/chenyufeng1991  。欢迎大家访问!

 

开发基于Handoff的App(Swift)的更多相关文章

  1. IOS开发-基于WebDriverAgent代理服务,实现iOS手机app自动化测试的框架搭建

    导引 iOS自动化测试一直使用的appium,iOS系统升级至10.0 Xcode8.0之后,改用WebDriverAgent代理服务作为server,编写了一套基于WebDriverAgent服务 ...

  2. 【iOS-Android开发对照】 之 APP入口

    [iOS-Android开发对照]之 APP入口 [图片 Android vs iOS] 提纲 对照分析iOS,Android的入口, iOS,Android的界面单元 为什么要有那样的生命周期 继承 ...

  3. 利用C#开发移动跨平台Hybrid App(一):从Native端聊Hybrid的实现

    0x00 前言 前一段时间分别读了两篇博客,分别是叶小钗兄的<浅谈Hybrid技术的设计与实现>以及徐磊哥的<从技术经理的角度算一算,如何可以多快好省的做个app>.受到了很多 ...

  4. 成都app开发:架构一个App需要学会哪些技术呢?

    成都亿合科技小编为您分享: 随着APP应用的流行,越来越多的人想自己学习怎么开发APP应用,那架构一个APP需要学些什么技术呢?首先要了解App都有哪些类型,不同的类型适用于哪些需求,用户可以根据自己 ...

  5. 【转】基于laravel制作APP接口(API)

    这篇文章主要介绍了基于laravel制作APP接口(API)的相关资料,需要的朋友可以参考下 前期准备 前言,为什么做以及要做个啥本人姓小名白,不折不扣编程届小白一名,但是自从大一那会儿接触到编程这件 ...

  6. 《Swift开发指南》国内第一本Swift图书上市了

    <Swift开发指南>国内第一本Swift图书上市了 既<courseId=799262">苹果Swift编程语言开发指南>视频教程地址:courseId=79 ...

  7. 移动跨平台开发框架Ionic开发一个新闻阅读APP

    移动跨平台开发框架Ionic开发一个新闻阅读APP 前言 这是一个系列文章,从环境搭建开始讲解,包括网络数据请求,将持续更新到项目完结.实战开发中遇到的各种问题的解决方案,也都将毫无保留的分享给大家. ...

  8. delphi不同版本字符串类型的演化(要支持基于firemonkey的app调用,字符串最好使用olevariant类型)

    string,DELPHI2009以前的版本string=ansistring,一个字符占一个字节,DELPHI2009及以上版本string=unicodestring,一个字符占二个字节. cha ...

  9. 《Flask Web开发——基于Python的Web应用开发实践》一字一句上机实践(上)

    目录 前言 第1章 安装 第2章 程序的基本结构 第3章 模板 第4章 Web表单 第5章 数据库 第6章 电子邮件 第7章 大型程序的结构   前言 学习Python也有一个半月时间了,学到现在感觉 ...

随机推荐

  1. maven Connection refused: connect

    现象: 本地可以访问错误提示中的地址.但使用maven无法下载jar包. 环境: 浏览器上网需要使用代理 解决方法: 设置成正常代理可以.具体方法可以下载一个代理工具.只要IE配置成能直接访问http ...

  2. 转:Eric Lippert:阅读代码真的很难

    转自:http://blog.jobbole.com/438/ 相关文章 微软资深软件工程师:阅读代码真的很难(第2篇) 阅读优秀代码是提高开发人员修为的一种捷径 学会阅读源代码 如何阅读大型代码库? ...

  3. PKCS #1 RSA Encryption Version 1.5

    PKCS #1  RSA Encryption Version 1.5 在进行RSA运算时需要将源数据D转化为Encryption block(EB).其中pkcs1padding V1.5的填充模式 ...

  4. gevent中如何实现长轮询

    浏览网页时,浏览器会传HTTP 请求到服务器,服务器会根据请求将网页的内容传给浏览器,但是在很多的情况下,使用者会需要看到最新的即时性资讯,例如观看股票市场行情,而在以前只能靠着重新载入网页才能获得最 ...

  5. 如何连接git bash和git hub

    git config --global user.name "Your Real Name" 2 git config --global user.email you@email. ...

  6. mysql spider之拆库无忧

    数据库的三板斧 先上MySQL,之后再上读写分离,然后呢? 后面典型的做法是垂直拆库和水平分表. 一旦数据库拆了之后,代价就来了. 1.事务不能跨库了(少,但是很重要,可以适当改写) 2.相关的关联查 ...

  7. Lecture Notes: Macros

    原论文链接失效,特在这里保存一份 http://www.apl.jhu.edu/~hall/Lisp-Notes/Macros.html Lisp functions take Lisp values ...

  8. 用ildasm/ilasm修改IL代码

    原文地址:http://www.cnblogs.com/dudu/archive/2011/05/17/ildasm_ilasm_il.html 在开发中遇到这样一个场景,需要修改一个dll文件(.N ...

  9. robotframework笔记25

    library文档工具(Libdoc) Libdoc是机器人框架内置的工具生成的关键字的文档 测试库和资源文件的HTML和XML格式. 前 格式适用于人类,后者 骑 和其他 工具. Libdoc显示库 ...

  10. 使用AndroidStudio编译NDK的方法及错误解决方案

    参考资料: [android ndk]macos环境下Android Studio中利用gradle编译jni模块及配置:http://demo.netfoucs.com/ashqal/article ...