版权:张英堂

欢迎转载,转载请注明出处。

做的项目很多,一到适配的时候头就大了,IOS6,7的适配,屏幕的适配,当然还有下一步要出4.7屏幕,也要做适配。。。。悲剧的移动端的人员。

  怎么做一个通用的适配呢?

   对于IOS6, 7要做的适配最大的就是风格的改变,当然这个就需要设计师来搞定了。然后就是原点的改变。 IOS7 的原点是从屏幕左上角开始。不论是否添加了navigation。

   而IOS6 的原点确实计算状态栏,navigation的高度,也就是20 + 44, 找到问题了,好了,开始解决,上代码!

      这是我写的两个VC的基类,一个是带navigation的,一个是不带的。

          代码很简单:这个是带navigation的,也就是高度 - 64,以及原点要从20 + 44 开始算。 (注:以下都以IOS7 为标准,向下兼容IOS6 的做法)

同理,不带navigation的,只需要 - 20 就好了。

这是最简单的适配。这时候有同学说了,我要使用ib文件怎么做呢,莫着急,先来分析一下,有什么办法。

    1.最简单的,就是做两套xib,根据版本来确定。哈哈,貌似没人愿意这么做吧。费时费力,不讨好。

    2.利用苹果自带的来使用。开始上图了。(以一个简单的登录页面讲解。)

        首先咱么先打开,看一下IB包含的属性

这时候注意一下红色区域

这里是适配的重点, 这时候点一下  view as , 包含了两个选项,一个是7.0 later, 一个是6.1later。 这两个就是分别在两个版本下的预览,为了看一下效果的,可以点一下看看,是否转化了。

有细心的同学发现了,那个auto layout 我给取消了,为什么要取消呢,这就是适配的重点。

点击我红色标示的地方,发现了吗,和你的有区别吧。那个自动排版是默认的,必须取消才能做继续的,继续咱们下一步,

看到这一块,autosizing, 这个就是为了以后的适配做准备,这里外圈,有上下左右四个,也就是离边框的距离,可以自己选择,一边要看自己的界面,如果这个view在偏上,我就会选择上,左,右而不会选择下,具体为什么,这个需要自己理解,不好说的。如果偏下的view就选择下,左,右,当然你也可以左右,只选择一个。这样就做好4.0, 3.5 屏幕的适配。

不过苹果也给好了,直接用ib文件做 版本适配。

下面就以我登陆界面的 返回 按钮来讲解。

         --- 

后边的图是右边的属性栏,这里就表明了  IOS 6/7 deltas 这就是适配了。这里的标准是 前面介绍的,在  view as 的视图,一般我都是 IOS7 ,做IOS6 的适配,也分析过,他们最大的区别就是远点的改变,那么在我这个视图中,没有navigation,所以这里,只需要给 Y坐标 - 20个 像素就好了,如果带了navigation就需要 - 64个像素了。也可以以整个页面来做这里的数值,

例如:

      --------   

这样就不用每一个空间都去更改数值了。好了,看效果,以返回键为准:

在IOS7 的情况下,是正好的,上边留下了一个状态栏,那么看咱们设置之后的效果如何

好,到此完成,达到咱们的效果了。

对于屏幕大小的适配,如果用代码的情况下,可以参照刚才步骤中的,分为上下左右。如果一个控件在偏上的位置,就从上边开始算,如果在偏下的位置,就要从下部开始计算,用屏幕的高度 - 离下边框的距离。

文章到此结束,欢迎经常参观,每周一次更新。

版权:张英堂。

< IOS > IOS适配,简单的分析解决一下的更多相关文章

  1. iOS开发——适配篇&App适配简单概括

    App适配简单概括 1:适配:适应.兼容各种不同的情况 系统适配 针对不同版本的操作系统进行适配 屏幕适配 针对不同大小的屏幕尺寸进行适配 在用户眼中 屏幕是由无数个像素组成的 像素越多,屏幕越清晰 ...

  2. 使用Analyze 和Instruments-Leaks分析解决iOS内存泄露

    版权声明:本文为博主原创文章,未经博主允许不得转载. 使用Analyze和Instruments-Leaks分析解决iOS内存泄露   实验的开发环境:Xcode 7   一.使用Product-An ...

  3. iOS 10 适配 ATS(app支持https通过App Store审核)

    iOS 10 适配 ATS 一. HTTPS 其实HTTPS从最终的数据解析的角度,与HTTP没有任何的区别,HTTPS就是将HTTP协议数据包放到SSL/TSL层加密后,在TCP/IP层组成IP数据 ...

  4. iOS屏幕适配

    ## iOS屏幕适配 ### iOS屏幕适配发展史 1> iPhone4以前(没有iPad) * 不需要屏幕适配 2> iPad.iPhone5等设备出现 * 需要做横竖屏适配 * aut ...

  5. iOS:界面适配--iPhone不同机型适配 6/6plus

    iOS:界面适配--iPhone不同机型适配 6/6plus        机型变化 坐标:表示屏幕物理尺寸大小,坐标变大了,表示机器屏幕尺寸变大了: 像素:表示屏幕图片的大小,跟坐标之间有个对应关系 ...

  6. iOS 9 适配中出现的坑

    整理 iOS 9 适配中出现的坑(图文) 2015-10-22 iOS开发 库克表示:“现在在中国有150多万的开发者在iOS当中开发应用程序,我们鼓励更多的人开发应用程序,也鼓励更多的创业加入.” ...

  7. iOS常用框架源码分析

    SDWebImage NSCache 类似可变字典,线程安全,使用可变字典自定义实现缓存时需要考虑加锁和释放锁 在内存不足时NSCache会自动释放存储的对象,不需要手动干预 NSCache的key不 ...

  8. ios下最简单的正则,RegexKitLite

    ios下最简单的正则,RegexKitLite 1.去RegexKitLite下载类库,解压出来会有一个例子包及2个文件,其实用到的就这2个文件,添加到工程中.备用地址:http://www.coco ...

  9. iOS 9 适配需要注意的问题

    iOS 9 适配需要注意的问题 1`网络适配_改用更安全的HTTPS iOS9把所有的http请求都改为https了:iOS9系统发送的网络请求将统一使用TLS 1.2 SSL.采用TLS 1.2 协 ...

随机推荐

  1. OnlineJudge 离线题库采集

    过段时间要把以前的OJ换掉,我负责VirtualJudge的部分.需要用C与PHP写一个Linux下的VJudge. 在此之前,将以前写给自己学弟学妹用的OJ离线题库的采集程序改进了一下.支持国内一些 ...

  2. RedHat安装GCC问题-解决依赖问题

    RedHat Linux在安装gcc时需要cpp和cloog-ppl但是在安装cpp的时候需要这个依赖:libmpfr.so.1()(64bit) is needed by cpp-4.4.6-3.e ...

  3. Hive 3、Hive 的安装配置(本地derby模式)

    这种方式是最简单的存储方式,只需要在hive-site.xml做如下配置便可; $ vim hive-site.xml <configuration>   <property> ...

  4. php 的设计模式

    1.单例模式 单例模式顾名思义,就是只有一个实例.作为对象的创建模式, 单例模式确保某一个类只有一个实例,而且自行实例化并向整个系统提供这个实例. 单例模式的要点有三个: 一是某个类只能有一个实例: ...

  5. Nexus 刷机

    @echo offfastboot flash bootloader bootloader-hammerhead-hhz12k.imgfastboot flash radio radio-hammer ...

  6. unity4.x for mac破解(含Unity全版本号破解)

    声明,破解方式及工具,均来源于国外互联网.仅供交流学习使用! 国外一个大仙做的破解.这位大侠实在是牛,全版本号跟进,win和mac的破解包都有.win下有类似于注冊机的Patch,mac下有crack ...

  7. .NET中反射机制的使用与分析

    .NET中反射机制的使用与分析 [日期:2008-06-30] 来源:  作者:志伟     .NET反射的定义:审查元数据并收集关于它的类型信息的能力. 元数据是一种二进制信息,用以对存储在公共语言 ...

  8. Transition 1

    W3C标准中对css3的transition这是样描述的:“css的transition允许css的属性值在一定的时间区间内平滑地过渡.这种效果可以在鼠标单击.获得焦点.被点击或对元素任何改变中触发, ...

  9. contentSize、contentInset和contentOffset

    contentSize.contentInset和contentOffset 是 scrollView三个基本的属性. contentSize: The size of the content vie ...

  10. OpenGL ES 2.0 shader开发

    1.创建一个shader容器 GLES20.glCreateShader(shaderType); 函数原型为: int glCreateShader (int type) 方法参数: GLES20. ...