Flutter文本自适应插件text_sizer_plus的使用
Flutter文本自适应插件text_sizer_plus的使用
TextSizerPlus
是一个 Flutter 插件,可以自动调整文本大小以完美地适应其边界。本文将详细介绍如何使用 TextSizerPlus
,并提供一个完整的示例代码。
目录
用法
TextSizerPlus
的行为与 Text
完全相同,唯一的区别是它会调整文本大小以适应其边界。
TextSizerPlus(
'The text to display',
style: TextStyle(fontSize: 20),
maxLines: 2,
)
maxLines
maxLines
参数的工作方式与 Text
小部件相同。如果没有指定 maxLines
参数,TextSizerPlus
只会根据可用宽度和高度来适配文本。
TextSizerPlus(
'A really long String',
style: TextStyle(fontSize: 30),
maxLines: 2,
)
minFontSize & maxFontSize
TextSizerPlus
从 TextStyle.fontSize
开始,测量结果文本并重新缩放以适应其边界。你可以设置允许的结果字体大小范围。
minFontSize
指定最小可能的字体大小。如果文本仍然无法适应,将根据overflow
处理。默认minFontSize
是 12。maxFontSize
设置最大的可能字体大小。这在TextStyle
继承字体大小时非常有用。
TextSizerPlus(
'A really long String',
style: TextStyle(fontSize: 30),
minFontSize: 18,
maxLines: 4,
overflow: TextOverflow.ellipsis,
)
group
你可以同步多个 TextSizerPlus
的字体大小。它们会适应各自的边界,并且所有 TextSizerPlus
在同一组中的字体大小相同。这意味着它们会调整字体大小以适应组中最小的有效字体大小。
var myGroup = TextSizerGroup();
TextSizerPlus(
'Text 1',
group: myGroup,
);
TextSizerPlus(
'Text 2',
group: myGroup,
);
stepGranularity
TextSizerPlus
会尝试每个字体大小,从 TextStyle.fontSize
开始,直到文本适应其边界。stepGranularity
指定每次减少字体大小的步长。通常,此值不应低于 1 以获得最佳性能。
TextSizerPlus(
'A really long String',
style: TextStyle(fontSize: 40),
minFontSize: 10,
stepGranularity: 10,
maxLines: 4,
overflow: TextOverflow.ellipsis,
)
presetFontSizes
如果你只想允许特定的字体大小,可以使用 presetFontSizes
设置。如果设置了 presetFontSizes
,minFontSize
、maxFontSize
和 stepGranularity
将被忽略。
TextSizerPlus(
'A really long String',
presetFontSizes: [40, 20, 14],
maxLines: 4,
)
overflowReplacement
如果文本溢出且无法适应其边界,将显示此小部件。这可以防止文本变得太小而难以阅读。
TextSizerPlus(
'A String tool long to display without extreme scaling or overflow.',
maxLines: 1,
overflowReplacement: Text('Sorry String too long'),
)
富文本
你也可以使用富文本(如不同的文本样式或链接)与 TextSizerPlus
。只需使用 TextSizerPlus.rich()
构造函数(与 Text.rich()
构造函数完全相同)。
TextSizerPlus.rich(
TextSpan(text: 'A really long String'),
style: TextStyle(fontSize: 20),
minFontSize: 5,
)
参数
参数 | 描述 |
---|---|
key * |
控制一个小部件如何替换树中的另一个小部件 |
textKey |
为生成的 Text 小部件设置键 |
style * |
如果非空,则用于此文本的样式 |
minFontSize |
自动调整文本大小时使用的最小文本大小约束 *如果设置了 presetFontSizes ,则忽略此参数 |
maxFontSize |
自动调整文本大小时使用的最大文本大小约束 *如果设置了 presetFontSizes ,则忽略此参数 |
stepGranularity |
字体大小适应约束时的步长 |
presetFontSizes |
预定义所有可能的字体大小 *重要: presetFontSizes 必须按降序排列 |
group |
同步多个 TextSizerPlus 的大小 |
textAlign * |
文本应如何水平对齐 |
textDirection * |
文本的方向性。这决定了 textAlign 值(如 TextAlign.start 和 TextAlign.end )如何解释 |
locale * |
用于选择字体,当相同的 Unicode 字符可以根据语言环境不同而渲染时 |
softWrap * |
文本是否应在软换行处断开 |
wrapWords |
单词是否应在一行中不适应时换行 *默认为 true 以行为 Text |
overflow * |
视觉溢出应如何处理 |
overflowReplacement |
如果文本溢出且无法适应其边界,将显示此小部件 |
textScaleFactor * |
每个逻辑像素的字体像素数。也影响 minFontSize 、maxFontSize 和 presetFontSizes |
maxLines |
文本可跨越的最大行数 |
semanticsLabel * |
此文本的替代语义标签 |
带有 * 的参数与 Text
的行为完全相同。
性能
TextSizerPlus
非常快。事实上,你可以将所有 Text
小部件替换为 TextSizerPlus
。尽管如此,你不应该在 TextStyle
中使用不合理的高 fontSize
。例如,如果知道文本永远不会大于 30,不要将 fontSize
设置为 1000。
如果字体大小范围非常大,考虑增加 stepGranularity
。
故障排除
缺少边界
如果 TextSizerPlus
溢出或不调整文本大小,你应该检查它是否有受约束的宽度和高度。
错误 代码:
Row(
children: [
TextSizerPlus(
'Here is a very long text, which should be resized',
maxLines: 1,
),
],
)
因为 Row
和其他小部件(如 Container
、Column
或 ListView
)不会约束其子小部件,所以文本会溢出。你可以通过限制 TextSizerPlus
来解决这个问题。在 Row
和 Column
的情况下,将其包装在 Expanded
中,或者使用 SizedBox
或其他具有固定宽度(和高度)的小部件。
正确 代码:
Row(
children: [
Expanded( // 限制 TextSizerPlus 到 Row 的宽度
child: TextSizerPlus(
'Here is a very long text, which should be resized',
maxLines: 1,
),
),
],
)
进一步的解释可以在这里找到:Stack Overflow。如果你仍然有问题,请打开一个 issue。
minFontSize 太大
TextSizerPlus
不会将文本大小调整到低于 minFontSize
,默认值为 12。如果你使用 TextSizerPlus.rich()
,这种情况很容易发生。
错误 代码:
TextSizerPlus.rich(
TextSpan(
text: 'Text that will not be resized correctly in some cases',
style: TextStyle(fontSize: 200),
),
)
这段富文本没有样式,因此会回退到默认样式(可能是 fontSize = 14
)。它有一个隐式的 minFontSize
为 12,这意味着它可以调整到最多 86% 的原始大小(14 -> 12)。只需将 minFontSize
设置为 0 或在 TextSizerPlus
中添加 style: TextStyle(fontSize: 200)
。
注意:如果你使用第一种选项,还应考虑降低 stepGranularity
。否则,调整大小的步骤会非常大。
正确 代码:
TextSizerPlus.rich(
TextSpan(
text: 'Text that will be resized correctly',
style: TextStyle(fontSize: 200),
),
minFontSize: 0,
stepGranularity: 0.1,
)
MIT 许可证
Copyright (c) 2018 Simon Leier
Permission is hereby granted, free of charge, to any person obtaining a copy
of this software and associated documentation files (the "Software"), to deal
in the Software without restriction, including without limitation the rights
to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
copies of the Software, and to permit persons to whom the Software is
furnished to do so, subject to the following conditions:
The above copyright notice and this permission notice shall be included in all
copies or substantial portions of the Software.
THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
SOFTWARE.
示例代码
以下是一个完整的示例代码,展示了如何使用 TextSizerPlus
:
import 'package:flutter/material.dart';
import 'package:text_sizer_plus/text_sizer_plus.dart';
void main() {
runApp(App());
}
class App extends StatelessWidget {
@override
Widget build(BuildContext context) {
return MaterialApp(
home: Scaffold(
body: Center(
child: SizedBox(
width: 200,
height: 140,
child: TextSizerPlus(
'This string will be automatically resized to fit in two lines.',
style: TextStyle(fontSize: 30),
maxLines: 2,
),
),
),
),
);
}
}
希望这篇文档对你有所帮助!如果有任何问题或建议,请随时联系我。
更多关于Flutter文本自适应插件text_sizer_plus的使用的实战系列教程也可以访问 https://www.itying.com/category-92-b0.html
更多关于Flutter文本自适应插件text_sizer_plus的使用的实战系列教程也可以访问 https://www.itying.com/category-92-b0.html
当然,下面是一个关于如何在Flutter应用中使用text_sizer_plus
插件来实现文本自适应的示例代码。text_sizer_plus
是一个帮助开发者根据屏幕尺寸和字体大小偏好自动调整文本大小的插件。
首先,你需要在你的pubspec.yaml
文件中添加text_sizer_plus
依赖:
dependencies:
flutter:
sdk: flutter
text_sizer_plus: ^x.y.z # 请替换为最新版本号
然后运行flutter pub get
来安装依赖。
接下来,你可以在你的Flutter应用中按照以下步骤使用text_sizer_plus
:
- 导入插件:
在你的Dart文件中导入text_sizer_plus
:
import 'package:text_sizer_plus/text_sizer_plus.dart';
- 使用TextSizerPlus:
你需要将你的MaterialApp
或CupertinoApp
包裹在TextSizerProvider
中,以便全局使用文本自适应功能。以下是一个完整的示例:
import 'package:flutter/material.dart';
import 'package:text_sizer_plus/text_sizer_plus.dart';
void main() {
runApp(MyApp());
}
class MyApp extends StatelessWidget {
@override
Widget build(BuildContext context) {
return TextSizerProvider(
builder: (context, textSizer) {
return MaterialApp(
title: 'Flutter TextSizerPlus Demo',
theme: ThemeData(
primarySwatch: Colors.blue,
),
home: MyHomePage(textSizer: textSizer),
);
},
);
}
}
class MyHomePage extends StatelessWidget {
final TextSizer textSizer;
MyHomePage({required this.textSizer});
@override
Widget build(BuildContext context) {
return Scaffold(
appBar: AppBar(
title: Text('TextSizerPlus Demo'),
),
body: Center(
child: Column(
mainAxisAlignment: MainAxisAlignment.center,
children: <Widget>[
// 使用 TextSizerWidget 来自适应文本大小
TextSizerWidget(
textSizer: textSizer,
text: 'Hello, this is a responsive text!',
style: TextStyle(fontWeight: FontWeight.bold),
),
SizedBox(height: 20),
// 使用 TextSizerWidget.builder 来自定义文本布局
TextSizerWidget.builder(
textSizer: textSizer,
text: 'This is another responsive text with custom layout.',
style: TextStyle(color: Colors.red),
builder: (context, size, textStyle) {
return Container(
decoration: BoxDecoration(
border: Border.all(color: Colors.grey),
padding: EdgeInsets.all(10),
),
child: Text(
textStyle.text,
style: textStyle.copyWith(fontSize: size),
),
);
},
),
],
),
),
);
}
}
在这个示例中,我们做了以下几件事:
- 使用
TextSizerProvider
包裹MaterialApp
,并通过builder
函数将TextSizer
实例传递给子组件。 - 在
MyHomePage
中,通过构造函数接收TextSizer
实例。 - 使用
TextSizerWidget
和TextSizerWidget.builder
来自适应文本大小。TextSizerWidget
直接使用预定义的样式,而TextSizerWidget.builder
允许你自定义文本的布局和样式。
这样,你就可以在你的Flutter应用中实现文本的自动调整大小功能了。希望这个示例对你有帮助!