对于从零开发一个Widget应用,本文主要介绍如下几点:
1.为现已有工程添加Widget;
2.绘制UI;
3.App间跳转;
4.数据共享的方式;
1.为现有工程添加Widget
新建工程
选择`Today Extension`,确认,为工程添加Widget成功.
2.绘制UI
和普通控制器一样,正常的绘制UI即可,默认工程使用SB构建,自己可以选用代码构建,需要注意的是,要删除plist中相关的代码.
3.App间跳转
app跳转可以通过URI方式打开和传值.
extensionContext?.open(URL(string: "mainApp://controller?type=1")!,completionHandler: { (result) in print(result) }) |
4.数据共享的方式
扩展程序一般都不是脱离宿主程序单独运行的,难免需要和宿主程序进行数据交互。通过App Groups提供的同一group内app共同读写区域,可以用NSUserDefaults和NSFileManager两种方式实现extension和containing app之间的数据共享。
使用App Groups需要在主程序和widget程序中分别打开App Groups选项,保证两个地方选择的groups相同,如下:
UserDefaults方式:
//写入数据 let userDefaults = UserDefaults(suiteName: "group.com.walden.Widget-Demo") userDefaults?.set("abcdefg",forKey: "widget") userDefaults?.synchronize() //读取数据 let userDefaults = UserDefaults(suiteName: "group.com.walden.Widget-Demo") let str = userDefaults?.value(forKey: "widget") as? String
FileManager方式:
//写入数据 var containerURL = FileManager.default.containerURL(forSecurityApplicationGroupIdentifier: "group.com.walden.Widget-Demo") containerURL = containerURL?.appendingPathComponent("Library/Caches/widget") let value = "abcdefg" try? value.write(to: containerURL!,atomically: true,encoding: .utf8) //读取数据 var containerURL = FileManager.default.containerURL(forSecurityApplicationGroupIdentifier: "group.com.walden.Widget-Demo") containerURL = containerURL?.appendingPathComponent("Library/Caches/widget") let v = String(contentsOf: containerURL!,encoding: .utf8)