Auto Layout:通过代码添加约束

3 篇文章 0 订阅
2 篇文章 0 订阅

最近做的项目用到了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中创建如下实例变量


@implementationViewController 

  UIButton *firstButton

}


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


- (void)viewDidLoad 

  [superviewDidLoad];


  firstButton = [UIButtonbuttonWithType:UIButtonTypeRoundedRect];

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

  [firstButton sizeToFit]; 

  firstButton.translatesAutoresizingMaskIntoConstraints = NO;


  [self.view addSubview:firstButton];

}


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


NSLayoutConstraint *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里

constraint = [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中创建一个新的实例变量


UIButton *secondButton;


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


secondButton = [UIButton buttonWithType:UIButtonTypeRoundedRect];

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

[secondButton sizeToFit]; 

secondButton.translatesAutoresizingMaskIntoConstraints =NO;


[self.view addSubview:secondButton];


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


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


[self.view addConstraint:constraint];


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


[self.view addConstraint:constraint];


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


constraint = [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的源代码。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Auto Layout可以通过代码实现,以下是一个使用代码实现Auto Layout布局的示例: 首先,创建需要布局的视图,并将其添加到父视图中: ``` UIView *superView = self.view; UIView *subView = [[UIView alloc] init]; subView.translatesAutoresizingMaskIntoConstraints = NO; [superView addSubview:subView]; ``` 然后,使用NSLayoutConstraint类创建需要的约束,并将它们添加到视图中: ``` NSLayoutConstraint *leadingConstraint = [NSLayoutConstraint constraintWithItem:subView attribute:NSLayoutAttributeLeading relatedBy:NSLayoutRelationEqual toItem:superView attribute:NSLayoutAttributeLeading multiplier:1.0 constant:10.0]; NSLayoutConstraint *topConstraint = [NSLayoutConstraint constraintWithItem:subView attribute:NSLayoutAttributeTop relatedBy:NSLayoutRelationEqual toItem:superView attribute:NSLayoutAttributeTop multiplier:1.0 constant:10.0]; NSLayoutConstraint *widthConstraint = [NSLayoutConstraint constraintWithItem:subView attribute:NSLayoutAttributeWidth relatedBy:NSLayoutRelationEqual toItem:nil attribute:NSLayoutAttributeNotAnAttribute multiplier:1.0 constant:100.0]; NSLayoutConstraint *heightConstraint = [NSLayoutConstraint constraintWithItem:subView attribute:NSLayoutAttributeHeight relatedBy:NSLayoutRelationEqual toItem:nil attribute:NSLayoutAttributeNotAnAttribute multiplier:1.0 constant:100.0]; [superView addConstraints:@[leadingConstraint, topConstraint]; [subView addConstraints:@[widthConstraint, heightConstraint]]; ``` 在上面的代码中,首先创建了需要布局的子视图subView,并将其添加到父视图superView中。然后,分别创建了leadingConstraint、topConstraint、widthConstraint和heightConstraint四个约束,并将它们添加到superView和subView中。 需要注意的是,使用NSLayoutConstraint类创建约束时,需要指定参照视图、属性和常量等信息,并将约束添加到视图中。使用addConstraints方法可以同时添加多个约束到一个视图中,而使用addConstraint方法可以将单个约束添加到一个视图中。 通过上面的示例,可以看到使用代码实现Auto Layout布局的过程相对繁琐,需要注意各个约束的关系和顺序,但在实际开发中,有时需要使用代码实现布局,因此需要仔细学习和掌握。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值