字体大小适配屏幕的方法

新建一个UIButton的类别 重写 load 方法 利用OC的运行时 对所有的Button、Label作处理(一般有文字的大部分是 Button、Label)
代码如下
UIButton+MyFont.h

#import <UIKit/UIKit.h>
#import <objc/runtime.h>

/**
 *  按钮
 */
@interface UIButton (myFont)

@end

/**
 *  Label
 */
@interface UILabel (myFont)

@end

UIButton+MyFont.m

#import "UIButton+MyFont.h"

//不同设备的屏幕比例(当然倍数可以自己控制)
#define SizeScale ((IPHONE_HEIGHT > 568) ? IPHONE_HEIGHT/568 : 1)

@implementation UIButton (myFont)

+ (void)load{
    Method imp = class_getInstanceMethod([self class], @selector(initWithCoder:));
    Method myImp = class_getInstanceMethod([self class], @selector(myInitWithCoder:));
    method_exchangeImplementations(imp, myImp);
}

- (id)myInitWithCoder:(NSCoder*)aDecode{
    [self myInitWithCoder:aDecode];
    if (self) {
        //部分不像改变字体的 把tag值设置成333跳过
        if(self.titleLabel.tag != 333){
            CGFloat fontSize = self.titleLabel.font.pointSize;
            self.titleLabel.font = [UIFont systemFontOfSize:fontSize*SizeScale];
        }
    }
    return self;
}


@end

@implementation UILabel (myFont)

+ (void)load{
    Method imp = class_getInstanceMethod([self class], @selector(initWithCoder:));
    Method myImp = class_getInstanceMethod([self class], @selector(myInitWithCoder:));
    method_exchangeImplementations(imp, myImp);
}

- (id)myInitWithCoder:(NSCoder*)aDecode{
    [self myInitWithCoder:aDecode];
    if (self) {
        //部分不像改变字体的 把tag值设置成333跳过
        if(self.tag != 333){
            CGFloat fontSize = self.font.pointSize;
            self.font = [UIFont systemFontOfSize:fontSize*SizeScale];
        }
    }
    return self;
}

@end

文/门前有棵葡萄树(简书作者)
原文链接:http://www.jianshu.com/p/5815e81abb52
著作权归作者所有,转载请联系作者获得授权,并标注“简书作者”。

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
要实现字体大小屏幕自动适配,你可以使用JavaScript中的`window.innerWidth`属性来获取屏幕的宽度,然后根据屏幕宽度来计算和设置字体大小。下面是一个示例代码: ```html <!DOCTYPE html> <html> <head> <style> #myText { font-size: 16px; /* 初始字体大小 */ } </style> </head> <body> <div id="myText">Hello World!</div> <script> var textElement = document.getElementById("myText"); function adjustFontSize() { var screenWidth = window.innerWidth; // 获取屏幕宽度 var fontSize = screenWidth / 20; // 计算字体大小,这里假设每20像素宽度对应1像素的字体大小 textElement.style.fontSize = fontSize + "px"; // 设置字体大小 } // 页面加载时和窗口尺寸改变时都调用此函数适配字体大小 window.addEventListener("load", adjustFontSize); window.addEventListener("resize", adjustFontSize); </script> </body> </html> ``` 在上面的示例中,我们定义了一个`adjustFontSize`函数,该函数根据屏幕宽度计算字体大小,并将其应用于文本元素。`window.addEventListener`方法用于在页面加载和窗口尺寸改变时调用此函数适配字体大小。 在这个示例中,我们假设每20像素宽度对应1像素的字体大小,你可以根据需要调整这个比例来适应你的需求。 注意:在使用`window.innerWidth`之前,确保文档已经加载完毕,否则获取到的屏幕宽度可能不准确。因此,我们在`window.addEventListener("load", adjustFontSize)`中调用`adjustFontSize`函数来保证文档加载完毕后再进行字体大小适配

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值