开发基于Handoff的App(Swift)

时间:2025-01-01 11:34:50
        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)运行效果如下:

开发基于Handoff的App(Swift)

开发基于Handoff的App(Swift)

开发基于Handoff的App(Swift)

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