回顾今日控件在过去几年中重要性如何得到提升是一件很有趣的事。今日控件首次在 iOS 8 出现,当时并没有受到高度欢迎,并且在通知中心与错过的通知结合在一起。然而,在 iOS 10,今日控件彻底的改变了,完全接管主屏幕的左滑项,这过去常常被用作「滑动解锁」。在外观方面,该控件也有相当大的转变,从一个深色主题转变为一个珍珠白主题。
不幸的是,对于开发者,如果你和我的团队一样还不能完全放弃对 iOS 10 以下的支持,那么你不得不解决完美支持两种外观风格,和一些其他在初看时不明显的问题。我最近参加了这个 QuickBooks Self-Employed 今日控件的改造-以下是一些注意事项:
支持两种主题
iOS 9 的今日控件
iOS 10 的今日控件
让我们从明显的问题开始解决。你可以构造两个不同的界面,分别用于 iOS 10 以下的版本和 iOS 10+ 的版本,或者确认一个单独的界面能够同时兼容深色和亮色背景。最后,我们通过构建一个界面来解决这个问题,但是对于我们视图的元素最终显示亮色还是深色的本文和背景色,这取决于在什么版本的 iOS 上运行。我们也确认了所有图片资源和有色文本在两种背景下都有良好的效果。修改图片的着色(tint color)在这被证明是有效的。
//Swift
var image = UIImage(named: "imageName");
image = image?.withRenderingMode(UIImageRenderingMode.alwaysTemplate)
let imageView = UIImageView(image: image)
imageView.tintColor = UIColor.blue
//Objective-C
UIImage *image = [UIImage imageNamed:@"imageName"];
image = [image imageWithRenderingMode:UIImageRenderingModeAlwaysTemplate];
UIImageView *imageView = [[UIImageView alloc] initWithImage:image];
imageView.tintColor = [UIColor blueColor];
居中控件
这有一个不怎么明显的问题 - iOS 9 的今日控件有轻微的居中偏移。如果你注意上图,你可以看到上面的 UITableView
并不是水平居中于他的空间。如果你想要为 iOS 9 的今日控件做细微的调整,我建议设置边距(margin),允许你能够使用全部被分配的空间宽度,这与 iOS 10 上的默认保持一致。
//Swift
func widgetMarginInsets(forProposedMarginInsets defaultMarginInsets: UIEdgeInsets) -> UIEdgeInsets {
return UIEdgeInsetsMake(0,0,0,0);
}
//Objective-C
- (UIEdgeInsets)widgetMarginInsetsForProposedMarginInsets:(UIEdgeInsets)defaultMarginInsets {
//centers widget for iOS 9
return UIEdgeInsetsMake(0,0,0,0);
}
注意:widgetMarginInsetsForProposedMarginInsets
是技术弃用的并且在 iOS 10 及以上的版本不会被调用。
在扩展模式中功能失效
紧密模式
扩展模式
iOS 10 增加了一个可选的扩展模式,这可以用来增加额外的功能和控件的使用面积。这是超级有用的,比如高级用户功能或是在用户有一些不想一直显示在主屏幕的东西(例如私人或财产信息)的情况下。你可以在 ViewDidLoad 中通过一行代码开启扩展模式:
//Swift
self.extensionContext?.widgetLargestAvailableDisplayMode = NCWidgetDisplayMode.expanded
//Objective-C
self.extensionContext.widgetLargestAvailableDisplayMode = NCWidgetDisplayModeExpanded;
然而,在 iOS 9 上这基本会破坏你的扩展,所以你实际上需要封装一下来确保仅在支持扩展模式时被设置。
//Swift
let extensionContext = NSExtensionContext()
if #available(iOS 10.0, *) {
extensionContext.widgetLargestAvailableDisplayMode = NCWidgetDisplayMode.expanded
}
//Objective-C
if ([self.extensionContext respondsToSelector:@selector(setWidgetLargestAvailableDisplayMode:)]) {
self.extensionContext.widgetLargestAvailableDisplayMode = NCWidgetDisplayModeExpanded;
}
在扩展模式下你还需要考虑一个问题,那就是如果你不合理地设置控件的高度,任何仅在扩展模式(超过 110 px)下显示的东西将会在 iOS 9 及以下的版本被切掉。为了解决这个问题,你需要确认你设置了控件的 preferredContentSize 高度来让它保留那些超过 110 px 的内容。谢谢 Greg Gardner 指出这点!