// // ASLayout.h // Texture // // Copyright (c) Facebook, Inc. and its affiliates. All rights reserved. // Changes after 4/13/2017 are: Copyright (c) Pinterest, Inc. All rights reserved. // Licensed under Apache 2.0: http://www.apache.org/licenses/LICENSE-2.0 // #pragma once #import #import #import NS_ASSUME_NONNULL_BEGIN AS_EXTERN CGPoint const ASPointNull; // {NAN, NAN} AS_EXTERN BOOL ASPointIsNull(CGPoint point); AS_EXTERN NSString *const ASThreadDictMaxConstraintSizeKey; /** * Safely calculates the layout of the given root layoutElement by guarding against nil nodes. * @param rootLayoutElement The root node to calculate the layout for. * @param sizeRange The size range to calculate the root layout within. */ AS_EXTERN ASLayout *ASCalculateRootLayout(id rootLayoutElement, const ASSizeRange sizeRange); /** * Safely computes the layout of the given node by guarding against nil nodes. * @param layoutElement The layout element to calculate the layout for. * @param sizeRange The size range to calculate the node layout within. * @param parentSize The parent size of the node to calculate the layout for. */ AS_EXTERN ASLayout *ASCalculateLayout(idlayoutElement, const ASSizeRange sizeRange, const CGSize parentSize); /** * A node in the layout tree that represents the size and position of the object that created it (ASLayoutElement). */ @interface ASLayout : NSObject /** * The underlying object described by this layout */ @property (nonatomic, weak, readonly) id layoutElement; /** * The type of ASLayoutElement that created this layout */ @property (nonatomic, readonly) ASLayoutElementType type; /** * Size of the current layout */ @property (nonatomic, readonly) CGSize size; /** * Position in parent. Default to ASPointNull. * * @discussion When being used as a sublayout, this property must not equal ASPointNull. */ @property (nonatomic, readonly) CGPoint position; /** * Array of ASLayouts. Each must have a valid non-null position. */ @property (nonatomic, copy, readonly) NSArray *sublayouts; /** * The frame for the given element, or CGRectNull if * the element is not a direct descendent of this layout. */ - (CGRect)frameForElement:(id)layoutElement; /** * @abstract Returns a valid frame for the current layout computed with the size and position. * @discussion Clamps the layout's origin or position to 0 if any of the calculated values are infinite. */ @property (nonatomic, readonly) CGRect frame; /** * Designated initializer */ - (instancetype)initWithLayoutElement:(id)layoutElement size:(CGSize)size position:(CGPoint)position sublayouts:(nullable NSArray *)sublayouts NS_DESIGNATED_INITIALIZER; /** * Convenience class initializer for layout construction. * * @param layoutElement The backing ASLayoutElement object. * @param size The size of this layout. * @param position The position of this layout within its parent (if available). * @param sublayouts Sublayouts belong to the new layout. */ + (instancetype)layoutWithLayoutElement:(id)layoutElement size:(CGSize)size position:(CGPoint)position sublayouts:(nullable NSArray *)sublayouts NS_RETURNS_RETAINED AS_WARN_UNUSED_RESULT; /** * Convenience initializer that has CGPointNull position. * Best used by ASDisplayNode subclasses that are manually creating a layout for -calculateLayoutThatFits:, * or for ASLayoutSpec subclasses that are referencing the "self" level in the layout tree, * or for creating a sublayout of which the position is yet to be determined. * * @param layoutElement The backing ASLayoutElement object. * @param size The size of this layout. * @param sublayouts Sublayouts belong to the new layout. */ + (instancetype)layoutWithLayoutElement:(id)layoutElement size:(CGSize)size sublayouts:(nullable NSArray *)sublayouts NS_RETURNS_RETAINED AS_WARN_UNUSED_RESULT; /** * Convenience that has CGPointNull position and no sublayouts. * Best used for creating a layout that has no sublayouts, and is either a root one * or a sublayout of which the position is yet to be determined. * * @param layoutElement The backing ASLayoutElement object. * @param size The size of this layout. */ + (instancetype)layoutWithLayoutElement:(id)layoutElement size:(CGSize)size NS_RETURNS_RETAINED AS_WARN_UNUSED_RESULT; /** * Traverses the existing layout tree and generates a new tree that represents only ASDisplayNode layouts */ - (ASLayout *)filteredNodeLayoutTree NS_RETURNS_RETAINED AS_WARN_UNUSED_RESULT; - (instancetype)init NS_UNAVAILABLE; - (instancetype)new NS_UNAVAILABLE; @end #pragma mark - Debugging @interface ASLayout (Debugging) /** * Set to YES to tell all ASLayout instances to retain their sublayout elements. Defaults to NO. * See `-retainSublayoutLayoutElements` to control this per-instance. * * Note: Weaver relies on this API. */ @property (class) BOOL shouldRetainSublayoutLayoutElements; /** * Recrusively output the description of the layout tree. */ - (NSString *)recursiveDescription; @end NS_ASSUME_NONNULL_END