在设备旋转时保持自动布局约束处于活动状态

Keep autolayout constraints active status on device rotation(在设备旋转时保持自动布局约束处于活动状态)
本文介绍了在设备旋转时保持自动布局约束处于活动状态的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!

问题描述

我注意到,当我以编程方式更新我的自动布局约束时,所有更改都会在我旋转屏幕时还原.

I noticed that when I update my autolayout constraints programmatically, all changes are reverted when I rotate the screen.

重现问题:

  • 带有 UIView 和 2 个约束的基本 Storyboard 界面:

  • Basic Storyboard interface with UIView and 2 constraints:

  1. 宽度等于 superview.width(乘数 1)激活
  2. 宽度等于 superview.width(乘数 1/2)已禁用

  • 使用 IBOutlet 创建和链接这两个约束

  • Create and link these 2 constraints with IBOutlet

    对我来说似乎是一个错误.

    Seems like a bug to me.

    你怎么看?

    截图:

    故事板:

    约束 #1:

    约束 #2:

    推荐答案

    Size Classes

    Installed 是指 Size Classes 安装,而不是 active/inactive.

    Size Classes

    Installed refers to Size Classes installation, not to active/inactive.

    您必须以编程方式创建另一个约束,并激活/停用那个一个.这是因为您无法更改约束的乘数(我可以更改乘数属性NSLayoutConstraint?),你也不能修改大小类(activateConstraints: 和 deactivateConstraints: 在 IB 中创建的约束旋转后不持久).

    You must create another constraint programmatically, and activate/deactivate that one. This is because you cannot change the multiplier of a constraint (Can i change multiplier property for NSLayoutConstraint?), nor can you tinker with Size Classes (activateConstraints: and deactivateConstraints: not persisting after rotation for constraints created in IB).

    有几种方法可以做到这一点.在下面的示例中,我创建了一个 x1 约束的副本,其中包含一个乘数或 1/2.然后我在两者之间切换:

    There are a few ways to do so. In the example below, I create a copy of your x1 constraint, with a multiplier or 1/2. I then toggle between the two:

    @IBOutlet var fullWidthConstraint: NSLayoutConstraint!
    var halfWidthConstraint: NSLayoutConstraint!
    
    override func viewDidLoad() {
        super.viewDidLoad()
        // Do any additional setup after loading the view, typically from a nib.
        halfWidthConstraint = NSLayoutConstraint(item: fullWidthConstraint.firstItem,
            attribute: fullWidthConstraint.firstAttribute,
            relatedBy: fullWidthConstraint.relation,
            toItem: fullWidthConstraint.secondItem,
            attribute: fullWidthConstraint.secondAttribute,
            multiplier: 0.5,
            constant: fullWidthConstraint.constant)
        halfWidthConstraint.priority = fullWidthConstraint.priority
    }
    
    @IBAction func changeConstraintAction(sender: UISwitch) {
        if sender.on {
            NSLayoutConstraint.deactivateConstraints([fullWidthConstraint])
            NSLayoutConstraint.activateConstraints([halfWidthConstraint])
        } else {
            NSLayoutConstraint.deactivateConstraints([halfWidthConstraint])
            NSLayoutConstraint.activateConstraints([fullWidthConstraint])
        }
    }
    

    <小时>

    iOS 9+Xcode 7+ 上测试.

    这篇关于在设备旋转时保持自动布局约束处于活动状态的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持编程学习网!

  • 本站部分内容来源互联网,如果有图片或者内容侵犯您的权益请联系我们删除!

    相关文档推荐

    Why local notification is not firing for UNCalendarNotificationTrigger(为什么没有为UNCalendarNotificationTrigger触发本地通知)
    iOS VoiceOver functionality changes with Bundle Identifier(IOS画外音功能随捆绑包标识符而变化)
    tabbar middle tab out of tabbar corner(选项卡栏中间的选项卡角外)
    Pushing UIViewController above UITabBar(将UIView控制器推送到UITabBar上方)
    How can I sync two flatList scroll position in react native(如何在本机Reaction中同步两个平面列表滚动位置)
    Get an event when UIBarButtonItem menu is displayed(显示UIBarButtonItem菜单时获取事件)