1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
| /*
Experiment that animates a red square left to right in a container
by swapping the priority of the left and right layout constraints
*/
import UIKit
import XCPlayground
let container = UIView(frame: CGRectZero)
container.backgroundColor = .cyanColor()
container.translatesAutoresizingMaskIntoConstraints = false
let inner = UIView(frame: CGRectZero)
inner.translatesAutoresizingMaskIntoConstraints = false
inner.backgroundColor = .magentaColor()
container.addSubview(inner)
let innerWidth = NSLayoutConstraint(
item: inner,
attribute: .Width,
relatedBy: .Equal,
toItem: nil,
attribute: .NotAnAttribute,
multiplier: 1.0,
constant: 200)
let innerHeight = NSLayoutConstraint(
item: inner,
attribute: .Height,
relatedBy: .Equal,
toItem: nil,
attribute: .NotAnAttribute,
multiplier: 1.0,
constant: 200)
let containerWidth = NSLayoutConstraint(
item: container,
attribute: .Width,
relatedBy: .Equal,
toItem: nil,
attribute: .NotAnAttribute,
multiplier: 1.0,
constant: 500)
let containerHeight = NSLayoutConstraint(
item: container,
attribute: .Height,
relatedBy: .Equal,
toItem: nil,
attribute: .NotAnAttribute,
multiplier: 1.0,
constant: 300)
let top = NSLayoutConstraint(
item: inner,
attribute: .Top,
relatedBy: .Equal,
toItem: container,
attribute: .Top,
multiplier: 1.0,
constant: 50
)
/*
1. Pin the leading edge of the pink box to it's container.
Set it's `priority` to 999.
*/
let left = NSLayoutConstraint(
item: inner,
attribute: .Leading,
relatedBy: .Equal,
toItem: container,
attribute: .Leading,
multiplier: 1.0,
constant: 0
)
left.priority = 999
/*
2. Pin the trailing edge of the pink box to it's container.
Set it's `priority` to 998.
*/
let right = NSLayoutConstraint(
item: inner,
attribute: .Trailing,
relatedBy: .Equal,
toItem: container,
attribute: .Trailing,
multiplier: 1.0,
constant: 0
)
right.priority = 998
NSLayoutConstraint.activateConstraints([
innerWidth,
innerHeight,
containerWidth,
containerHeight,
top,
left,
right
])
// animate the inner square left -> right -> left
// by swapping the left and right constraint priorities
func animate() {
UIView.animateWithDuration(1.0, animations: {
let prevRight = right.priority
let prevLeft = left.priority
/*
3. Swap the priorities of the two constraints
in the animation block
*/
left.priority = prevRight
right.priority = prevLeft
container.layoutIfNeeded()
}, completion: { if $0 { animate() }})
}
animate()
XCPlaygroundPage.currentPage.needsIndefiniteExecution = true
XCPlaygroundPage.currentPage.liveView = container
|