Solve the bug related to baseline height

Summary:
This diff fixes the height calculation logic for the nodes with baseline. Before height calculation for baseline was done at wrong place.

The task was created due to the regression caused by D9219678.

Reviewed By: IanChilds

Differential Revision: D9421551

fbshipit-source-id: 3fbb738314130b346c4186ec45d00c9ea63bc9f4
This commit is contained in:
Pritesh Nandgaonkar 2018-08-21 17:23:25 -07:00 committed by Facebook Github Bot
parent f884a1be69
commit d85226f539

View File

@ -2511,6 +2511,9 @@ static void YGJustifyMainAxis(
leadingPaddingAndBorderMain + leadingMainDim; leadingPaddingAndBorderMain + leadingMainDim;
collectedFlexItemsValues.crossDim = 0; collectedFlexItemsValues.crossDim = 0;
float maxAscentForCurrentLine = 0;
float maxDescentForCurrentLine = 0;
bool isNodeBaselineLayout = YGIsBaselineLayout(node);
for (uint32_t i = startOfLineIndex; for (uint32_t i = startOfLineIndex;
i < collectedFlexItemsValues.endOfLineIndex; i < collectedFlexItemsValues.endOfLineIndex;
i++) { i++) {
@ -2575,12 +2578,31 @@ static void YGJustifyMainAxis(
collectedFlexItemsValues.mainDim += betweenMainDim + collectedFlexItemsValues.mainDim += betweenMainDim +
YGNodeDimWithMargin(child, mainAxis, availableInnerWidth); YGNodeDimWithMargin(child, mainAxis, availableInnerWidth);
if (isNodeBaselineLayout) {
// If the child is baseline aligned then the cross dimension is
// calculated by adding maxAscent and maxDescent from the baseline.
const float ascent = YGBaseline(child) +
YGUnwrapFloatOptional(child->getLeadingMargin(
YGFlexDirectionColumn, availableInnerWidth));
const float descent =
child->getLayout().measuredDimensions[YGDimensionHeight] +
YGUnwrapFloatOptional(child->getMarginForAxis(
YGFlexDirectionColumn, availableInnerWidth)) -
ascent;
maxAscentForCurrentLine =
YGFloatMax(maxAscentForCurrentLine, ascent);
maxDescentForCurrentLine =
YGFloatMax(maxDescentForCurrentLine, descent);
} else {
// The cross dimension is the max of the elements dimension since // The cross dimension is the max of the elements dimension since
// there can only be one element in that cross dimension. // there can only be one element in that cross dimension in the case
// when the items are not baseline aligned
collectedFlexItemsValues.crossDim = YGFloatMax( collectedFlexItemsValues.crossDim = YGFloatMax(
collectedFlexItemsValues.crossDim, collectedFlexItemsValues.crossDim,
YGNodeDimWithMargin(child, crossAxis, availableInnerWidth)); YGNodeDimWithMargin(child, crossAxis, availableInnerWidth));
} }
}
} else if (performLayout) { } else if (performLayout) {
child->setLayoutPosition( child->setLayoutPosition(
childLayout.position[pos[mainAxis]] + childLayout.position[pos[mainAxis]] +
@ -2590,6 +2612,11 @@ static void YGJustifyMainAxis(
} }
} }
collectedFlexItemsValues.mainDim += trailingPaddingAndBorderMain; collectedFlexItemsValues.mainDim += trailingPaddingAndBorderMain;
if (isNodeBaselineLayout) {
collectedFlexItemsValues.crossDim =
maxAscentForCurrentLine + maxDescentForCurrentLine;
}
} }
// //
@ -3187,9 +3214,9 @@ static void YGNodelayoutImpl(
// STEP 8: MULTI-LINE CONTENT ALIGNMENT // STEP 8: MULTI-LINE CONTENT ALIGNMENT
// currentLead stores the size of the cross dim // currentLead stores the size of the cross dim
float currentLead = leadingPaddingAndBorderCross;
if (performLayout && (lineCount > 1 || YGIsBaselineLayout(node))) { if (performLayout && (lineCount > 1 || YGIsBaselineLayout(node))) {
float crossDimLead = 0; float crossDimLead = 0;
float currentLead = leadingPaddingAndBorderCross;
if (!YGFloatIsUndefined(availableInnerCrossDim)) { if (!YGFloatIsUndefined(availableInnerCrossDim)) {
const float remainingAlignContentDim = const float remainingAlignContentDim =
availableInnerCrossDim - totalLineCrossDim; availableInnerCrossDim - totalLineCrossDim;
@ -3372,7 +3399,6 @@ static void YGNodelayoutImpl(
} }
} }
} }
currentLead += lineHeight; currentLead += lineHeight;
} }
} }
@ -3452,18 +3478,6 @@ static void YGNodelayoutImpl(
dim[crossAxis]); dim[crossAxis]);
} }
if (performLayout &&
node->getStyle().dimensions[dim[crossAxis]].unit == YGUnitAuto &&
node->getStyle().alignItems == YGAlignBaseline) {
node->setLayoutMeasuredDimension(
YGNodeBoundAxis(
node,
crossAxis,
currentLead + paddingAndBorderAxisRow,
crossAxisownerSize,
ownerWidth),
dim[crossAxis]);
}
// As we only wrapped in normal direction yet, we need to reverse the // As we only wrapped in normal direction yet, we need to reverse the
// positions on wrap-reverse. // positions on wrap-reverse.
if (performLayout && node->getStyle().flexWrap == YGWrapWrapReverse) { if (performLayout && node->getStyle().flexWrap == YGWrapWrapReverse) {