For any iOS developer, Autolayout is a very useful feature which is used in designing the iPhone / iPad App UI. Among all the controls that AutoLayout provides, UIScrollView is one of the most useful controls in iOS as it enables iOS app developer to present the content larger than a single screen. The view is scrollable when the content length is larger than the screen size.
Unlike other controls, the scrollview needs all the constraints for its edges i.e. for edges (top, left, bottom, right) and the controllers that are added in the scrollview must be given the constraints w.r.t the edges of scrollview because scrollview calculates it’s content from the constraints given to controllers.
When you are giving the constraints to the scrollview then its not required to set its contentSize because it is automatically calculated from the given constraints to its subview. You can set scrollview’s offset to move scrollview up and down as required. You must turn off autoresizing property.
Class responsible for setting Constraints
NSLayoutContraint class
This class is used for giving constraints to the components dynamically. A constraint is a relationship between two UI objects that must be followed by the constraint-based layout system. Each constraint follows this linear equation,
itemA.attributeOption1 = multiplier × itemB.attributeOption2 + constant
In this equation, attributeOption1 and attributeOption2 are the variables that Auto Layout can set in order to fix the constraints. The other values are defined when you create the constraint.
For example, Consider below linear equation,
labelTitle.leading = 1.0 × labelDescription.trailing + 8.0
Here to set relative position of two labels, the leading edge of the description label is 8 points after the trailing edge of the title label.
Methods Used To add Constraints
1) constraintsWithVisualFormat: method
In this method the visual format language is used to give the constraints to the components. The AutoLayout Visual Format Language is generally used to specify the common constraints including the vertical layout, standard spacing and dimensions and constraints with different priorities. This will return array of constraints using an ASCII art-like visual format string.
For Example,
// Constraints for scrollview // Create a scrollview, set its properties and then add in the view. _scrollview = [[UIScrollView alloc] init]; self.scrollview.translatesAutoresizingMaskIntoConstraints = NO; self.scrollview.backgroundColor = [UIColor clearColor]; [self.view addSubview:self.scrollview]; // Create a container view that will hold the component inside the scrollview. It is just a UIView. It is subview of scrollview. _containerView = [[UIView alloc] init]; self.containerView.translatesAutoresizingMaskIntoConstraints = NO; self.containerView.backgroundColor = [UIColor clearColor]; [self.scrollview addSubview:self.containerView]; // Here the constraints to the scrollview and the container view is given by the visual format language. NSDictionary *dict = @{ @"scrollview" : self.scrollview, @"containerView" : self.containerView }; //constraints for scrollview all for - top, bottom and rignt, left [self.view addConstraints:[NSLayoutConstraint constraintsWithVisualFormat:@"H:|-0-[scrollview]-0-|" options:0 metrics:nil views:dict]]; [self.view addConstraints:[NSLayoutConstraint constraintsWithVisualFormat:@"V:|-0-[scrollview]-0-|" options:0 metrics:nil views:dict]]; //constraints for contrinerview all for - top, bottom and rignt, left [self.view addConstraints:[NSLayoutConstraint constraintsWithVisualFormat:@"H:|-0-[containerView]-0-|" options:0 metrics:nil views:dict]]; [self.view addConstraints:[NSLayoutConstraint constraintsWithVisualFormat:@"V:|-0-[containerView]-0-|" options:0 metrics:nil views:dict]]; //equal width for containerview with view [self.view addConstraint:[NSLayoutConstraint constraintWithItem:self.view attribute:NSLayoutAttributeWidth relatedBy:NSLayoutRelationEqual toItem:self.containerView attribute:NSLayoutAttributeWidth multiplier:1.0 constant:0.0]];
2) constraintWithItem: method
In this method we deal with the items i.e. components to which the constraints is going to be given.
Example, consider the scrollview and containerview from previous example. The previous example by this method will look like below.
//leading for scrollview [self.view addConstraint:[NSLayoutConstraint constraintWithItem:self.scrollview attribute:NSLayoutAttributeLeading relatedBy:NSLayoutRelationEqual toItem:self.view attribute:NSLayoutAttributeLeading multiplier:1.0 constant:0.0]]; //top for scrollview [self.view addConstraint:[NSLayoutConstraint constraintWithItem:self.scrollview attribute:NSLayoutAttributeTop relatedBy:NSLayoutRelationEqual toItem:self.view attribute:NSLayoutAttributeTop multiplier:1.0 constant:0.0]]; //trailing for scrollview [self.view addConstraint:[NSLayoutConstraint constraintWithItem:self.view attribute:NSLayoutAttributeTrailing relatedBy:NSLayoutRelationEqual toItem:self.scrollview attribute:NSLayoutAttributeTrailing multiplier:1.0 constant:0.0]]; //bottom for scrollview [self.view addConstraint:[NSLayoutConstraint constraintWithItem:self.view attribute:NSLayoutAttributeBottom relatedBy:NSLayoutRelationEqual toItem:self.scrollview attribute:NSLayoutAttributeBottom multiplier:1.0 constant:0.0]]; //leading for scrollview [self.view addConstraint:[NSLayoutConstraint constraintWithItem:self.containerView attribute:NSLayoutAttributeLeading relatedBy:NSLayoutRelationEqual toItem:self.view attribute:NSLayoutAttributeLeading multiplier:1.0 constant:0.0]]; //top for containerView [self.view addConstraint:[NSLayoutConstraint constraintWithItem:self.containerView attribute:NSLayoutAttributeTop relatedBy:NSLayoutRelationEqual toItem:self.view attribute:NSLayoutAttributeTop multiplier:1.0 constant:0.0]]; //trailing for containerView [self.view addConstraint:[NSLayoutConstraint constraintWithItem:self.view attribute:NSLayoutAttributeTrailing relatedBy:NSLayoutRelationEqual toItem:self.containerView attribute:NSLayoutAttributeTrailing multiplier:1.0 constant:0.0]]; //bottom for containerView [self.view addConstraint:[NSLayoutConstraint constraintWithItem:self.view attribute:NSLayoutAttributeBottom relatedBy:NSLayoutRelationEqual toItem:self.containerView attribute:NSLayoutAttributeBottom multiplier:1.0 constant:0.0]];
You have set all the constraints for the scrollview and the container view. Now to know how to set the constraints within the scrollview, please look into my video where I have demonstrated all the constraints that you need to add to scrollview for the dynamic contents.
With this, I hope it will be easy for you now to maintain the constraints for the scrollview and its contents. If you have any questions please feel free to ask in the comments section below.
Author : MahendraGP