iOS 自动布局 Auto Layout 入门 04 约束的动态效果

本文介绍如何在iOS应用中使用运行时约束调整按钮布局。通过一个实例展示了如何通过代码改变按钮标题,并确保布局遵循预设约束,如水平居中、间距保持等。同时介绍了如何设置等宽约束使按钮宽度一致。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

前面几节使用的约束都是通过Interface Builder添加的,这一节我们来看看运行时约束是怎么样的。

首先我们删除没有背景色的那个按钮


添加以下方法到ViewController.m中:

- (IBAction)buttonTapped:(UIButton *)sender
{
    if ([[sender titleForState:UIControlStateNormal] isEqualToString:@"X"])
    {
        [sender setTitle:@"A very long title for this button" forState:UIControlStateNormal];
    }
    else
    {
        [sender setTitle:@"X" forState:UIControlStateNormal];
    }
}
这个action的作用是,当按钮被点击时,修改按钮的标题。通过Interface Builder,将两个按钮都连接到这个action上。
程序执行效果如下:

 

无论哪一个按钮的标题更长,界面的布局始终遵循我们设定的约束:

  • 下方的按钮始终水平居中
  • 下方的按钮于底部有20个点的间隔
  • 上方的按钮始终于下方的按钮左对齐
  • 上方的按钮与下方的按钮垂直间距为40

接下来,我们为两个按钮添加等宽约束:


由于我们之前为按钮设置了‘Size to Fit Content'属性,执行程序,点击两个按钮,可以看到,两个按钮始终以较大的按钮为参考对象来设置宽度:


  

  

我们还可以为某个按钮添加宽度约束,这个宽度约束会覆盖掉‘Size to Fit Contant'属性。这样,两个按钮的宽度都变成了我们设定一个固定值:


程序执行效果如下,无论我们如何点击按钮,两个按钮的宽度都不会改变:



评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值