Skip to content

Helper class for creating auto layout constraints in code

Notifications You must be signed in to change notification settings

franciscojma86/autolayout

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

13 Commits
 
 
 
 
 
 

Repository files navigation

#UIView+Autolayout This is a category on UIView created for making Auto Layout constraints in code easily. While making constraints from IB is pretty straightforward, if you want to make any changes on the constraints, you need to make a lot of IBOutlets, and sometimes, you just need to create new constraints from code.

##Installation Just drag and drop the UIView+Autolayout.h and .m into your project.

##Usage Using UIView+Autolayout is very simple, but you must still follow the Auto Layout basics:

  • Before adding any constraints, the view must be already added to a superview
  • Layout constraints between 2 views must be added to a superview they have in common
  • Call -layoutIfNeeded from the superview to layout the constraints and see the effects

####Creating a constraint

There are 4 types of constraints this category can generate for you

  • Edges alignment
  • Centers alignment
  • Dimensions alignment
  • Relative positions

#####Edges alignment

To align the edges of a view with it's parent view call -alignSubview:edges:apply Make sure you pass the edges you wish to align. Inspect the enums in the .h Sending :apply as YES, will add the constraints to the calling view in the same call. If you want to only generate the constraints, and save them to add them later, send it as NO.

//Create a constraint to attach the subview at the top of the superview. Apply it to the calling view now.
[parentView alignSubview:subView edges:ConstraintEdgesTop apply:YES];

//Create a constraint to align two views' bottom and top edge. Don't apply it yet.
NSArray *constraints = [parentView alignView:view1 toView:view2 edges:ConstraintEdgesTop | ConstraintEdgesBottom apply:NO];

#####Centers alignment

Follow the same instructions and logic as the edge alignments.

//Align the subview to the center of the superview.
[parentView alignSubView:subview centers:ConstraintCentersX | ConstraintsCenterY apply:YES];

#####Dimensions alignment

You can align two views to have same height and/or width with any offset or multiplier value with oen simple call. Remember that these constraints must be added to a parent view they have in common.

//Make the view1 twice as big as view2.
[parentView alignView:view1 toView:view2 offset:0.0 multiplier:2.0 dimensions:ConstraintDimensionsWidth | ConstraintDimensionsHeight apply:YES];

#####Relative positions

With these methods you can easily position any view relative to another view, i.e. "On top of view", "Leading view", etc.

//Make view2 lead(be in front, or "to the right") of view1 by 20 points
[parentView arrangeView:view2 toView:view1 offset:20.0 multiplier:1.0 position:ConstraintPositionToLead apply:YES];

Hope this helps making constraints more fun! Any feedback or suggestions email me at [email protected] Thanks!

About

Helper class for creating auto layout constraints in code

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published