Anchorman
Anchorman copied to clipboard
An autolayout library for the damn fine citizens of San Diego.
Anchorman
Do you think autolayout has to be hard?
Nah. NSLayoutAnchor
is pretty neat! But it's still a bit tedious of an API. Try writing .translatesAutoresizingMaskIntoConstraints = false
and .isActive = true
10 times over. But we can make it a bit easier with a very thin layer of abstraction.
Let's start off with a vocabulary lesson.
UIView
and UILayoutGuide
are Anchorable
. You can pin one to the other, in any combination you like, as long as it generates valid NSLayoutConstraint
s.
How's it work?
I am a cool developer, making a cool app. It has so many views. I want to pin my view to it's superview.
self.backgroundView.pinToSuperview()
That was easy, but I don't want to pin to a superview anymore, I want to pin to another view.
self.messageLabel.pin(to: self.backgroundView)
Ah, ok. Easy enough… How about pinning my label to the left and right side of it's superview… and with insets… and center it in my view.
self.titleLabel.pinToSuperview([ .leading(10.0), .trailing(10.0), .centerY ])
Whoa, that was neat! You can specify a group of edges you want to pin to, and their offsets. Swift enums are the best!
And of course, you can pick one edge to pin to another edge.
self.footerLabel.pin(edge: .bottom, toEdge: .bottom, of: self.view.safeAreaLayoutGuide, constant: 10.0)
Last but not least, set constant values for your constraints. For width, height, or both.
self.footerLabel.set(size: .width(44.0) ])
self.titleLabel.set(size: [ .width(44.0), .height(44.0) ])
I lied, there's a bit more. Anchorman includes a couple of goodies to make your life easier between iOS 10 and iOS 11.
var backwardsCompatibleSafeAreaLayoutGuide: UILayoutGuide
var backwardsCompatibleSafeAreaInsets: UIEdgeInsets
These will use safeAreaLayoutGuide
and safeAreaInsets
on iOS 11, and layoutMarginsGuide
and layoutMargins
on iOS 10, so you can avoid a whole bunch of if #available
conditions.
Installation
Anchorman supports Swift 4 with the latest versions. If you're looking for Swift 3 support, use version 2.0
You can use CocoaPods to install Anchorman by adding it to your Podfile:
platform :ios, '8.0'
use_frameworks!
pod 'Anchorman'
Or Carthage
github "mergesort/Anchorman"
Or install it the old fashioned way by downloading Anchorman.swift
and dropping it in your project.
About me
Hi, I'm Joe! @mergesort everywhere on the web, but especially on Twitter.
License
See the license for more information about how you can use Anchorman. I promise it's not GPL, because I am not "that guy".
Fin
Hopefully Anchorman is your cup of tea, it's the kind of autolayout library I'd want to use. And with that, good night San Diego.