123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272 |
- //
- // MASConstraint.h
- // Masonry
- //
- // Created by Jonas Budelmann on 22/07/13.
- // Copyright (c) 2013 cloudling. All rights reserved.
- //
- #import "MASUtilities.h"
- /**
- * Enables Constraints to be created with chainable syntax
- * Constraint can represent single NSLayoutConstraint (MASViewConstraint)
- * or a group of NSLayoutConstraints (MASComposisteConstraint)
- */
- @interface MASConstraint : NSObject
- // Chaining Support
- /**
- * Modifies the NSLayoutConstraint constant,
- * only affects MASConstraints in which the first item's NSLayoutAttribute is one of the following
- * NSLayoutAttributeTop, NSLayoutAttributeLeft, NSLayoutAttributeBottom, NSLayoutAttributeRight
- */
- - (MASConstraint * (^)(MASEdgeInsets insets))insets;
- /**
- * Modifies the NSLayoutConstraint constant,
- * only affects MASConstraints in which the first item's NSLayoutAttribute is one of the following
- * NSLayoutAttributeTop, NSLayoutAttributeLeft, NSLayoutAttributeBottom, NSLayoutAttributeRight
- */
- - (MASConstraint * (^)(CGFloat inset))inset;
- /**
- * Modifies the NSLayoutConstraint constant,
- * only affects MASConstraints in which the first item's NSLayoutAttribute is one of the following
- * NSLayoutAttributeWidth, NSLayoutAttributeHeight
- */
- - (MASConstraint * (^)(CGSize offset))sizeOffset;
- /**
- * Modifies the NSLayoutConstraint constant,
- * only affects MASConstraints in which the first item's NSLayoutAttribute is one of the following
- * NSLayoutAttributeCenterX, NSLayoutAttributeCenterY
- */
- - (MASConstraint * (^)(CGPoint offset))centerOffset;
- /**
- * Modifies the NSLayoutConstraint constant
- */
- - (MASConstraint * (^)(CGFloat offset))offset;
- /**
- * Modifies the NSLayoutConstraint constant based on a value type
- */
- - (MASConstraint * (^)(NSValue *value))valueOffset;
- /**
- * Sets the NSLayoutConstraint multiplier property
- */
- - (MASConstraint * (^)(CGFloat multiplier))multipliedBy;
- /**
- * Sets the NSLayoutConstraint multiplier to 1.0/dividedBy
- */
- - (MASConstraint * (^)(CGFloat divider))dividedBy;
- /**
- * Sets the NSLayoutConstraint priority to a float or MASLayoutPriority
- */
- - (MASConstraint * (^)(MASLayoutPriority priority))priority;
- /**
- * Sets the NSLayoutConstraint priority to MASLayoutPriorityLow
- */
- - (MASConstraint * (^)(void))priorityLow;
- /**
- * Sets the NSLayoutConstraint priority to MASLayoutPriorityMedium
- */
- - (MASConstraint * (^)(void))priorityMedium;
- /**
- * Sets the NSLayoutConstraint priority to MASLayoutPriorityHigh
- */
- - (MASConstraint * (^)(void))priorityHigh;
- /**
- * Sets the constraint relation to NSLayoutRelationEqual
- * returns a block which accepts one of the following:
- * MASViewAttribute, UIView, NSValue, NSArray
- * see readme for more details.
- */
- - (MASConstraint * (^)(id attr))equalTo;
- /**
- * Sets the constraint relation to NSLayoutRelationGreaterThanOrEqual
- * returns a block which accepts one of the following:
- * MASViewAttribute, UIView, NSValue, NSArray
- * see readme for more details.
- */
- - (MASConstraint * (^)(id attr))greaterThanOrEqualTo;
- /**
- * Sets the constraint relation to NSLayoutRelationLessThanOrEqual
- * returns a block which accepts one of the following:
- * MASViewAttribute, UIView, NSValue, NSArray
- * see readme for more details.
- */
- - (MASConstraint * (^)(id attr))lessThanOrEqualTo;
- /**
- * Optional semantic property which has no effect but improves the readability of constraint
- */
- - (MASConstraint *)with;
- /**
- * Optional semantic property which has no effect but improves the readability of constraint
- */
- - (MASConstraint *)and;
- /**
- * Creates a new MASCompositeConstraint with the called attribute and reciever
- */
- - (MASConstraint *)left;
- - (MASConstraint *)top;
- - (MASConstraint *)right;
- - (MASConstraint *)bottom;
- - (MASConstraint *)leading;
- - (MASConstraint *)trailing;
- - (MASConstraint *)width;
- - (MASConstraint *)height;
- - (MASConstraint *)centerX;
- - (MASConstraint *)centerY;
- - (MASConstraint *)baseline;
- #if (__IPHONE_OS_VERSION_MIN_REQUIRED >= 80000) || (__TV_OS_VERSION_MIN_REQUIRED >= 9000) || (__MAC_OS_X_VERSION_MIN_REQUIRED >= 101100)
- - (MASConstraint *)firstBaseline;
- - (MASConstraint *)lastBaseline;
- #endif
- #if (__IPHONE_OS_VERSION_MIN_REQUIRED >= 80000) || (__TV_OS_VERSION_MIN_REQUIRED >= 9000)
- - (MASConstraint *)leftMargin;
- - (MASConstraint *)rightMargin;
- - (MASConstraint *)topMargin;
- - (MASConstraint *)bottomMargin;
- - (MASConstraint *)leadingMargin;
- - (MASConstraint *)trailingMargin;
- - (MASConstraint *)centerXWithinMargins;
- - (MASConstraint *)centerYWithinMargins;
- #endif
- /**
- * Sets the constraint debug name
- */
- - (MASConstraint * (^)(id key))key;
- // NSLayoutConstraint constant Setters
- // for use outside of mas_updateConstraints/mas_makeConstraints blocks
- /**
- * Modifies the NSLayoutConstraint constant,
- * only affects MASConstraints in which the first item's NSLayoutAttribute is one of the following
- * NSLayoutAttributeTop, NSLayoutAttributeLeft, NSLayoutAttributeBottom, NSLayoutAttributeRight
- */
- - (void)setInsets:(MASEdgeInsets)insets;
- /**
- * Modifies the NSLayoutConstraint constant,
- * only affects MASConstraints in which the first item's NSLayoutAttribute is one of the following
- * NSLayoutAttributeTop, NSLayoutAttributeLeft, NSLayoutAttributeBottom, NSLayoutAttributeRight
- */
- - (void)setInset:(CGFloat)inset;
- /**
- * Modifies the NSLayoutConstraint constant,
- * only affects MASConstraints in which the first item's NSLayoutAttribute is one of the following
- * NSLayoutAttributeWidth, NSLayoutAttributeHeight
- */
- - (void)setSizeOffset:(CGSize)sizeOffset;
- /**
- * Modifies the NSLayoutConstraint constant,
- * only affects MASConstraints in which the first item's NSLayoutAttribute is one of the following
- * NSLayoutAttributeCenterX, NSLayoutAttributeCenterY
- */
- - (void)setCenterOffset:(CGPoint)centerOffset;
- /**
- * Modifies the NSLayoutConstraint constant
- */
- - (void)setOffset:(CGFloat)offset;
- // NSLayoutConstraint Installation support
- #if TARGET_OS_MAC && !(TARGET_OS_IPHONE || TARGET_OS_TV)
- /**
- * Whether or not to go through the animator proxy when modifying the constraint
- */
- @property (nonatomic, copy, readonly) MASConstraint *animator;
- #endif
- /**
- * Activates an NSLayoutConstraint if it's supported by an OS.
- * Invokes install otherwise.
- */
- - (void)activate;
- /**
- * Deactivates previously installed/activated NSLayoutConstraint.
- */
- - (void)deactivate;
- /**
- * Creates a NSLayoutConstraint and adds it to the appropriate view.
- */
- - (void)install;
- /**
- * Removes previously installed NSLayoutConstraint
- */
- - (void)uninstall;
- @end
- /**
- * Convenience auto-boxing macros for MASConstraint methods.
- *
- * Defining MAS_SHORTHAND_GLOBALS will turn on auto-boxing for default syntax.
- * A potential drawback of this is that the unprefixed macros will appear in global scope.
- */
- #define mas_equalTo(...) equalTo(MASBoxValue((__VA_ARGS__)))
- #define mas_greaterThanOrEqualTo(...) greaterThanOrEqualTo(MASBoxValue((__VA_ARGS__)))
- #define mas_lessThanOrEqualTo(...) lessThanOrEqualTo(MASBoxValue((__VA_ARGS__)))
- #define mas_offset(...) valueOffset(MASBoxValue((__VA_ARGS__)))
- #ifdef MAS_SHORTHAND_GLOBALS
- #define equalTo(...) mas_equalTo(__VA_ARGS__)
- #define greaterThanOrEqualTo(...) mas_greaterThanOrEqualTo(__VA_ARGS__)
- #define lessThanOrEqualTo(...) mas_lessThanOrEqualTo(__VA_ARGS__)
- #define offset(...) mas_offset(__VA_ARGS__)
- #endif
- @interface MASConstraint (AutoboxingSupport)
- /**
- * Aliases to corresponding relation methods (for shorthand macros)
- * Also needed to aid autocompletion
- */
- - (MASConstraint * (^)(id attr))mas_equalTo;
- - (MASConstraint * (^)(id attr))mas_greaterThanOrEqualTo;
- - (MASConstraint * (^)(id attr))mas_lessThanOrEqualTo;
- /**
- * A dummy method to aid autocompletion
- */
- - (MASConstraint * (^)(id offset))mas_offset;
- @end
|