最新的iPhone 各种机型尺寸信息列表(含iPhone 7/8、iPhoneX、iPhone XR、iPhone XS Max)

1. iPhone 各种机型尺寸信息列表入下表:

 

机型尺寸逻辑缩放因子
(UIKit Scale factor)
实际缩放因子
(Native Scale factor)
屏幕宽高屏幕分辨率
3GS3.5寸1.01.0320x480320x480
4(S)3.5寸2.02.0320x480640x960
5(C)/5(S)/SE4寸2.02.0320x568640x1136
6(S)/7/84.7寸2.02.0375x667750x1334
6(S)+/7+/8+5.5寸3.02.608414x7361080x1920
X/XS5.8寸3.03.0375x8121125x2436
XR6.1寸2.02.0414×896828 x1792
XS Max6.5寸3.03.0414×8961242x2688

 

需要注意的地方是,6(S)+/7+/8+的时候,实际的缩放因子并不等于逻辑上的缩放因子。所以,他的屏幕分辨率是1080x1920而不是1242x2208。

上述数据,可以通过代码获得。获取逻辑缩放因子、逻辑屏幕宽度;实际缩放/物理因子、实际/物理屏幕宽度的方式:

//逻辑缩放因子
[UIScreen mainScreen].scale

//逻辑屏幕宽度
[UIScreen mainScreen].bounds


//实际/物理缩放因子
[UIScreen mainScreen].nativeScale

//实际/物理屏幕宽度
[UIScreen mainScreen].nativeBounds

        iOS里面对于缩放因子有2个不同的概念。一个是其实际的缩放因子(Native Scale factor),一个是UIKit上所表示的逻辑缩放因子(UIKit Scale factor)。UIKit Scale factor和Native Scale factor不相等的时候,系统会先使用逻辑上的factor(即UIKit Scale factor)来渲染,渲染之后再把结果进行缩放,使之符合Native Scale factor下渲染的样子。在一些UI渲染计算量大的应用(如游戏),这类多余的渲染是很耗费资源的,应该在渲染这类UI的时候指定使用Native Scale factor来做渲染。MetalKit(新的系统接口,支持GPU加速3D绘图的API。)里面有这个用法。详情见官网

参考:《为什么 iPhone 6 Plus 要将 3x 渲染的 2208x1242 分辨率缩小到 1080p 屏幕上?》

2. 手机机型区分

       由于现在iPhone 6、iPhone 7、iPhone 8屏幕尺寸一样,他们的Plus版也是一样的。所以按照以前的以屏幕高度来区分的方法,结果会有可能重叠。

      (1)以屏幕高度的不同来区分

 

#define iPhone_4 ((int)[UIScreen mainScreen].bounds.size.height == 480)

 

#define iPhone_5 ((int)[UIScreen mainScreen].bounds.size.height == 568)

 

#define iPhone_6 ((int)[UIScreen mainScreen].bounds.size.height == 667) //6、7、8

 

#define iPhone_6p ((int)[UIScreen mainScreen].bounds.size.height ==736)//6p、7p、8p

 

#define iPhone_X  ((int)[UIScreen mainScreen].bounds.size.height ==812)

  

          

 

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值