在Flutter中实现五种风格的Tab

flutter SDK提供的默认标签样式不太吸引人。 但这并不意味着您无法自定义标签的外观。 在Flutter中自定义Tab指示器的样式可以通过简单的代码行完成,而无需实现我们自己的窗口小部件。

在本文中,我将向您展示如何为下一个Flutter项目添加5种不同的标签样式。

首先,您需要使用DefaultTabController类创建一个基本选项卡。 将DefaultTabController分配给MaterialApp小部件的home属性。 作为DefaultTabController的子级,可以将Scaffold与 Appbar和主体一起使用。 将Appbar小部件分配到ScaffoldAppbar属性,以使选项卡的标题部分。 对于脚手架的body属性,可以为TabBarView小部件分配3个子小部件,以在单击时显示Tab内容项。

image

检查完整的代码以获取默认Tab

return DefaultTabController(
      length: 3,
      child: Scaffold(
        appBar: AppBar(
          elevation: 0,
          bottom: TabBar(
            indicatorSize: TabBarIndicatorSize.label,
            tabs: [
              Tab(
                child: Align(
                  alignment: Alignment.center,
                  child: Text("APPS"),
                ),
              ),
              Tab(
                child: Align(
                  alignment: Alignment.center,
                  child: Text("MOVIES"),
                ),
              ),
              Tab(
                child: Align(
                  alignment: Alignment.center,
                  child: Text("GAMES"),
                ),
              ),
            ],
          ),
        ),
        body: TabBarView(
          children: [
            Icon(Icons.apps),
            Icon(Icons.movie),
            Icon(Icons.games),
          ],
        ),
      ),
    );

1. 圆角Tab风格

作为第一种样式,我们将向选项卡指示器添加圆角样式。 首先,我将简要介绍我们将要修改的参数。

1. unselectedLabelColor –不存在指示符的标签颜色。 基本上,尚未选择的指标。
2. indicatorSize –选定的指标大小。 我们可以添加两个值以使指标为标签宽度或标签宽度。
3. Indicator –这是我们要为指标分配自定义样式的地方

Tab–这将包含Tab标题的列表。 在这里,我们可以为每个Tab标题添加额外的样式。
可以通过添加带有borderRadius 50BoxDecoration来实现圆角样式。在这里,我们向每个Tab```标题添加红色边框。 当有人选择Tab``时,它将用红色填充。 如果您对边框不感兴趣,可以删除边框并保持简单。

image
return DefaultTabController(
      length: 3,
      child: Scaffold(
        appBar: AppBar(
          backgroundColor:Colors.white,
          elevation: 0,
          bottom: TabBar(
            unselectedLabelColor:Colors.redAccent,
            indicatorSize: TabBarIndicatorSize.label,
            indicator:BoxDecoration(
              color:Colors.redAccent,
              borderRadius:BorderRadius.circular(50),
            ),
            tabs: [
              Tab(
                child:Container(
                  decoration:BoxDecoration(
                    borderRadius:BorderRadius.circular(50),
                    border:Border.all(color:Colors.redAccent,
                      width:1,
                    ),
                  ),
                  child:Align(
                    alignment:Alignment.center,
                    child:Text("APPS"),
                  ),
                ),
              ),
              Tab(
                child:Container(
                  decoration:BoxDecoration(
                    borderRadius:BorderRadius.circular(50),
                    border:Border.all(color:Colors.redAccent,
                      width:1,
                    ),
                  ),
                  child:Align(
                    alignment:Alignment.center,
                    child:Text("MOVIES"),
                  ),
                ),
              ),
              Tab(
                child:Container(
                  decoration:BoxDecoration(
                    borderRadius:BorderRadius.circular(50),
                    border:Border.all(color:Colors.redAccent,
                      width:1,
                    ),
                  ),
                  child:Align(
                    alignment:Alignment.center,
                    child:Text("GASMES"),
                  ),
                ),
              ),
            ],
          ),
        ),
        body: TabBarView(
          children: [
            Icon(Icons.apps),
            Icon(Icons.movie),
            Icon(Icons.games),
          ],
        ),
      ),
    );

2. 圆角带有渐变色Tab风格

我们将删除以前方法中添加到每个Tab的样式。 删除后,向BoxDecoration添加渐变。 您可以使用带有两种颜色的LinearGradient小部件来获得渐变效果。 您可以根据自己的喜好更改渐变。

image
return DefaultTabController(
      length: 3,
      child: Scaffold(
        appBar: AppBar(
          backgroundColor:Colors.white,
          elevation: 0,
          bottom: TabBar(
            unselectedLabelColor:Colors.redAccent,
            indicatorSize: TabBarIndicatorSize.tab,
            indicator:BoxDecoration(
              gradient:LinearGradient(
                colors:[
                  Colors.redAccent,
                  Colors.orangeAccent,
                ],
              ),
              color:Colors.redAccent,
              borderRadius:BorderRadius.circular(50),
            ),
            tabs: [
              Tab(
                child:Align(
                  alignment:Alignment.center,
                  child:Text("APPS"),
                ),
              ),
              Tab(
                child:Align(
                  alignment:Alignment.center,
                  child:Text("MOVIES"),
                ),
              ),
              Tab(
                child:Align(
                  alignment:Alignment.center,
                  child:Text("GASMES"),
                ),
              ),
            ],
          ),
        ),
        body: TabBarView(
          children: [
            Icon(Icons.apps),
            Icon(Icons.movie),
            Icon(Icons.games),
          ],
        ),
      ),
    );

3. 矩形Tab风格

矩形样式可以通过更改上一个中的小代码来完成。 可以通过为leftToprightTop都添加10来更改boxDecorationBorderRadius。 然后,我将appbar backgroundColor更改为红色,以使其看起来更好。

image
return DefaultTabController(
      length: 3,
      child: Scaffold(
        appBar: AppBar(
          backgroundColor:Colors.redAccent,
          elevation: 0,
          bottom: TabBar(
            labelColor:Colors.redAccent,
            unselectedLabelColor:Colors.white,
            indicatorSize: TabBarIndicatorSize.label,
            indicator:BoxDecoration(
              color:Colors.white,
              borderRadius:BorderRadius.only(
                topLeft:Radius.circular(10),
                topRight:Radius.circular(10),
              ),
            ),
            tabs: [
              Tab(
                child:Align(
                  alignment:Alignment.center,
                  child:Text("APPS"),
                ),
              ),
              Tab(
                child:Align(
                  alignment:Alignment.center,
                  child:Text("MOVIES"),
                ),
              ),
              Tab(
                child:Align(
                  alignment:Alignment.center,
                  child:Text("GASMES"),
                ),
              ),
            ],
          ),
        ),
        body: TabBarView(
          children: [
            Icon(Icons.apps),
            Icon(Icons.movie),
            Icon(Icons.games),
          ],
        ),
      ),
    );

4.菱形Tab样式

您可以通过为ShapeDecoration小部件的shape参数添加带有BeveledRectangleBorderShapeDecoration来获得Diamond选项卡样式。 BeveledRectangleBorder将允许您添加展平角而不是圆角。

在这里,我们使用borderRadius作为10使其看起来像这样。

image
    return DefaultTabController(
      length: 3,
      child: Scaffold(
        appBar: AppBar(
          backgroundColor:Colors.white,
          elevation: 0,
          bottom: TabBar(
            unselectedLabelColor:Colors.redAccent,
            indicatorPadding:EdgeInsets.only(left:30,right:30),
            indicator:ShapeDecoration(
              color:Colors.redAccent,
              shape:BeveledRectangleBorder(
                side:BorderSide(
                  color:Colors.redAccent,
                ),
                borderRadius:BorderRadius.circular(10),
              ),
            ),
            tabs: [
              Tab(
                child:Align(
                  alignment:Alignment.center,
                  child:Text("APPS"),
                ),
              ),
              Tab(
                child:Align(
                  alignment:Alignment.center,
                  child:Text("MOVIES"),
                ),
              ),
              Tab(
                child:Align(
                  alignment:Alignment.center,
                  child:Text("GASMES"),
                ),
              ),
            ],
          ),
        ),
        body: TabBarView(
          children: [
            Icon(Icons.apps),
            Icon(Icons.movie),
            Icon(Icons.games),
          ],
        ),
      ),
    );

5.菱形Tab样式(2)

同样,通过更改BeveledRectangleBorderborderRadius,可以实现不同的形状。 您可以将borderRadius更改为20,以获得其他形状。 您可以通过更改borderRadius值尝试不同的样式。

image
    return DefaultTabController(
      length: 3,
      child: Scaffold(
        appBar: AppBar(
          backgroundColor:Colors.white,
          elevation: 0,
          bottom: TabBar(
            unselectedLabelColor:Colors.redAccent,
            indicatorPadding:EdgeInsets.only(left:30,right:30),
            indicator:ShapeDecoration(
              color:Colors.redAccent,
              shape:BeveledRectangleBorder(
                side:BorderSide(
                  color:Colors.redAccent,
                ),
                borderRadius:BorderRadius.circular(20),
              ),
            ),
            tabs: [
              Tab(
                child:Align(
                  alignment:Alignment.center,
                  child:Text("APPS"),
                ),
              ),
              Tab(
                child:Align(
                  alignment:Alignment.center,
                  child:Text("MOVIES"),
                ),
              ),
              Tab(
                child:Align(
                  alignment:Alignment.center,
                  child:Text("GASMES"),
                ),
              ),
            ],
          ),
        ),
        body: TabBarView(
          children: [
            Icon(Icons.apps),
            Icon(Icons.movie),
            Icon(Icons.games),
          ],
        ),
      ),
    );

我希望您能通过几行代码更好地了解如何更改选项卡样式。 如果您想观看此视频,请观看以下视频。
https://www.youtube.com/watch?v=Vnd0yvCkdNA&feature=youtu.be

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 203,456评论 5 477
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 85,370评论 2 381
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 150,337评论 0 337
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,583评论 1 273
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,596评论 5 365
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,572评论 1 281
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 37,936评论 3 395
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,595评论 0 258
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 40,850评论 1 297
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,601评论 2 321
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,685评论 1 329
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,371评论 4 318
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 38,951评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,934评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,167评论 1 259
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 43,636评论 2 349
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,411评论 2 342

推荐阅读更多精彩内容