mirror of
https://github.com/status-im/react-native.git
synced 2025-01-28 10:14:49 +00:00
Move absolute layout calculation out into seperate function
Reviewed By: gkassabli Differential Revision: D4028329 fbshipit-source-id: 2903f66b028063cec0a6b3037ca7cb4d6552176d
This commit is contained in:
parent
73c5360470
commit
02fc4c8ffa
@ -931,6 +931,114 @@ static void computeChildFlexBasis(
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static void absoluteLayoutChild(
|
||||||
|
const CSSNodeRef node,
|
||||||
|
const CSSNodeRef child,
|
||||||
|
const float width,
|
||||||
|
const CSSMeasureMode widthMode,
|
||||||
|
const CSSDirection direction) {
|
||||||
|
|
||||||
|
const CSSFlexDirection mainAxis = resolveAxis(node->style.flexDirection, direction);
|
||||||
|
const CSSFlexDirection crossAxis = getCrossFlexDirection(mainAxis, direction);
|
||||||
|
const bool isMainAxisRow = isRowDirection(mainAxis);
|
||||||
|
|
||||||
|
float childWidth = CSSUndefined;
|
||||||
|
float childHeight = CSSUndefined;
|
||||||
|
CSSMeasureMode childWidthMeasureMode = CSSMeasureModeUndefined;
|
||||||
|
CSSMeasureMode childHeightMeasureMode = CSSMeasureModeUndefined;
|
||||||
|
|
||||||
|
if (isStyleDimDefined(child, CSSFlexDirectionRow)) {
|
||||||
|
childWidth = child->style.dimensions[CSSDimensionWidth] +
|
||||||
|
getMarginAxis(child, CSSFlexDirectionRow);
|
||||||
|
} else {
|
||||||
|
// If the child doesn't have a specified width, compute the width based
|
||||||
|
// on the left/right
|
||||||
|
// offsets if they're defined.
|
||||||
|
if (isLeadingPosDefined(child, CSSFlexDirectionRow) &&
|
||||||
|
isTrailingPosDefined(child, CSSFlexDirectionRow)) {
|
||||||
|
childWidth = node->layout.measuredDimensions[CSSDimensionWidth] -
|
||||||
|
(getLeadingBorder(node, CSSFlexDirectionRow) +
|
||||||
|
getTrailingBorder(node, CSSFlexDirectionRow)) -
|
||||||
|
(getLeadingPosition(child, CSSFlexDirectionRow) +
|
||||||
|
getTrailingPosition(child, CSSFlexDirectionRow));
|
||||||
|
childWidth = boundAxis(child, CSSFlexDirectionRow, childWidth);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
if (isStyleDimDefined(child, CSSFlexDirectionColumn)) {
|
||||||
|
childHeight = child->style.dimensions[CSSDimensionHeight] +
|
||||||
|
getMarginAxis(child, CSSFlexDirectionColumn);
|
||||||
|
} else {
|
||||||
|
// If the child doesn't have a specified height, compute the height
|
||||||
|
// based on the top/bottom
|
||||||
|
// offsets if they're defined.
|
||||||
|
if (isLeadingPosDefined(child, CSSFlexDirectionColumn) &&
|
||||||
|
isTrailingPosDefined(child, CSSFlexDirectionColumn)) {
|
||||||
|
childHeight = node->layout.measuredDimensions[CSSDimensionHeight] -
|
||||||
|
(getLeadingBorder(node, CSSFlexDirectionColumn) +
|
||||||
|
getTrailingBorder(node, CSSFlexDirectionColumn)) -
|
||||||
|
(getLeadingPosition(child, CSSFlexDirectionColumn) +
|
||||||
|
getTrailingPosition(child, CSSFlexDirectionColumn));
|
||||||
|
childHeight = boundAxis(child, CSSFlexDirectionColumn, childHeight);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
// If we're still missing one or the other dimension, measure the content.
|
||||||
|
if (CSSValueIsUndefined(childWidth) || CSSValueIsUndefined(childHeight)) {
|
||||||
|
childWidthMeasureMode =
|
||||||
|
CSSValueIsUndefined(childWidth) ? CSSMeasureModeUndefined : CSSMeasureModeExactly;
|
||||||
|
childHeightMeasureMode =
|
||||||
|
CSSValueIsUndefined(childHeight) ? CSSMeasureModeUndefined : CSSMeasureModeExactly;
|
||||||
|
|
||||||
|
// According to the spec, if the main size is not definite and the
|
||||||
|
// child's inline axis is parallel to the main axis (i.e. it's
|
||||||
|
// horizontal), the child should be sized using "UNDEFINED" in
|
||||||
|
// the main size. Otherwise use "AT_MOST" in the cross axis.
|
||||||
|
if (!isMainAxisRow && CSSValueIsUndefined(childWidth) && widthMode != CSSMeasureModeUndefined) {
|
||||||
|
childWidth = width;
|
||||||
|
childWidthMeasureMode = CSSMeasureModeAtMost;
|
||||||
|
}
|
||||||
|
|
||||||
|
layoutNodeInternal(child,
|
||||||
|
childWidth,
|
||||||
|
childHeight,
|
||||||
|
direction,
|
||||||
|
childWidthMeasureMode,
|
||||||
|
childHeightMeasureMode,
|
||||||
|
false,
|
||||||
|
"abs-measure");
|
||||||
|
childWidth = child->layout.measuredDimensions[CSSDimensionWidth] +
|
||||||
|
getMarginAxis(child, CSSFlexDirectionRow);
|
||||||
|
childHeight = child->layout.measuredDimensions[CSSDimensionHeight] +
|
||||||
|
getMarginAxis(child, CSSFlexDirectionColumn);
|
||||||
|
}
|
||||||
|
|
||||||
|
layoutNodeInternal(child,
|
||||||
|
childWidth,
|
||||||
|
childHeight,
|
||||||
|
direction,
|
||||||
|
CSSMeasureModeExactly,
|
||||||
|
CSSMeasureModeExactly,
|
||||||
|
true,
|
||||||
|
"abs-layout");
|
||||||
|
|
||||||
|
if (isTrailingPosDefined(child, mainAxis) &&
|
||||||
|
!isLeadingPosDefined(child, mainAxis)) {
|
||||||
|
child->layout.position[leading[mainAxis]] =
|
||||||
|
node->layout.measuredDimensions[dim[mainAxis]] -
|
||||||
|
child->layout.measuredDimensions[dim[mainAxis]] -
|
||||||
|
getTrailingPosition(child, mainAxis);
|
||||||
|
}
|
||||||
|
|
||||||
|
if (isTrailingPosDefined(child, crossAxis) &&
|
||||||
|
!isLeadingPosDefined(child, crossAxis)) {
|
||||||
|
child->layout.position[leading[crossAxis]] =
|
||||||
|
node->layout.measuredDimensions[dim[crossAxis]] -
|
||||||
|
child->layout.measuredDimensions[dim[crossAxis]] -
|
||||||
|
getTrailingPosition(child, crossAxis);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
//
|
//
|
||||||
// This is the main routine that implements a subset of the flexbox layout
|
// This is the main routine that implements a subset of the flexbox layout
|
||||||
// algorithm
|
// algorithm
|
||||||
@ -1851,115 +1959,20 @@ static void layoutNodeImpl(const CSSNodeRef node,
|
|||||||
paddingAndBorderAxisCross);
|
paddingAndBorderAxisCross);
|
||||||
}
|
}
|
||||||
|
|
||||||
// STEP 10: SIZING AND POSITIONING ABSOLUTE CHILDREN
|
|
||||||
currentAbsoluteChild = firstAbsoluteChild;
|
|
||||||
while (currentAbsoluteChild != NULL) {
|
|
||||||
// Now that we know the bounds of the container, perform layout again on the
|
|
||||||
// absolutely-positioned children.
|
|
||||||
if (performLayout) {
|
if (performLayout) {
|
||||||
float childWidth = CSSUndefined;
|
// STEP 10: SIZING AND POSITIONING ABSOLUTE CHILDREN
|
||||||
float childHeight = CSSUndefined;
|
for (currentAbsoluteChild = firstAbsoluteChild;
|
||||||
CSSMeasureMode childWidthMeasureMode = CSSMeasureModeUndefined;
|
currentAbsoluteChild != NULL;
|
||||||
CSSMeasureMode childHeightMeasureMode = CSSMeasureModeUndefined;
|
currentAbsoluteChild = currentAbsoluteChild->nextChild) {
|
||||||
|
absoluteLayoutChild(
|
||||||
if (isStyleDimDefined(currentAbsoluteChild, CSSFlexDirectionRow)) {
|
node,
|
||||||
childWidth = currentAbsoluteChild->style.dimensions[CSSDimensionWidth] +
|
currentAbsoluteChild,
|
||||||
getMarginAxis(currentAbsoluteChild, CSSFlexDirectionRow);
|
availableInnerWidth,
|
||||||
} else {
|
widthMeasureMode,
|
||||||
// If the child doesn't have a specified width, compute the width based
|
direction);
|
||||||
// on the left/right
|
|
||||||
// offsets if they're defined.
|
|
||||||
if (isLeadingPosDefined(currentAbsoluteChild, CSSFlexDirectionRow) &&
|
|
||||||
isTrailingPosDefined(currentAbsoluteChild, CSSFlexDirectionRow)) {
|
|
||||||
childWidth = node->layout.measuredDimensions[CSSDimensionWidth] -
|
|
||||||
(getLeadingBorder(node, CSSFlexDirectionRow) +
|
|
||||||
getTrailingBorder(node, CSSFlexDirectionRow)) -
|
|
||||||
(getLeadingPosition(currentAbsoluteChild, CSSFlexDirectionRow) +
|
|
||||||
getTrailingPosition(currentAbsoluteChild, CSSFlexDirectionRow));
|
|
||||||
childWidth = boundAxis(currentAbsoluteChild, CSSFlexDirectionRow, childWidth);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
if (isStyleDimDefined(currentAbsoluteChild, CSSFlexDirectionColumn)) {
|
|
||||||
childHeight = currentAbsoluteChild->style.dimensions[CSSDimensionHeight] +
|
|
||||||
getMarginAxis(currentAbsoluteChild, CSSFlexDirectionColumn);
|
|
||||||
} else {
|
|
||||||
// If the child doesn't have a specified height, compute the height
|
|
||||||
// based on the top/bottom
|
|
||||||
// offsets if they're defined.
|
|
||||||
if (isLeadingPosDefined(currentAbsoluteChild, CSSFlexDirectionColumn) &&
|
|
||||||
isTrailingPosDefined(currentAbsoluteChild, CSSFlexDirectionColumn)) {
|
|
||||||
childHeight = node->layout.measuredDimensions[CSSDimensionHeight] -
|
|
||||||
(getLeadingBorder(node, CSSFlexDirectionColumn) +
|
|
||||||
getTrailingBorder(node, CSSFlexDirectionColumn)) -
|
|
||||||
(getLeadingPosition(currentAbsoluteChild, CSSFlexDirectionColumn) +
|
|
||||||
getTrailingPosition(currentAbsoluteChild, CSSFlexDirectionColumn));
|
|
||||||
childHeight = boundAxis(currentAbsoluteChild, CSSFlexDirectionColumn, childHeight);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
// If we're still missing one or the other dimension, measure the content.
|
|
||||||
if (CSSValueIsUndefined(childWidth) || CSSValueIsUndefined(childHeight)) {
|
|
||||||
childWidthMeasureMode =
|
|
||||||
CSSValueIsUndefined(childWidth) ? CSSMeasureModeUndefined : CSSMeasureModeExactly;
|
|
||||||
childHeightMeasureMode =
|
|
||||||
CSSValueIsUndefined(childHeight) ? CSSMeasureModeUndefined : CSSMeasureModeExactly;
|
|
||||||
|
|
||||||
// According to the spec, if the main size is not definite and the
|
|
||||||
// child's inline axis is parallel to the main axis (i.e. it's
|
|
||||||
// horizontal), the child should be sized using "UNDEFINED" in
|
|
||||||
// the main size. Otherwise use "AT_MOST" in the cross axis.
|
|
||||||
if (!isMainAxisRow && CSSValueIsUndefined(childWidth) &&
|
|
||||||
!CSSValueIsUndefined(availableInnerWidth)) {
|
|
||||||
childWidth = availableInnerWidth;
|
|
||||||
childWidthMeasureMode = CSSMeasureModeAtMost;
|
|
||||||
}
|
|
||||||
|
|
||||||
layoutNodeInternal(currentAbsoluteChild,
|
|
||||||
childWidth,
|
|
||||||
childHeight,
|
|
||||||
direction,
|
|
||||||
childWidthMeasureMode,
|
|
||||||
childHeightMeasureMode,
|
|
||||||
false,
|
|
||||||
"abs-measure");
|
|
||||||
childWidth = currentAbsoluteChild->layout.measuredDimensions[CSSDimensionWidth] +
|
|
||||||
getMarginAxis(currentAbsoluteChild, CSSFlexDirectionRow);
|
|
||||||
childHeight = currentAbsoluteChild->layout.measuredDimensions[CSSDimensionHeight] +
|
|
||||||
getMarginAxis(currentAbsoluteChild, CSSFlexDirectionColumn);
|
|
||||||
}
|
|
||||||
|
|
||||||
layoutNodeInternal(currentAbsoluteChild,
|
|
||||||
childWidth,
|
|
||||||
childHeight,
|
|
||||||
direction,
|
|
||||||
CSSMeasureModeExactly,
|
|
||||||
CSSMeasureModeExactly,
|
|
||||||
true,
|
|
||||||
"abs-layout");
|
|
||||||
|
|
||||||
if (isTrailingPosDefined(currentAbsoluteChild, mainAxis) &&
|
|
||||||
!isLeadingPosDefined(currentAbsoluteChild, mainAxis)) {
|
|
||||||
currentAbsoluteChild->layout.position[leading[mainAxis]] =
|
|
||||||
node->layout.measuredDimensions[dim[mainAxis]] -
|
|
||||||
currentAbsoluteChild->layout.measuredDimensions[dim[mainAxis]] -
|
|
||||||
getTrailingPosition(currentAbsoluteChild, mainAxis);
|
|
||||||
}
|
|
||||||
|
|
||||||
if (isTrailingPosDefined(currentAbsoluteChild, crossAxis) &&
|
|
||||||
!isLeadingPosDefined(currentAbsoluteChild, crossAxis)) {
|
|
||||||
currentAbsoluteChild->layout.position[leading[crossAxis]] =
|
|
||||||
node->layout.measuredDimensions[dim[crossAxis]] -
|
|
||||||
currentAbsoluteChild->layout.measuredDimensions[dim[crossAxis]] -
|
|
||||||
getTrailingPosition(currentAbsoluteChild, crossAxis);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
currentAbsoluteChild = currentAbsoluteChild->nextChild;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
// STEP 11: SETTING TRAILING POSITIONS FOR CHILDREN
|
// STEP 11: SETTING TRAILING POSITIONS FOR CHILDREN
|
||||||
if (performLayout) {
|
|
||||||
const bool needsMainTrailingPos =
|
const bool needsMainTrailingPos =
|
||||||
mainAxis == CSSFlexDirectionRowReverse || mainAxis == CSSFlexDirectionColumnReverse;
|
mainAxis == CSSFlexDirectionRowReverse || mainAxis == CSSFlexDirectionColumnReverse;
|
||||||
const bool needsCrossTrailingPos =
|
const bool needsCrossTrailingPos =
|
||||||
|
Loading…
x
Reference in New Issue
Block a user