buildWidget method
Compose Flutter widget with child widgets already built
Subclasses should override this method. This method provides a general description of the layout of this math node. The child nodes are built in prior. This method is only responsible for the placement of those child widgets accroding to the layout & other interactions.
Please ensure children works in the same order as updateChildren, computeChildOptions, and buildWidget.
Implementation
@override
BuildResult buildWidget(
MathOptions options, List<BuildResult?> childBuildResults) {
final baseResult = childBuildResults[1]!;
final indexResult = childBuildResults[0];
return BuildResult(
options: options,
widget: CustomLayout<_SqrtPos>(
delegate: SqrtLayoutDelegate(
options: options,
baseOptions: baseResult.options,
// indexOptions: indexResult?.options,
),
children: <Widget>[
CustomLayoutId(
id: _SqrtPos.base,
child: MinDimension(
minHeight: options.fontMetrics.xHeight.cssEm.toLpUnder(options),
topPadding: 0,
child: baseResult.widget,
),
),
CustomLayoutId(
id: _SqrtPos.surd,
// we use IgnorePointer here to ignore root image during hit test,
// so 'SelectionManagerMixin.getRenderLineAtOffset' can find
// render lines in the base widget
child: IgnorePointer(
child: LayoutBuilderPreserveBaseline(
builder: (context, constraints) => sqrtSvg(
minDelimiterHeight: constraints.minHeight,
baseWidth: constraints.minWidth,
options: options,
),
),
),
),
if (index != null)
CustomLayoutId(
id: _SqrtPos.ind,
child: indexResult!.widget,
),
],
),
);
}