自从iPhone4把屏幕分辨率提升了之后,苹果给开发者提供了一个point的概念,来取代旧的分辨率的概念。 
它们假定屏幕上的定位和大小是用point来描述的,而iPhone3和iPhone4的屏幕是由相同的point组成的,都是320pt*480pt,也就是说,对于旧的iPhone,1pt = 1px,而对于retina屏幕,1pt = 2px。 
而在代码里面,所有的px的概念都被改成了pt的概念,也就是说,在编程的时候,一个物体对于普通屏幕的坐标跟其对于retina屏幕是一样的(也就是说,以前为普通屏幕所写的代码,可以不需要修改一句代码就可以运行在retina屏幕上)。

然后高清的兼容除了位置和大小的变动之外,app里面图片的大小也变动了。 
目前苹果的策略是,允许开发者提供两套图,一套给普通屏幕准备,而另一套给retina屏幕准备,使用文件的名称来区分,比如a.png是普通屏幕的,则a@2x.png则是给retina屏幕的, 
但app运行时需要调用图片的时候,系统将自动搜索@2x后缀的图片,如果没有,则自动试用a.png。

所以说,苹果并非没有这方面(修改设备分辨率)的经验,而就第一次而言,苹果使用的策略十分简单,因为并没有对开发者造成太大的困扰。

而且就目前iPhone4的屏幕分辨率而言,我相信已经能够满足用户足够多的时间,而下一次对于显示的改进则不在于分辨率了。

iPad则有可能有分辨率的提升,但仍然可以沿用当前的策略。

iPhone4设计的360*480,(@2X,实际分辨率640*960)

添加一个Default-568h@2x.png, 就自动支持iPhone 5长屏幕分辨率(320*568), 而xib不用调整, 也会同样自动适应长分辨率.
移植起来还比较方便!

在Launch Images -> Retina(4-inch) 里选择一张 640*1136 的图片为Default-568h@2x.png,再启动程序

//得到屏幕的宽和高  
CGRect rect=[[UIScreen mainScreen] bounds];       
CGSize size = rect.size;  
int screenWidth = size.width;  
int screenHeight = size.height;

2012-09-21 09:57
NSLayoutConstraint Class Reference

Inherits from    
NSObject
Conforms to    
NSObject (NSObject)
Framework    
/System/Library/Frameworks/AppKit.framework
Availability    
Available in iOS 6.0 and later.
Companion guide    
Cocoa Auto Layout Guide
Declared in    
NSLayoutConstraint.h

iPhone5的新分辨率着实啃爹了一把,刚下完xcode4.5想玩玩iphone5的长屏幕效果,顺便研究下怎么去兼容它。

app在ios6的4inch的显示效果。。果然传说中的上下两个小黑边~放个adbanner还不错。。。

        

继续,开始修复黑边~~这一步只要在config里多加一张4inch的launch图片就能搞定

这样如下图,让layout上对齐,并且actionSheet显示正常~

最后用宏替换掉写死的460,

C代码  
  1. #define ScreenHeight [[UIScreen mainScreen] bounds].size.height
  2. #define ScreenWidth [[UIScreen mainScreen] bounds].size.width
  3. #define StateBarHeight 20
  4. #define MainHeight (ScreenHeight - StateBarHeight)
  5. #define MainWidth ScreenWidth

挑了张比较简单的view改了下,效果还不错啦~

搞完洗洗睡了~~

【更新】有同学和我反映xib没法搞

其实apple早就给我们想好了用autolayout就能解决,但是这种方案的兼容性并不好,这里就不叙述了

我的做法是在m文件里映射那个需要定位的控件IBOutlet

C代码  
  1. - (void)viewDidLoad
  2. {
  3. [super viewDidLoad];
  4. //for ip5
  5. CGRect rect = button.frame;
  6. rect.origin.y = MainHeight - rect.size.height;
  7. button.frame = rect;
  8. }

在load方法里植入兼容代码就可以了。

另外有时候外层view的大小是不可见的,导致在下部的控件没有办法被用户触发,这是因为view的frame是直接由xib赋值,ip4一般直接赋值460,所以需要对frame进行重置

另外如果要直接兼容先前的xib可以这样在class 的 viewDidLoad里写:

C代码  
  1. //for ip5
  2. CGRect mainRect = self.view.frame;
  3. mainRect.size.height = ScreenHeight;
  4. self.view.frame = mainRect;

另外可能需要判断ip5的宏定义,我这里提供一个:

C代码  
  1. #define isIPhone5 ([UIScreen instancesRespondToSelector:@selector(currentMode)] ? CGSizeEqualToSize(CGSizeMake(640, 1136), [[UIScreen mainScreen] currentMode].size) : NO)

这样基本能解决xib来init带来的兼容性问题。

参考:

http://www.zhihu.com/question/19864772

http://leyteris.iteye.com/blog/1682624

ios屏幕兼容 phone4和iphone5的屏幕尺寸不同,在程序中兼容相关推荐

  1. 处理iPhone5加长屏幕的4种方法

    iPhone5拥有加长的屏幕:相同的宽,但高度上却增加了176个像素. 大多数的用户能够接受这多出来的空间,但是对于应用开发者来说如何创建一个能够适用于不能类型的iPhone屏幕的背景就是个挑战了. ...

  2. 常用各个手机屏幕分辨率归纳。iphone5/iphone7/iphone7 plus/iphoneX/Android 分辨率大小归纳

    ios,android 常用手机屏幕分辨率归纳. 针对IOS,Android 手机分辨率大小.屏幕尺寸.开发尺寸的参考. 在实际页面的开发过程,往往显示屏幕的宽度换算为像素尺寸的1/2. IOS: A ...

  3. iOS 12测评:一改iOS 11华而不实 流畅度大幅提升限制屏幕时间防沉迷

    iOS 12于今年6月在WWDC上宣布后,已经为开发人员和普通大众经过数月的测试后正式推出.苹果的iOS更新,它将适配各种iPhone和iPad设备,从今年最新的iPhone XS一直追溯到2013年 ...

  4. 移动设备应用程序中支持多个屏幕大小和 DPI 值

    支持多个屏幕大小和 DPI 值的指导原则 要部署独立于平台的应用程序,应了解不同的输出设备.设备可以具有不同的屏幕大小或分辨率以及不同的 DPI 值或密度. Flex 工程师 Jason SJ 在他的 ...

  5. win10一按右键就闪屏_Win10屏幕闪烁是什么原因 Win10屏幕闪烁现象的原因及解决办法...

    部分使用Win10系统的用户可能会遇到过屏幕出现闪烁的问题,这通常是因为运行了不兼容的软件或者显卡驱动出现了故障.那么Win10屏幕闪烁是什么原因呢?以下是Win10屏幕闪烁解决办法. 检查任务管理器 ...

  6. android 获取屏幕编号,怎样获取Android手机屏幕的大小(分辨率、密度)

    getWindow().setFlags(WindowManager.LayoutParams.FLAG_FULLSCREEN, WindowManager.LayoutParams.FLAG_FUL ...

  7. 忘记屏幕时间! 通过这些替代方案跟踪您在macOS Catalina中的应用使用情况

    sergey causelove/Shutterstock 谢尔盖·原因爱/快门 The Screen Time feature first appeared in iOS 12 to help yo ...

  8. android多屏幕适配资源生成,android – 多屏幕适配相关

    1.基本概念 屏幕大小(screen size) – 屏幕的实际大小,用屏幕对角线长度来衡量(比如3.4寸,3.8寸).android把屏幕分为以下4种:small,normal,large,extr ...

  9. cocos2d 屏幕適配_cocos2d-x 2.x屏幕适配基础

    一开始我就忽略了屏幕适配的问题,现在才发现它是多么的重要.通过实践才领悟了其基础概念,而屏幕适配的策略是建立在其上的,有很多,但我还没有认真研究.这里仅把自己对屏幕适配基础知识进行一个梳理. 关于屏幕 ...

最新文章

  1. Python基础学习!容器:列表,元组,字典与集合!(1)
  2. MFC中实现模态对话框的结构与原理
  3. vue热更新无法关闭_vue-cli3热更新失效
  4. IOS libxml/tree.h file not found 解决方案
  5. SwiftUI 开源项目 - ZYSwiftUIFrame 自带服务端的完整示例项目(更新中...)
  6. Confluence 6 使用电子邮件可见
  7. java structs_Java之Structs框架初探
  8. 计算机常用单词 pdf,关于计算机的常用词汇.pdf
  9. 学会Python有哪些可以做的兼职?所有途径全在这里了...
  10. PS对图片的基本处理
  11. C 宇恒棋 大力猜想 神奇数学
  12. c语言代码大全表解释_C语言常用错误代码释义大全,值得收藏!
  13. 金融day03 —— 银行支付结算、银行资产业务
  14. 【菜鸟进阶之路】P2141 珠心算测验 - 洛谷
  15. 联盟优势电信服务器,中国电信积极推进OLA联盟行业技术标准制定 加速智能家居互联互通...
  16. 大学计算机未来五年规划,大学生活评价与未来五年计划(8页)-原创力文档
  17. 蓝桥杯官网 试题 PREV-240 历届真题 答疑【第十一届】【决赛】【研究生组】【C++】【C】【Java】【Python】四种解法
  18. opengl Bresenham直线算法
  19. 安装open_clip时提示错误 请求大佬们帮助
  20. 测试计划包括哪些主要步骤和信息?

热门文章

  1. WebService三大基本元素 SOAP WSDL UDDI
  2. 今日微信群早报 精选12条新闻简讯3月23日
  3. 【大话GSM】WCDMA和LTE在提供数据和语音业务上的差异
  4. 软件测试自学日语app,免费学日语的软件哪个好?零基础学习日语的app评测推荐...
  5. 12连跳后富士康应停产整顿
  6. 微信公众号,关联网页支付功能(公众号支付)的实现
  7. 下载网盘文件失败的解决方法
  8. php动态网站开发实训项目,PHP动态网站开发项目实战
  9. Win10搜索框无法使用怎么办?Win10搜索栏用不了的解决办法
  10. uniapp 微信小程序,开启定位权限,permission : scope.userLocation