有天测试 MM 给我提了一个 Bug: iOS 10上某些 Label 显示为...
好吧, 又到了适配新系统的季节.
先分析原因, 分别在 iOS 9 和 iOS 10 的系统上运行以下代码:
输出结果(左为 iOS9,右为 iOS10):
可见, 在 iOS 10 系统上部分字体宽度更改了, 所以出现 UILabel & UIButton 显示不全的情况. 经过对各种语言 Glyph(字形?字符? 还是 Glyph 吧) 的 对比, 发现仅仅是中文 Glyph 库替换了.
解决办法有几种:
Case 1:
如果使用 UIButton, 可以用 [button sizeToFit] 对 button 的 bounds 进行调整. 当然更改 button 的 bounds 也许会影响页面布局, 这也许不是你想要的, 那么请看 Case 3.
Case 2:
如果只需要适配 iOS10, 且想要和9上一样的布局(好奇怪的感觉~.~), 可以使用
[label setAdjustsFontForContentSizeCategory:YES] 调节字体大小.
Case 3:
如何解决所有控件的宽度溢出? 减少需求宽度, 或增加供应宽度. 由于增加的供应宽度是对于中文 Glyph 个数的线性, 还需要调整 containter 的 frame,并不是我们需要的~
采用减少宽度, 那思路就和 Case 2一样了:'Adjusts Font', 进行 font 的重定向.
创建一个 UIFont 的 category, 进行 Method Swizzling 重定向方法, 对照字体的 map , 对照字体的 map 实现 font 缩放.
file.m代码如下, 可复制.
#import "UIFont+Swizzle.h"
#import <objc/runtime.h>
@implementation