我们先来看一张美工小姐姐提供的蓝湖图。

发现什么了吗?

设计尺寸750X1314是设备(物理)分辨率。其实美工是按照6/6s/7/8标准标注的图。因为6/6s/7/8的缩放因子是@2x,所以750/2X1314/2 == 375X667,就是我们6/6s/7/8手机的逻辑分辨率。

    //UI设计基准px  750×1314 转换为iphone使用的逻辑分辨率值为 375×667

    iphone型号                       尺寸           逻辑分辨率(point)          设备(物理)分辨率(px)         缩放因子           宽/高比

    iphone6/6s/7/8                 4.7                375×667                             750×1314                        @2x                  0.562

    iphone6p/6sp/7p/8p       5.5                414×736                              1242×2208                     @3x                  0.563

    iphoneX/xs/11pro            5.8                 375X812                             1125X2436                     @3x                  0.462

    iphoneXr/11                      6.1                 414×896                             828×1792                       @2x                  0.462

    iphoneXsMac/proMax    6.5                414×896                              1242×2688                    @3x                  0.462

    iphone12/12pro              6.1                  390×884                             1170×2532                     @3x                  0.462

    iphone12proMax           6.7                   428×926                             1284×2778                    @3x                  0.462

等比例缩放

先阅读下代码

//屏幕尺寸
#define LTX_SCREEN_WIDTH             [UIScreen mainScreen].bounds.size.width
#define LTX_SCREEN_HEIGHT            [UIScreen mainScreen].bounds.size.height
//宽高比例
#define LTX_WIDTH_SCALE(width)       (width/375.0)*LTX_SCREEN_WIDTH
#define LTX_HEIGHT_SCALE(height)     (height/667.0)*LTX_SCREEN_HEIGHT
// 是否是刘海屏
#define IS_iPhoneXSeries                 (LTX_SCREEN_HEIGHT >= 780 ? YES : NO)
// 顶部安全区域
#define LTX_SAVEAREA_TOP                 (IS_iPhoneXSeries ? 24.0f : 0.0f)
//状态栏高度
#define LTX_STATUS_HEIGHT            [[UIApplication sharedApplication] statusBarFrame].size.height
// 导航栏高度
#define LTX_NAVBAR_HEIGHT                44.0f
//导航栏+状态栏高度
#define LTX_TOP_HEIGHT               (LTX_STATUS_HEIGHT+44)
//底部安全区域  工具栏底部 距离底部高度
#define LTX_SAFE_BOTTOM              (([[UIScreen mainScreen] bounds].size.height-780) ? 0 : 43)
//tabbar高度
#define LTX_TABBAR_HEIGHT                (IS_iPhoneXSeries ? 83.0f : 49.0f)

//不同屏幕尺寸字体适配
#define LTX_FONTSIZE_SCALE(R)     [UIFont systemFontOfSize:LTX_WIDTH_SCALE(R)]

以375/667为基准,采取等比例缩放。

1,文字

    label.font = LTX_FONTSIZE_SCALE(16);

如果在6/6s/7/8手机上字体大小是16pt,那么在6p/6sp/7p/8p上显示的字体大小就是17.6pt;在X/xs/11pro上显示的字体大小是16pt;在Xr/11/XsMac/proMax 上显示的字体大小就是17.6pt。

2,图片

    self.redView = [[RedView alloc] initWithFrame:CGRectMake(100, 100, LTX_WIDTH_SCALE(86*2), LTX_WIDTH_SCALE(88*2))];
    self.redView.layer.contents = (__bridge id)[UIImage imageNamed:@"2"].CGImage;
    [self.view addSubview:self.redView];

3,间距,使用Masonry自动布局。使用 LTX_WIDTH_SCALE(width) / LTX_HEIGHT_SCALE(height) 比例布局。

最简单的适配方案。

跟新

1.,375X812

// 适配小屏手机
NS_INLINE CGFloat AValueAfterScale(CGFloat value)
{
    if (AUIsPad()) {
        return value;
    }
    
    CGFloat minFactor = MIN([UIScreen mainScreen].bounds.size.width / 375, [UIScreen mainScreen].bounds.size.height / 812);
    return value * minFactor;
}

版权声明:本文为weixin_38934440原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。
原文链接:https://blog.csdn.net/weixin_38934440/article/details/114883319