dart - 在 Flutter 应用程序中更改 SliverAppBar 标题颜色

标签 dart flutter appbar

我正在使用 SliverAppBar,包括背景图片和标题。 标题文本是白色的,我需要将 AppBar 上的颜色更改为黑色是“减少”(因为标签栏也是白色的)。

怎么做?

NestedScrollView(
          headerSliverBuilder: (BuildContext context, bool innerBoxIsScrolled) {;
            return <Widget>[
              SliverAppBar(
                expandedHeight: 200.0,
                floating: false,
                pinned: true,
                backgroundColor: Colors.white,
                flexibleSpace: FlexibleSpaceBar(
                    centerTitle: true,
                    title: Text(_event.name,
                        style: TextStyle(
                          color: Colors.white,
                          fontSize: 16.0,
                        )),
                    background: CachedNetworkImage(
                      imageUrl: _event?.imageMediumUrl ??
                          'http://preprod.tibib-live.com/medias/cached-media/medium/5bea5964109aa-c827b05facc3781485e584dac2f4dddc.png',
                      fit: BoxFit.cover,
                    )),
              ),
              SliverPersistentHeader(
                delegate: _SliverAppBarDelegate(
                  TabBar(
                    labelColor: Colors.white,
                    indicatorColor: Colors.red,
                    unselectedLabelColor: Colors.grey,
                    tabs: [
                      Tab(icon: Icon(Icons.info), text: "Info"),
                      Tab(icon: Icon(Icons.people), text: "Courses"),
                    ],
                  ),
                ),
                pinned: true,
              ),
            ];
          },
          body: TabBarView(
            children: <Widget>[_buildInfo(), _buildTrials()],
          ),
        ),

最佳答案

您可以使用 ScrollController 来完成,监听滚动并将偏移量与工具栏的默认大小进行比较。 我为你做了一个例子:

            class TestingNewState extends State<TestingNew> {
              ScrollController _scrollController;

              bool lastStatus = true;

              _scrollListener() {
                if (isShrink != lastStatus) {
                  setState(() {
                    lastStatus = isShrink;
                  });
                }
              }

              bool get isShrink {
                return _scrollController.hasClients &&
                    _scrollController.offset > (200 - kToolbarHeight);
              }

              @override
              void initState() {
                _scrollController = ScrollController();
                _scrollController.addListener(_scrollListener);
                super.initState();
              }

              @override
              void dispose() {
                _scrollController.removeListener(_scrollListener);
                super.dispose();
              }

              @override
              Widget build(BuildContext context) {
                return NestedScrollView(
                  controller: _scrollController,
                  headerSliverBuilder: (BuildContext context, bool innerBoxIsScrolled) {
                    return <Widget>[
                      SliverAppBar(
                        expandedHeight: 200.0,
                        floating: false,
                        pinned: true,
                        backgroundColor: Colors.white,
                        flexibleSpace: FlexibleSpaceBar(
                            centerTitle: true,
                            title: Text("text sample",
                                style: TextStyle(
                                  color: isShrink ? Colors.black : Colors.white,
                                  fontSize: 16.0,
                                )),
                            background: CachedNetworkImage(
                              imageUrl:
                                  'http://preprod.tibib-live.com/medias/cached-media/medium/5bea5964109aa-c827b05facc3781485e584dac2f4dddc.png',
                              fit: BoxFit.cover,
                            )),
                      ),
                    ];
                  },
                  body: Center(
                    child: Text("hello world"),
                  ),
                );
              }
            }

关于dart - 在 Flutter 应用程序中更改 SliverAppBar 标题颜色,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/53622598/

相关文章:

flutter - 实现 CupertinoActionSheet 的正确方法是什么?

firebase - flutter 地实现搜索栏

serialization - _ $ UserSerializerMixin我需要吗?

flutter 错误: A value of type 'OutletListModel' can't be assigned to a variable of type 'List<OutletListModel>?'

flutter - Flutter:带OnPressed选项的 snackbar

flutter - 使用Flutter隐藏/显示小部件的最佳方法是什么?

flutter - 我们可以在手机上通过 chrome 浏览器打开一个 Flutter Web 应用程序吗?

Flutter - 如何为切换选项卡时移动的 TabBar 创建自定义指示器 - 我有一个 DartPad 示例

android - 如何在android中的应用栏左侧对齐图标

android - 如何设置 Android AppBar 操作文本的样式?