zoukankan      html  css  js  c++  java
  • 【转】iOS6中的Auto Layout:通过代码添加约束

     
     

    最近做的项目用到了Auto Layout,于是经过了一番大量的google,这是我看到的讲用代码创建约束最清晰的一篇教程,于是想跟更多的人分享一下。原文也比较简单,可以直接过去看,如果我翻译的那块需要校对的,也请多多指教。


    原文:http://www.ioscreator.com/tutorials/auto-layout-in-ios-6-adding-constraints-through-code


    iOS6提供了一种设计用户界面的新方法:Auto Layout。使用Auto-Layout很容为多种屏幕大小和多种语言设计UI。你可以在IB中使用Auto Layout,那么你一定要小心,否则不经意地移动了界面上的一个UI组件就会弄乱这些约束。因此对于这篇教程,我们用代码定义约束。


    打 开XCode并创建一个Single View Application。工程名叫作ConstraintsCodeDemo,然后填上组织名,公司标识,类前缀。确定在Devices中只选择了 iPhone,Use Storyboards没有选,并且Use Automatic Reference Counting选上了。


    我们将创建一个简单的按钮,并想把它放在界面的左上角。在viewController.m中创建如下实例变量

     

    ViewController 

      UIButton *firstButton


    在viewDidLoad中创建这个按钮,并把它添加到view中

     

    - (void)viewDidLoad 

      [superviewDidLoad];

     

      firstButton = [UIButtonbuttonWithType:UIButtonTypeRoundedRect];

      [firstButton setTitle:@"First"forState:UIControlStateNormal]; 

      [firstButton sizeToFit]; 

      firstButton.translatesAutoresizingMaskIntoConstraints = NO;

     

      [self.view addSubview:firstButton];

      这是由于苹果在iOS 6当中引入了自动布局的新概念,但在那时仍然有很多旧的代码使用autoresizingMask与setFrame:的方式构建界面。试想,如果将一个 已经设置好frame并使用autoresizingMask的视图添加到一个使用自动布局的视图中时,运行时需要隐式地将前者的frame和 autoresizingMask转化为自动布局约束(这些隐式转换的约束的类型为 NSAutoresizingMaskLayoutConstraint),这样才能明确其位置与尺寸而不会导致约束的缺失。这个隐式转换的过程,是由 UIView的translatesAutoresizingMaskIntoConstraints属性的值决定的。默认情况下,该值为YES,表示需 要运行时自动进行隐式转换。这对于兼容旧的代码当然是好的,然而当我们明确为视图添加了约束后,我们就不希望再进行autoresizingMask的隐 式转换了,否则就会引起约束的冲突。因此,需要特别注意的是,当我们使用代码创建视图时,需要将translatesAutoresizingMaskIntoConstraints属性的值设置为NO

    设置translatesAutoresizingMaskIntoConstraints属性为NO,来禁用“古老的”springs and struts方法。这个属性是为了向后兼容。我们将添加一个左边约束,于是这个按钮会在view中移动20个点。把下面的代码添加到viewDidLoad下面。

     

    *constraint = [NSLayoutConstraint constraintWithItem:firstButton attribute:NSLayoutAttributeLeading relatedBy:NSLayoutRelationEqualtoItem:self.view attribute:NSLayoutAttributeLeading multiplier:1.0f constant:20.f];

     

    [self.view addConstraint:constraint];

     

    Auto Layout用一个公式来计算界面之间的关系:


    A = B * m + c


    或者


    viewA.attribute = viewB.attributs*multiplier + constant


    在这个例子中公式如下:

     

    firstButton.NSLayoutAttributeLeading = self.view.NSLayoutAtrributeLeading * 1.0f + 20f

    按钮左边的位置等于父视图左边距减掉20.

    把下面的约束添加到viewDidLoad里

    = [NSLayoutConstraint constraintWithItem:firstButton attribute:NSLayoutAttributeTop relatedBy:NSLayoutRelationEqualtoItem:self.view attribute:NSLayoutAttributeTop multiplier:1.0f constant:30.f];

     

    [self.view addConstraint:constraint];


    该约束将会使按钮距离父视图上面30个点。Build and Run。这个按钮距离左边20个点,上面30个点。

     

    按 cmd+<- 使界面横屏。

     

    在interface中创建一个新的实例变量

     

    *secondButton;


    在viewDidLoad中添加下面的代码,在view中添加第二个按钮。

     

    = [UIButton buttonWithType:UIButtonTypeRoundedRect];

    [secondButton setTitle:@"Second"forState:UIControlStateNormal]; 

    [secondButton sizeToFit]; 

    secondButton.translatesAutoresizingMaskIntoConstraints =NO;

     

    [self.view addSubview:secondButton];


    这个按钮将在父视图的X轴方向居中,距离底部40个点。在viewDidLoad中添加下面的约束。

     

    = [NSLayoutConstraint constraintWithItem:secondButtonattribute:NSLayoutAttributeBottom relatedBy:NSLayoutRelationEqualtoItem:self.view attribute:NSLayoutAttributeBottom multiplier:1.0fconstant:-40.f];

     

    [self.view addConstraint:constraint];

     

    = [NSLayoutConstraint constraintWithItem:secondButton attribute:NSLayoutAttributeCenterX relatedBy:NSLayoutRelationEqual toItem:self.view attribute:NSLayoutAttributeCenterX multiplier:1.0fconstant:0.0f];

     

    [self.view addConstraint:constraint];


    第二个按钮宽度固定为200个点。添加下面约束。

     

    = [NSLayoutConstraint constraintWithItem:secondButton attribute:NSLayoutAttributeWidth relatedBy:NSLayoutRelationEqualtoItem:nil attribute:NSLayoutAttributeNotAnAttribute multiplier:1.0fconstant:200.0f];

     

    [self.view addConstraint:constraint];


    请 注意这个约束只与按钮有关,与父视图无关,因为这是一个固定大小。因此toItem设置为nil,对应的属性参数设置为 NSLayoutAttributeNotAnAttribute。Build and Run。这个固定的按钮放在X轴的中心,并且距离父视图底部40个点。

     

    按cmd+<- 使界面横屏。


     

    以上是在代码中使用约束的一个简介,还有更多的内容需要理解,但是这篇教程的目的是使事情能够简单,期待着在将来的教程中有更复杂的例子。


    你可以在github上下载到ConstraintsCodeDemo的源代码。

  • 相关阅读:
    浅谈jQuery easyui datagrid操作单元格样式
    关于翻页之后表格重新加载,之前选中的项丢失的问题处理
    jquery操作复选框(checkbox)的12个小技巧总结
    项目管理学习笔记之四.风险管理
    c#基于udp实现的p2p语音聊天工具
    漫说好管理vs.坏管理
    linux安装tomcat
    wifi共享精灵2014.04.25.001已经更新,wifi热点中文名走起!
    NYOJ 589 糖果
    MacBook Pro安装Photoshop且支持Retina有你们说的那么困难吗!
  • 原文地址:https://www.cnblogs.com/A--G/p/4666804.html
Copyright © 2011-2022 走看看