2019-01-18 swiftTheme 换肤的一个小缺陷:某种条件下,在cell被选中状态下:给cell换肤会失败。...

swiftTheme 换肤使用了通知,运行时绑定,动态执行的方法原理,但是我在使用过程中发现了一个问题:
场景如下:
uitableViewCell 背景色设置
通过设置contentView背景色来 设置默认的背景色
设置selectedBackgroundView来 设置选中时背景色。(还可以selected代理方法设置contentView背景色的方法来设置背景色)

bug场景:当cell001 选中时,执行换肤操作,结果看起来是全部都换肤了。
(假设,默认色是白色,选中是金色。换肤后默认色是黑色)

但是选中的cell001从金色变成了“未选中”的黑色(假的未选中,实际上是选中状态)。再次点击这个cell,你会发现这个cell的默认背景色竟然变成了白色!!!!!
颜色顺序是:金色---》换肤后为黑色----》点击后,变成白色

诡异之处,换肤通知的确执行了,但是content的颜色怎么还是白色呢?
即:swiftTheme对选中状态的cell 无法实现换肤的功能。

问题剖析:
使用xcode自带工具查看图层。你就会发现问题所在:
默认状态: 只有contentView 颜色:白色
选中状态:selectedBackgroundView 金色 contentView 白色,透明度为0
选中后换肤:selectedBackgroundView 金色 contentView 黑色,透明度为1
选中后换肤再点击:只有contentView 颜色:白色
这样流程就很清晰了:
contentView的颜色有两种状态:
在选中时,会被系统改变透明度,取消选中时,透明度还原,回到选中之前颜色。
问题的关键就在这里:系统记录了cell选中前contentView的颜色。

解决方案:
记录下当前选中cell的索引。
换肤后,在通知方法里,更新(reload)被选中的cell,让他们回到未选中状态,再次执行换肤操作,最后再次选中这些cell。
选中——还原——换肤——再选中
完美解决。

得出结论:选中状态下:给cell换肤会失败。

第二种方案:使用selected代理方法设置contentView背景色的方法来设置背景色
这个方案应该可以避开这种情况。

猜你喜欢

转载自blog.csdn.net/weixin_34261739/article/details/87104421