mirror of
https://github.com/Swiftgram/Telegram-iOS.git
synced 2025-06-16 05:55:20 +00:00

git-subtree-dir: submodules/AsyncDisplayKit git-subtree-mainline: d06f423e0ed3df1fed9bd10d79ee312a9179b632 git-subtree-split: 02bedc12816e251ad71777f9d2578329b6d2bef6
158 lines
5.5 KiB
Objective-C
158 lines
5.5 KiB
Objective-C
//
|
|
// 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 <Foundation/Foundation.h>
|
|
#import <AsyncDisplayKit/ASDimension.h>
|
|
#import <AsyncDisplayKit/ASLayoutElement.h>
|
|
|
|
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<ASLayoutElement> 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(id<ASLayoutElement>layoutElement, 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<ASLayoutElement> 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<ASLayout *> *sublayouts;
|
|
|
|
/**
|
|
* The frame for the given element, or CGRectNull if
|
|
* the element is not a direct descendent of this layout.
|
|
*/
|
|
- (CGRect)frameForElement:(id<ASLayoutElement>)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<ASLayoutElement>)layoutElement
|
|
size:(CGSize)size
|
|
position:(CGPoint)position
|
|
sublayouts:(nullable NSArray<ASLayout *> *)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<ASLayoutElement>)layoutElement
|
|
size:(CGSize)size
|
|
position:(CGPoint)position
|
|
sublayouts:(nullable NSArray<ASLayout *> *)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<ASLayoutElement>)layoutElement
|
|
size:(CGSize)size
|
|
sublayouts:(nullable NSArray<ASLayout *> *)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<ASLayoutElement>)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
|