Flutter Text 下面有两个默认的下划线,和设置划掉效果

Text的decoration默认是TextDecoration.none

不知道什么原因,有时候定义的Text下面会出现两个下划线,如下图:

此时要去掉下面的下划线只需要在style下面的TextStyle增加属性decoration: TextDecoration.none

 

其次加个扩展,若想加划掉的效果,如下图:

可通过设置如下属性:

  • 5
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 4
    评论
Flutter Text Widget是Flutter Framework中用于呈现文本的Widget之一。该Widget可以显示单行或者多行文本,并且支持文字样式、对齐方式、文本溢出方式、行间距等多种属性的设置。在使用Text Widget的过程中,我们可能需要自定义下划线的样式来美化文本。 实现自定义下划线有多种方法,下面我们介绍其中一种方法: 在Text Widget的child组件内添加CustomPaint Widget,通过CustomPainter来绘制下划线。 例如,下面的示例演示了如何使用CustomPainter来绘制一条黑色且宽度为2.0的下划线。 ```dart Text( 'Hello, world!', style: TextStyle(fontSize: 24), textAlign: TextAlign.center, textDirection: TextDirection.ltr, maxLines: 1, overflow: TextOverflow.ellipsis, textScaleFactor: 1.5, // 添加下划线 child: CustomPaint( painter: LinePainter(), child: Text('Hello, world!'), ), ) // LinePainter绘制下划线 class LinePainter extends CustomPainter { @override void paint(Canvas canvas, Size size) { final paint = Paint() ..color = Colors.black ..strokeWidth = 2.0; canvas.drawLine(Offset.zero, Offset(size.width, 0), paint); } @override bool shouldRepaint(CustomPainter oldDelegate) => false; } ``` 通过上面的代码,我们可以看到,在Text Widget的child组件中添加了一个CustomPaint Widget,并通过LinePainter来绘制了下划线。在LinePainter中,我们通过canvas.drawLine方法来画一条宽度为2.0的黑色直线。同时,由于CustomPainter是在Widget绘制完成后才执行的,因此下划线可以自动适应Text Widget的宽度。 在实现自定义下划线的时候,我们可以根据需求来自定义不同的下划线样式。例如,可以通过paint.color、paint.strokeWidth等属性来设置下划线的颜色、宽度等。如果需要实现复杂的下划线效果,也可以通过绘制曲线、添加阴影、使用渐变色等方式来实现。 总结来说,通过在Text Widget的child组件中添加CustomPaint Widget,再通过CustomPainter来绘制下划线,是一种简单且灵活的自定义下划线的方法。在实际开发中,我们可以根据实际需求来灵活应用,实现不同样式的下划线

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 4
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值