问题
iOS用户更新至iOS 11之后,widget展开/折叠按钮的点击率明显增大,加上用户的反馈,发现在iOS 10上正常显示的widget在iOS 11上会出现展开/折叠状态错乱的情况
如下图所示
京东也存在类似问题
查找问题
- 经过试验,当我们在对widget界面调试的时候,在viewDidLoad、viewWillAppear等生命周期内的断点并不会阻塞widget界面的滑动,说明这可能并未在主线程进行操作,这即违背了刷新UI要在主线程的规律
- 之前widgetLargestAvailableDisplayMode的设置是在viewWillAppear里执行的,这有可能会改变在viewDidLoad内经过计算数据已设置完成的view展示状态,导致出现问题
解决方法
- 在涉及更新UI状态的时候,确保回到主线程进行刷新
- 对于widgetLargestAvailableDisplayMode的状态移到viewDidLoad执行
类似这样:
- (void)viewDidLoad{
[super viewDidLoad];
// Do any additional setup after loading the view from its nib.
//
if([[UIDevice currentDevice].systemVersion floatValue] >= 10){
self.extensionContext.widgetLargestAvailableDisplayMode = NCWidgetDisplayModeExpanded;
}
}
总结
这次修复bug,除了解决方法以外,感觉有些东西不能盲目的去网上copy,对于设置widget状态,网上几乎所有demo都是写在viewWillAppear里,其实每次打开widget界面都会执行viewDidLoad方法,写在viewWillAppear里甚至有可能会强制又改变了设置好的frame,导致出现问题。