在网格中自动缩放文本的大小

问题描述 投票:0回答:1

我正在尝试创建一个表格,使文本自动缩放以适合单元格,但是所有单元格将具有相同的文本大小,同时最大化字体大小。我尝试了FittedBox,但它不能那样工作。任何想法如何进行?

class MyTable extends StatelessWidget {

  @override
  Widget build(BuildContext context) {
    return Container(
      child: Column(
        children: [
          Expanded(
            child: Row(
              children: [
                Expanded(child: Center(child: Text("R1C1: Some text1"))),
                Expanded(child: Center(child: Text("R1C2: Some text2"))),
                Expanded(child: Center(child: Text("R1C3: Some text3"))),
              ],
            ),
          ),
          Expanded(
            child: Row(
              children: [
                Expanded(child: Center(child: Text("R2C1: Some text4"))),
                Expanded(child: Center(child: Text("R2C2: Some text5"))),
                Expanded(child: Center(child: Text("R2C3: Some text6"))),
              ],
            ),
          ),
          Expanded(
            child: Row(
              children: [
                Expanded(child: Center(child: Text("R3C1: Some text7"))),
                Expanded(child: Center(child: Text("R3C2: Some text8"))),
                Expanded(child: Center(child: Text("R3C3: Some text9"))),
              ],
            ),
          ),
        ],
      ),
    );
  }
}

flutter flutter-layout
1个回答
0
投票

我能够使用auto_size_text软件包解决此问题。我使用组来同步所有单元格的大小。

class MyTable extends StatelessWidget {
  final AutoSizeGroup myGroup = AutoSizeGroup();

  @override
  Widget build(BuildContext context) {
    return Container(
      child: Column(
        children: [
          Expanded(
            child: Row(
              children: [
                Expanded(
                  child: Center(
                    child: AutoSizeText(
                      "R1C1: Some text1",
                      style: TextStyle(fontSize: 50),
                      group: myGroup,
                    ),
                  ),
                ),
                Expanded(
                  child: Center(
                    child: AutoSizeText(
                      "R1C2: Some text2",
                      style: TextStyle(fontSize: 50),
                      group: myGroup,
                    ),
                  ),
                ),
...
© www.soinside.com 2019 - 2024. All rights reserved.