paint method

  1. @override
void paint(
  1. Canvas canvas,
  2. Rect rect, {
  3. TextDirection? textDirection,
  4. BoxShape shape = BoxShape.rectangle,
  5. BorderRadius? borderRadius,
})
override

Paints the border within the given Rect on the given Canvas.

Uniform borders and non-uniform borders with similar colors and styles are more efficient to paint than more complex borders.

You can provide a BoxShape to draw the border on. If the shape in BoxShape.circle, there is the requirement that the border has uniform color and style.

If you specify a rectangular box shape (BoxShape.rectangle), then you may specify a BorderRadius. If a borderRadius is specified, there is the requirement that the border has uniform color and style.

The getInnerPath and getOuterPath methods do not know about the shape and borderRadius arguments.

The textDirection argument is not used by this paint method.

See also:

  • paintBorder, which is used if the border has non-uniform colors or styles and no borderRadius.
  • pub.dev/packages/non_uniform_border, a package that implements a Non-Uniform Border on ShapeBorder, which is used by Material Design buttons and other widgets, under the "shape" field.

Implementation

@override
void paint(
  Canvas canvas,
  Rect rect, {
  TextDirection? textDirection,
  BoxShape shape = BoxShape.rectangle,
  BorderRadius? borderRadius,
}) {
  if (isUniform) {
    switch (top.style) {
      case BorderStyle.none:
        return;
      case BorderStyle.solid:
        switch (shape) {
          case BoxShape.circle:
            assert(borderRadius == null,
                'A borderRadius can only be given for rectangular boxes.');
            _paintUniformBorderWithCircle(canvas, rect, top as TxBorderSide);
            break;
          case BoxShape.rectangle:
            if (borderRadius != null) {
              _paintUniformBorderWithRadius(
                canvas,
                rect,
                top as TxBorderSide,
                borderRadius,
              );
              return;
            }
            _paintUniformBorderWithRectangle(
              canvas,
              rect,
              top as TxBorderSide,
            );
            break;
        }
        return;
    }
  }

  assert(() {
    if (borderRadius != null) {
      throw FlutterError.fromParts(<DiagnosticsNode>[
        ErrorSummary(
            'A borderRadius can only be given for a uniform TxBorder.'),
        ErrorDescription('The following is not uniform:'),
        if (!_colorIsUniform) ErrorDescription('TxBorderSide.color'),
        if (!_widthIsUniform) ErrorDescription('TxBorderSide.width'),
        if (!_styleIsUniform) ErrorDescription('TxBorderSide.style'),
      ]);
    }
    return true;
  }());
  assert(() {
    if (shape != BoxShape.rectangle) {
      throw FlutterError.fromParts(<DiagnosticsNode>[
        ErrorSummary(
            'A TxBorder can only be drawn as a circle if it is uniform'),
        ErrorDescription('The following is not uniform:'),
        if (!_colorIsUniform) ErrorDescription('TxBorderSide.color'),
        if (!_widthIsUniform) ErrorDescription('TxBorderSide.width'),
        if (!_styleIsUniform) ErrorDescription('TxBorderSide.style'),
      ]);
    }
    return true;
  }());

  paintTxBorder(
    canvas,
    rect,
    top: top as TxBorderSide,
    right: right as TxBorderSide,
    bottom: bottom as TxBorderSide,
    left: left as TxBorderSide,
  );
}