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 horizontalPadding = this.horizontalPadding.toLpUnder(options);
final verticalPadding = this.verticalPadding.toLpUnder(options);
Widget widget = Stack(
children: <Widget>[
Container(
// color: backgroundcolor,
decoration: hasBorder
? BoxDecoration(
color: backgroundcolor,
border: Border.all(
// TODO minRuleThickness
width:
options.fontMetrics.fboxrule.cssEm.toLpUnder(options),
color: bordercolor ?? options.color,
),
)
: null,
child: Padding(
padding: EdgeInsets.symmetric(
vertical: verticalPadding,
horizontal: horizontalPadding,
),
child: childBuildResults[0]!.widget,
),
),
if (notation.contains('updiagonalstrike'))
Positioned(
left: 0,
right: 0,
top: 0,
bottom: 0,
child: LayoutBuilder(
builder: (context, constraints) => CustomPaint(
size: constraints.biggest,
painter: LinePainter(
startRelativeX: 0,
startRelativeY: 1,
endRelativeX: 1,
endRelativeY: 0,
lineWidth: 0.046.cssEm.toLpUnder(options),
color: bordercolor ?? options.color,
),
),
),
),
if (notation.contains('downdiagnoalstrike'))
Positioned(
left: 0,
right: 0,
top: 0,
bottom: 0,
child: LayoutBuilder(
builder: (context, constraints) => CustomPaint(
size: constraints.biggest,
painter: LinePainter(
startRelativeX: 0,
startRelativeY: 0,
endRelativeX: 1,
endRelativeY: 1,
lineWidth: 0.046.cssEm.toLpUnder(options),
color: bordercolor ?? options.color,
),
),
),
),
],
);
if (notation.contains('horizontalstrike')) {
widget = CustomLayout<int>(
delegate: HorizontalStrikeDelegate(
vShift: options.fontMetrics.xHeight.cssEm.toLpUnder(options) / 2,
ruleThickness:
options.fontMetrics.defaultRuleThickness.cssEm.toLpUnder(options),
color: bordercolor ?? options.color,
),
children: <Widget>[
CustomLayoutId(
id: 0,
child: widget,
),
],
);
}
return BuildResult(
options: options,
widget: widget,
);
}