iOS Xib 适配字体

热门标签

特别声明:文章多为网络转载,资源使用一般不提供任何帮助,特殊资源除外,如有侵权请联系!

很多时候我们会使用Xib开发界面,如果是Xib创建的,我们再去每个控件都重新都设置一遍字体,岂不是无端增加工作量,最好的办法是在XIB里面设置字体大小后自动进行等比缩放。

我的思路是这样的,通过Xib创建的视图在初始化的时候都会调用awakeFromNib方法,通过交换方法,实现为Xib适配字体。

+ (void)load {
    Method swizeeMethod = class_getInstanceMethod([UILabel class], @selector(d_awakeFromNib));
    Method originalMethod = class_getInstanceMethod([UILabel class], @selector(awakeFromNib));
    
    if (!class_addMethod([UILabel class], @selector(awakeFromNib), method_getImplementation(swizeeMethod), method_getTypeEncoding(swizeeMethod))) {
        
        method_exchangeImplementations(originalMethod,swizeeMethod);
    } else {
        class_replaceMethod(self, @selector(d_awakeFromNib), method_getImplementation(originalMethod), method_getTypeEncoding(originalMethod));
    }
}
- (void)d_awakeFromNib {
    self.font = [UIFont fontWithDescriptor:self.font.fontDescriptor size:self.font.pointSize * [self getScaleFontSize]];
    
    [self d_awakeFromNib];
}
+ (CGFloat)getScaleFontSize{
    // 375 是设计师一般都习惯以iphone6设计UI
    CGFloat width = [[UIScreen mainScreen] currentMode].size.width;
  // 1242是iPhone XS Max的宽度,如果不加限制在iPad字体惨不忍睹,大于iPhone XS Max 的都适配1.5倍
    if (width <= 1242) {
         return  [UIScreen mainScreen].bounds.size.width/375;
    }
    else{
        return 1.5;
    }
}

demo

标签:

未经允许不得转载:作者:SheaYang, 转载或复制请以 超链接形式 并注明出处 技术狗|博客
原文地址:《iOS Xib 适配字体》 发布于2019-12-04

分享到:
赞(0)

评论 抢沙发

6 + 5 =


iOS Xib 适配字体

长按图片转发给朋友

Vieu4.0主题
专业打造轻量级个人企业风格博客主题!专注于前端开发,全站响应式布局自适应模板。

登录

忘记密码 ?

您也可以使用第三方帐号快捷登录

Q Q 登 录
微 博 登 录