flutter TextPainter 的用法

本文章基于 Flutter 3.16.2 Dart SDK 3.2.2。

TextPainter 是 Flutter 中用于在 Canvas 上绘制文本的类。它允许您在自定义的 CustomPainter 中使用 drawText 方法来绘制文本,并可以控制文本的位置、颜色、字体等属性。

import 'package:flutter/material.dart';class CustomTextPainter extends CustomPainter {void paint(Canvas canvas, Size size) {TextPainter textPainter = TextPainter(text: TextSpan(text: 'Hello, Flutter!',style: TextStyle(color: Colors.black, fontSize: 24),),textAlign: TextAlign.center,textDirection: TextDirection.ltr,)..layout();textPainter.paint(canvas, Offset(0, 0));}bool shouldRepaint(CustomPainter oldDelegate) {return oldDelegate != this;}
}class CustomTextWidget extends StatelessWidget {Widget build(BuildContext context) {return CustomPaint(size: Size(200, 100),painter: CustomTextPainter(),);}
}void main() {runApp(MaterialApp(home: Scaffold(appBar: AppBar(title: Text('Custom Text Painter Example'),),body: Center(child: CustomTextWidget(),),),));
}

运行效果如下:就是绘制出一条普通的文本

图片

本文案例使用 DartPad 在线测试 https://dartpad.cn/?id

现在,绘制一条文本,并在文本下绘制一条下划线(当然你可以是其他任意的图形),核心代码如下

import 'package:flutter/material.dart';class UnderlinePainter extends CustomPainter {void paint(Canvas canvas, Size size) {Paint paint = Paint()..color = Colors.black..strokeCap = StrokeCap.round..strokeWidth = 4; // 设置下划线宽度// 绘制文本TextSpan textSpan = TextSpan(text: 'Hello, Flutter!', // 文本内容style: TextStyle(color: Colors.black),);TextPainter textPainter = TextPainter(text: textSpan,textAlign: TextAlign.center,textDirection: TextDirection.ltr)..layout();textPainter.paint(canvas, Offset(0, 0));// 绘制下划线canvas.drawLine(new Offset(0, textPainter.height),new Offset(size.width, textPainter.height), paint);}bool shouldRepaint(CustomPainter oldDelegate) {return oldDelegate != this;}
}

在这里插入图片描述

TextSpan是一个用于表示文本的类,TextSpan包含以下属性:
  • text: 要绘制的文本内容。

  • style: 文本的样式,包括字体、颜色、大小等。

  • alignment: 文本的对齐方式。

  • textDirection: 文本的方向,例如从左到右或从右到左。

TextPainter类用于在Canvas上绘制文本,常用属性包括:
  • text:要绘制的文本内容。

  • style:文本的样式,包括字体、颜色、大小等。

  • alignment:文本的对齐方式。

  • textDirection:文本的方向,例如从左到右或从右到左。

  • color:文本的颜色。

  • fontSize:文本的字体大小。

  • fontFamily:文本的字体类型。

  • textAlign:文本的对齐方式,例如居中、左对齐、右对齐等。

  • maxLines:文本的最大行数,超过这个行数将会出现溢出情况。

  • overflow:文本的溢出方式,例如裁剪、滚动等。

  • textScaleFactor:文本的缩放因子,可以用于实现缩放效果。

  • decorationColor:文本装饰的颜色,例如线条的颜色。

  • decoration:文本装饰的类型,例如删除线、上划线、下划线等。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.hqwc.cn/news/259471.html

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

管理类联考——数学——真题篇——按题型分类——充分性判断题——秒杀

题型结构 问题求解:通过计算求解,从五个选项中选出一个正确答案。条件充分性判断:问所给的条件(1)(2)能否推出题设的结论,共有五个选项,从中选出正确的一个。&#xff0…

demo(七) zuul请求过滤

在之前的基础上,实现请求过滤功能: 一、介绍: 1、背景:为实现对用户请求的安全校验和权限控制,用于对签名验证、权限校验的过滤器或拦截器。 2、实现方法:实现请求过滤只需继承ZuulFilter并重写方法&…

功能点估算常见问题,AI时代下成本估算探索

CoCode学院:功能点估算常见问题 AI时代下成本估算探索 功能点估算常见问题,AI时代下成本估算探索 功能点估算常见问题 资深软件造价评估专家李培圣 直播内容 1、功能点估算概述 2、功能点估算的常见问题 3、现场答疑 直播时间 12月13日 (周三) 20&a…

什么是自动化测试?什么情况下使用?

什么是自动化测试? 自动化测试是指把以人为驱动的测试行为转化为机器执行的过程。实际上自动化测试往往通过一些测试工具或框架,编写自动化测试脚本,来模拟手工测试过程。比如说,在项目迭代过程中,持续的回归测试是一项非常枯燥…

HarmonyOS创建JavaScript(类 Web开发模式)项目

上文 HarmonyOS带大家创建自己的第一个Page页面并实现路由跳转(ArkTS)带大家创建了我们项目中第一个自己创建的page 并完成了一个跳转逻辑的编写 上文的开发模式是 ArkTS 的 也被称为 声明式开发范式 还有一种 javaScript的 类Web开发模式 这种方式就类似于我们传统的前端开发模…

元宇宙真的凉凉了吗?

AI和元宇宙作为引领技术和产业发展的两个并行元素正在加速融合,激发出行业强大的创新力。 这里重点讲一下元宇宙。它是建立在区块链之上的虚拟世界,去中心化平台让用户拥有所有权和自治权。通过沉浸式的体验,让虚拟更接近现实。 随着我国元宇…

【numpy】np.triu的使用

every blog every motto: You can do more than you think. https://blog.csdn.net/weixin_39190382?typeblog 0. 前言 np.triu使用,参数辨析 1. 正文 import numpy as nparr np.ones((3,3)) print(arr)print(np.triu(arr,0))0时,包含对角线上的元…

Leetcode—290.单词规律【简单】

2023每日刷题&#xff08;五十一&#xff09; Leetcode—290.单词规律 实现代码 class Solution { public:bool wordPattern(string pattern, string s) {unordered_map<char, string> m1;unordered_map<string, char> m2;stringstream stro(s);string tmp;for(a…

docker安装一主一从MySQL数据库步骤

安装MySQL主从复制 ①宿主机创建以下目录 /mydata/mysql-master/log 命令&#xff1a;mkdir -p /mydata/mysql-master/log /mydata/mysql-master/data 命令&#xff1a;mkdir -p /mydata/mysql-master/data /mydata/mysql-master/conf 命令&#xff1a;mkdir -p /mydata/mysql-…

层流燃烧模拟的技术研究与实践

层流燃烧模拟的技术研究与实践 一、引言 层流燃烧,作为一种基础而重要的燃烧类型,广泛存在于各种工业应用中,如发动机、燃气轮机、燃烧室等。为了更好地理解和优化这一过程,科研人员运用计算流体动力学(CFD)工具进行模拟,以期能更深入地洞察其内在机制。 二、层流燃烧…

uniapp实战 —— 竖排多级分类展示

效果预览 完整范例代码 页面 src\pages\category\category.vue <script setup lang"ts"> import { getCategoryTopAPI } from /apis/category import type { CategoryTopItem } from /types/category import { onLoad } from dcloudio/uni-app import { compu…

Anaconda3常用命令汇总

winR打开cmd窗口&#xff0c;以下所有命令都是通过cmd窗口执行 1、查看Anaconda3版本&#xff1a; conda -V 或者 conda --version 如果无法识别“conda”命令&#xff0c;请自行设置环境变量 环境变量设置&#xff1a; 二、环境管理命令汇总 1、查看所有虚拟环境 cond…