ios7 xib 适配

</pre><span style="font-family:'Comic Sans MS'; font-size:18px"></span><p></p><pre name="code" class="objc">
如果你已经下载了xcode5,正准备使用,你会发现各种布局的改变.

注定这段时间是忙的,是头疼的!原创在此哦http://my.csdn.net/rhljiayou

这两天经常会碰到群里有人在问问题,问ios7怎么适配,以及各种网上说的如何解决ios7下状态栏的问题.

我发现各种群里流传着一种适配方法,就是修改window的坐标(window.frame),然后大家纷纷效仿,但是往往出现各种问题,发出各种报怨,各种吐嘈;

殊不知别人的写法并不是你的写法,别人的适配也不是你的适配,所以别的方法不一定能解决你的问题.我们要理解他,得到解决思路,而不是解决代码.

其实官方已经给出状态栏同时兼容ios6和ios7的解决方案.他就集成在xcode5中,如下图所示:

 着急做适配,可能会做错喔!原创在此哦http://my.csdn.net/rhljiayou

要了解这个适配先要讲一下Deltas也就是这个 ∆,上过高中物理都应该知道这个东西,不认识的请自觉检讨(初中数学就教过).

Deltas的意思你可以理解为增量.相对增量.

科普讲完,下面是具体使用.

首先要出现∆选项,必须使用xcode5的方式打开xib:

在xib的第一个标签中哦~原创在此哦http://my.csdn.net/rhljiayou

由于我们要同时兼容6和7,所以我们需要选6.1或更早

然后调整增量,增量的意思是如果运行在ios7的模式下,就使其坐标+增量,如果是6或更早的,就是直接使用上面的坐标

效果如图,十分完美,呵呵

<pre name="code" class="objc">
<pre name="code" class="objc">#define iphone5     ([UIScreen instancesRespondToSelector:@selector(currentMode)]?CGSizeEqualToSize(CGSizeMake(640, 1136), [[UIScreen mainScreen] currentMode].size):NO)

#define ios7  [[[UIDevice currentDevice] systemVersion] floatValue] >= 7
#define kTabBarHeight 63.0f

  if ([[[UIDevice currentDevice] systemVersion] floatValue] >= 7)
        {
            self.view.frame=CGRectMake( 0, -50,self.view.frame.size.width, self.view.frame.size.height);
            
        }
 UILabel *label1=[[UILabel alloc] initWithFrame:CGRectMake(15,ios7? 45:30,80,40)];
 UIView *aView=[[UIView alloc]initWithFrame:
                   CGRectMake(0, 0, 320,iphone5?600:self.tabBarController.view.frame.size.height)];


以上代码 视图大小完美适配。

创在此哦http://my.csdn.net/rhljiayou
-(void)viewWillAppear:(BOOL)animated
{
    if ([[[UIDevice currentDevice] systemVersion] floatValue] >= 7) {
        self.view.bounds =CGRectMake(0, -40,self.view.frame.size.width,self.view.frame.size.height );
    }
    [super viewWillAppear:animated];
    
}


 
<pre>
 
 
 
 

                
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值