mirror of
https://github.com/status-im/react-native.git
synced 2025-01-18 05:23:26 +00:00
5c83855c75
Summary: @public We need some another object like ShadowNode (but not ShadowNode) to represent an instance of the component in the mutation instructions. This is the main motivation for introducing ShadowView. Why not use ShadowNode? ShadowNode is designed to represent a node in ShadowTree, not be a part of a mutation instruction. * ShadowNode exposes some APIs that should not be exposed to the mounting layer; * ShadowNode is an immutable data structure, so we cannot mutate it in some way which can be meaningful for mounting; * We should not add to ShadowNode any functionality which is needed only for mounting; * ShadowNode is a bit more heavy object to share that it needs to be; it's exposed (embedded into Mutation) as a `shared_ptr` which is not optimal from the performance perspective; * Retaining ShadowNode from mounting code can unnecessarily extend its lifetime which can negatively affect memory usage. Reviewed By: mdvacca Differential Revision: D9403562 fbshipit-source-id: 72ad81ed918157a62cd3d1a03261f14447649d0b
52 lines
1.5 KiB
C++
52 lines
1.5 KiB
C++
/**
|
|
* Copyright (c) 2015-present, Facebook, Inc.
|
|
*
|
|
* This source code is licensed under the MIT license found in the
|
|
* LICENSE file in the root directory of this source tree.
|
|
*/
|
|
|
|
#pragma once
|
|
|
|
#include <fabric/core/LayoutPrimitives.h>
|
|
#include <fabric/graphics/Geometry.h>
|
|
|
|
namespace facebook {
|
|
namespace react {
|
|
|
|
/*
|
|
* Describes results of layout process for partucular shadow node.
|
|
*/
|
|
struct LayoutMetrics {
|
|
Rect frame;
|
|
EdgeInsets contentInsets {0};
|
|
EdgeInsets borderWidth {0};
|
|
DisplayType displayType {DisplayType::Flex};
|
|
LayoutDirection layoutDirection {LayoutDirection::Undefined};
|
|
Float pointScaleFactor {1.0};
|
|
|
|
Rect getContentFrame() const {
|
|
return Rect {
|
|
Point {contentInsets.left, contentInsets.top},
|
|
Size {frame.size.width - contentInsets.left - contentInsets.right, frame.size.height - contentInsets.top - contentInsets.bottom}
|
|
};
|
|
}
|
|
|
|
bool operator ==(const LayoutMetrics& rhs) const {
|
|
return
|
|
std::tie(this->frame, this->contentInsets, this->borderWidth, this->displayType, this->layoutDirection) ==
|
|
std::tie(rhs.frame, rhs.contentInsets, rhs.borderWidth, rhs.displayType, rhs.layoutDirection);
|
|
}
|
|
|
|
bool operator !=(const LayoutMetrics& rhs) const {
|
|
return !(*this == rhs);
|
|
}
|
|
};
|
|
|
|
/*
|
|
* Represents some undefined, not-yet-computed or meaningless value of `LayoutMetrics` type.
|
|
*/
|
|
static const LayoutMetrics EmptyLayoutMetrics = {.frame = { .size = {-1, -1}}};
|
|
|
|
} // namespace react
|
|
} // namespace facebook
|