Flutter 如何在颤振中获得AppBar标题的舒克效果?

Flutter 如何在颤振中获得AppBar标题的舒克效果?,flutter,flutter-layout,flutter-animation,Flutter,Flutter Layout,Flutter Animation,我如何获得AppBar标题的这种效果,示例: 当页面滚动并出现在appBar中时,“咖啡馆”这个大标题就会消失。谢谢。您可能需要 您也可以查看教程 以本文为基础的示例: import 'package:flutter/material.dart'; void main() => runApp(MyApp()); class MyApp extends StatelessWidget { @override Widget build(BuildContext context

我如何获得AppBar标题的这种效果,示例:

当页面滚动并出现在appBar中时,“咖啡馆”这个大标题就会消失。谢谢。

您可能需要

  • 您也可以查看教程
以本文为基础的示例:

import 'package:flutter/material.dart';

void main() => runApp(MyApp());

class MyApp extends StatelessWidget {
  @override
  Widget build(BuildContext context) {
    return MaterialApp(
        title: 'App',
        theme: ThemeData(
          primarySwatch: Colors.blue,
        ),
        home: MainCollapsingToolbar());
  }
}

class MainCollapsingToolbar extends StatefulWidget {
  @override
  _MainCollapsingToolbarState createState() => _MainCollapsingToolbarState();
}

class _MainCollapsingToolbarState extends State<MainCollapsingToolbar> {
  ScrollController _scrollController = ScrollController();
  double offset = 0.0;
  @override
  void initState() {
    super.initState();
    _scrollController.addListener(() {
      setState(() {
        offset = _scrollController.offset;
      });
    });
  }

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

  @override
  Widget build(BuildContext context) {
    return Scaffold(
      body: DefaultTabController(
        length: 2,
        child: NestedScrollView(
          controller: _scrollController,
          headerSliverBuilder: (BuildContext context, bool innerBoxIsScrolled) {
            return <Widget>[
              SliverAppBar(
                expandedHeight: 200.0,
                floating: false,
                pinned: true,
                flexibleSpace: FlexibleSpaceBar(
                  centerTitle: (offset == 0) ? false : true,
                  title: Text("Collapsing Toolbar",
                      style: TextStyle(
                        color: Colors.white,
                        fontSize: 16.0,
                      )),
                ),
              ),
              SliverPersistentHeader(
                delegate: _SliverAppBarDelegate(
                  TabBar(
                    labelColor: Colors.black87,
                    unselectedLabelColor: Colors.grey,
                    tabs: [
                      Tab(icon: Icon(Icons.info), text: "Tab 1"),
                      Tab(icon: Icon(Icons.lightbulb_outline), text: "Tab 2"),
                    ],
                  ),
                ),
                pinned: true,
              ),
            ];
          },
          body: Center(
            child: Text("Sample text"),
          ),
        ),
      ),
    );
  }
}

class _SliverAppBarDelegate extends SliverPersistentHeaderDelegate {
  _SliverAppBarDelegate(this._tabBar);

  final TabBar _tabBar;

  @override
  double get minExtent => _tabBar.preferredSize.height;
  @override
  double get maxExtent => _tabBar.preferredSize.height;

  @override
  Widget build(
      BuildContext context, double shrinkOffset, bool overlapsContent) {
    return new Container(
      child: _tabBar,
    );
  }

  @override
  bool shouldRebuild(_SliverAppBarDelegate oldDelegate) {
    return false;
  }
}
导入“包装:颤振/材料.省道”;
void main()=>runApp(MyApp());
类MyApp扩展了无状态小部件{
@凌驾
小部件构建(构建上下文){
返回材料PP(
标题:“应用程序”,
主题:主题数据(
主样本:颜色。蓝色,
),
主页:主折叠工具栏();
}
}
类MainCollasingToolbar扩展StatefulWidget{
@凌驾
_MainCollasingToolBarState createState()=>\u MainCollasingToolBarState();
}
类_MainCollasingToolbar状态扩展状态{
ScrollController_ScrollController=ScrollController();
双偏移=0.0;
@凌驾
void initState(){
super.initState();
_scrollController.addListener((){
设置状态(){
偏移量=_scrollController.offset;
});
});
}
@凌驾
无效处置(){
_scrollController.dispose();
super.dispose();
}
@凌驾
小部件构建(构建上下文){
返回脚手架(
正文:DefaultTabController(
长度:2,
子:嵌套滚动视图(
控制器:\ u滚动控制器,
headerSliverBuilder:(BuildContext上下文,boolInnerBoxIsCrolled){
返回[
滑杆(
扩展高度:200.0,
浮动:假,
对,,
flexibleSpace:FlexibleSpaceBar(
centerTitle:(偏移量==0)?false:true,
标题:文本(“折叠工具栏”,
样式:TextStyle(
颜色:颜色,白色,
字体大小:16.0,
)),
),
),
滑冰机(
代表:_SliverAppBarDelegate(
塔巴(
labelColor:Colors.black87,
未选择的标签颜色:Colors.grey,
选项卡:[
选项卡(图标:图标(Icons.info),文本:“选项卡1”),
选项卡(图标:图标(图标。灯泡轮廓),文本:“选项卡2”),
],
),
),
对,,
),
];
},
正文:中(
子:文本(“示例文本”),
),
),
),
);
}
}
类_SliverAppBarDelegate扩展SliverPersistentHeaderDelegate{
_SliverAppBarDelegate(此选项卡);
最终TabBar _TabBar;
@凌驾
double-get-minExtent=>\u tabBar.preferredSize.height;
@凌驾
double get maxExtent=>\u tabBar.preferredSize.height;
@凌驾
小部件构建(
BuildContext上下文、双收缩偏移、布尔重叠内容){
退回新货柜(
孩子:_tabBar,
);
}
@凌驾
布尔应该重建(\u SliverAppBarDelegate oldDelegate){
返回false;
}
}

我测试了许多使用棉条的示例,但没有找到合适的。我需要得到与示例中完全相同的效果。问题是放置一个大标题。有一个选项可以使用带有FlexibleSpaceBar的银条,但我在这里得到一个“错误”描述:我认为您不会找到完全相同的示例。你必须做一点实验来找出如何修复它。我用一个基于媒体文章的例子更新了答案。希望它将有助于使用ScrollController和检查滚动状态是一个解决方案。感谢