当前位置:   article > 正文

iOS开发 -手机屏幕适配的简单使用_ios 屏幕适配

ios 屏幕适配

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

发现什么了吗?

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

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

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

    iphone6/6s/7/8                 4.7                375x667                             750x1314                        @2x                  0.562

    iphone6p/6sp/7p/8p       5.5                414x736                              1242x2208                     @3x                  0.563

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

    iphoneXr/11                      6.1                 414x896                             828x1792                       @2x                  0.462

    iphoneXsMac/proMax    6.5                414x896                              1242x2688                    @3x                  0.462

    iphone12/12pro              6.1                  390x884                             1170x2532                     @3x                  0.462

    iphone12proMax           6.7                   428x926                             1284x2778                    @3x                  0.462

等比例缩放

先阅读下代码

  1. //屏幕尺寸
  2. #define LTX_SCREEN_WIDTH [UIScreen mainScreen].bounds.size.width
  3. #define LTX_SCREEN_HEIGHT [UIScreen mainScreen].bounds.size.height
  4. //宽高比例
  5. #define LTX_WIDTH_SCALE(width) (width/375.0)*LTX_SCREEN_WIDTH
  6. #define LTX_HEIGHT_SCALE(height) (height/667.0)*LTX_SCREEN_HEIGHT
  7. // 是否是刘海屏
  8. #define IS_iPhoneXSeries (LTX_SCREEN_HEIGHT >= 780 ? YES : NO)
  9. // 顶部安全区域
  10. #define LTX_SAVEAREA_TOP (IS_iPhoneXSeries ? 24.0f : 0.0f)
  11. //状态栏高度
  12. #define LTX_STATUS_HEIGHT [[UIApplication sharedApplication] statusBarFrame].size.height
  13. // 导航栏高度
  14. #define LTX_NAVBAR_HEIGHT 44.0f
  15. //导航栏+状态栏高度
  16. #define LTX_TOP_HEIGHT (LTX_STATUS_HEIGHT+44)
  17. //底部安全区域 工具栏底部 距离底部高度
  18. #define LTX_SAFE_BOTTOM (([[UIScreen mainScreen] bounds].size.height-780) ? 0 : 43)
  19. //tabbar高度
  20. #define LTX_TABBAR_HEIGHT (IS_iPhoneXSeries ? 83.0f : 49.0f)
  21. //不同屏幕尺寸字体适配
  22. #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,图片

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

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

最简单的适配方案。

跟新

1.,375X812

  1. // 适配小屏手机
  2. NS_INLINE CGFloat AValueAfterScale(CGFloat value)
  3. {
  4. if (AUIsPad()) {
  5. return value;
  6. }
  7. CGFloat minFactor = MIN([UIScreen mainScreen].bounds.size.width / 375, [UIScreen mainScreen].bounds.size.height / 812);
  8. return value * minFactor;
  9. }

声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/小小林熬夜学编程/article/detail/269374
推荐阅读
相关标签
  

闽ICP备14008679号