Выровнять текст в созданной пользователем форме: Flutter

Я создал одну нестандартную форму во Flutter. Проблема, с которой я столкнулся, заключается в том, что я использовал ShapeBorder и назначил ему Card. Я хочу выровнять свой текст внутри нарисованного виджета, но в настоящее время он также рассматривает наш сторонний вид как часть виджета.

Вот код, который я использовал:

       Align(
    child: Container(
      height: 250,
      width: 300,
      child: Card(
        clipBehavior: Clip.hardEdge,
        shape: Shape1(factor: 0.8),
        child: Container(
          padding: EdgeInsets.only(left: 16.0),
          child: Align(
            alignment: Alignment.bottomLeft,
            child: Text(
              'Lorem Ipsum is simply dummy text of the printing and typesetting industry. Lorem Ipsum has been the industry standard dummy text ever since the 1500s, when an unknown printer took a galley of type and scrambled it to make a type specimen book',
              // style: textStyleNotoSansRegular(),
            ),
          ),
        ),
      ),
    ),
    widthFactor: 0.8,
  ),

Класс формы:

       class Shape1 extends ShapeBorder {
  final double factor;


  Shape1({this.factor});

  @override
  EdgeInsetsGeometry get dimensions => EdgeInsets.zero;

  @override
  Path getInnerPath(Rect rect, {TextDirection textDirection}) => null;

  @override
  Path getOuterPath(Rect rect, {TextDirection textDirection}) {
    return Path()
      ..moveTo(rect.bottomLeft.dx, rect.bottomLeft.dy)
      ..relativeLineTo(rect.width * factor, 0)
      ..lineTo(rect.topRight.dx, rect.topRight.dy)
      ..relativeLineTo(rect.width * -factor, 0)
      ..close();
  }

  @override
  void paint(Canvas canvas, Rect rect, {TextDirection textDirection}) {
    var path = Path()
      ..moveTo(rect.bottomLeft.dx, rect.bottomLeft.dy)
      ..relativeLineTo(rect.width * factor, 0)
      ..lineTo(rect.topRight.dx, rect.topRight.dy)
      ..relativeLineTo(rect.width * -factor, 0)
      ..close();

    var boxPainter = Paint();
    boxPainter.strokeWidth = 5;
    boxPainter.color = Colors.yellow;
    boxPainter.style = PaintingStyle.stroke;
    canvas.drawPath(path, boxPainter);

  }

  @override
  ShapeBorder scale(double t) => null;
}

Текущий результат:

Ожидаемый результат:

0 ответов

Другие вопросы по тегам