如何在Flutter中创建文本切口?

时间:2019-11-30 15:37:58

标签: flutter flutter-layout flutter-animation

我正在尝试创建一个文本框,该文本框的文本颜色应为透明,如果我更改背景容器的颜色,则文本颜色也应发生变化。例如,考虑这张图片

enter image description here

在这里,我有一个堆栈,其中第一个元素是一个带有colour= black的容器,因此我也希望 MY TEXT 是黑色的。 我不想每次更改第一个容器的颜色时都手动设置文本的字体颜色。因为我可能打算以后用动画填充容器,并且希望在文本上运行相同的动画也。

我尝试将文本前景色的颜色设置为透明,将背景色设置为橙色,但这无济于事,文本也变为橙色,因此看不见。

2 个答案:

答案 0 :(得分:1)

您将需要使用CustomPainterTextPainter并为此使用混合模式。

example

在小部件树中:

return Container(
      color: Colors.black,
      height: 40.0,
      child: Center(
        child: CustomPaint(
          painter: MyTextPainter(text: 'Hello'),
        ),
      ),
    );

您的自定义文字画家:

class MyTextPainter extends CustomPainter {
  MyTextPainter({this.text});

  final String text;

  @override
  void paint(Canvas canvas, Size size) {
    TextPainter textPainter = TextPainter(
      text: TextSpan(
        text: text,
        style: TextStyle(
          fontSize: 30.0,
          fontWeight: FontWeight.w600,
        ),
      ),
      textDirection: TextDirection.ltr,
    );
    textPainter.layout();

    // Draw text
    final textOffset = size.center(Offset.zero) - textPainter.size.center(Offset.zero);
    final textRect = textOffset & textPainter.size;

    // Your text box (orange in your example)
    final boxRect = RRect.fromRectAndCorners(textRect.inflate(5.0));
    final boxPaint = Paint()
      ..color = Colors.orange
      ..blendMode = BlendMode.srcOut;

    canvas.saveLayer(boxRect.outerRect, Paint());
    textPainter.paint(canvas, textOffset);
    canvas.drawRRect(boxRect, boxPaint);
    canvas.restore();
  }

  @override
  bool shouldRepaint(MyTextPainter oldDelegate) => true;
}

答案 1 :(得分:0)

在寻找更多选择的同时,我发现这种非常简单的方法可以实现我想要的。

ShaderMask(
          blendMode: BlendMode.srcOut,
          child: Text(
              text,
            ),
          shaderCallback: (bounds) =>
              LinearGradient(colors: [Colors.black], stops: [0.0])
                  .createShader(bounds),
        )