Flutter How to check if Sliver AppBar is expanded or collapsed?

前端 未结 2 504
北恋
北恋 2020-12-09 16:42

I am using a SliverAppBar in Flutter, with a background widget.

The thing is When it\'s expanded, the title and icons (leading and actions) should be wh

2条回答
  •  自闭症患者
    2020-12-09 17:28

    You need to use ScrollController to achieve the desired effect

    try this code

    import 'package:flutter/material.dart';
    
    void main() => runApp(MyApp());
    
    class MyApp extends StatelessWidget {
    
      // This widget is the root of your application.
      @override
      Widget build(BuildContext context) {
        return MaterialApp(
          title: 'Flutter Demo',
          theme: ThemeData(
            primarySwatch: Colors.blue,
          ),
          home: SliverExample(
            bodyWidgets: Text(
                'Hello Body gggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggggg'),
            backgroundWidget: Text('Hello Background'),
          ),
        );
      }
    }
    
    class SliverExample extends StatefulWidget {
      final Widget backgroundWidget;
      final Widget bodyWidgets;
    
      SliverExample({
        this.backgroundWidget,
        this.bodyWidgets,
      });
    
      @override
      _SliverExampleState createState() => _SliverExampleState();
    }
    
    class _SliverExampleState extends State {
    
      ScrollController _scrollController;
      Color _theme ;
    
      @override
      void initState() {
        super.initState();
        _theme = Colors.black;
    
        _scrollController = ScrollController()
          ..addListener(
            () => _isAppBarExpanded ?
                _theme != Colors.white ?
            setState(
              () {
                _theme = Colors.white;
                print(
                    'setState is called');
              },
            ):{}
                : _theme != Colors.black ?
            setState((){
              print(
                  'setState is called');
              _theme = Colors.black;
            }):{},
    
          );
      }
    
      bool get _isAppBarExpanded {
        return _scrollController.hasClients &&
            _scrollController.offset > (200 - kToolbarHeight);
      }
    
      @override
      Widget build(BuildContext context) {
        // To change the item's color accordingly
        // To be used in multiple places in code
        //Color itemColor = isAppBarExpanded ? Colors.white : Colors.black;
    
        // In my case PrimaryColor is white,
        // and the background widget is dark
    
        return Scaffold(
          body: CustomScrollView(
            controller: _scrollController,
            slivers: [
              SliverAppBar(
                pinned: true,
                leading: BackButton(
                  color: _theme, // Here
                ),
                actions: [
                  IconButton(
                    icon: Icon(
                      Icons.shopping_cart,
                      color: _theme, // Here
                    ),
                    onPressed: () {},
                  ),
                ],
                expandedHeight: 200.0,
                flexibleSpace: FlexibleSpaceBar(
                  centerTitle: true,
                  title: Text(
                    'title',
                    style: TextStyle(
                      fontSize: 18.0,
                      color: _theme, // Here
                    ),
                  ),
                  // Not affecting the question.
                  background: widget.backgroundWidget,
                ),
              ),
              // Not affecting the question.
              SliverToBoxAdapter(child: widget.bodyWidgets),
            ],
          ),
        );
      }
    }
    

    if you are not familiar with ? : notation you can use the following

    _scrollController = ScrollController()
          ..addListener(
              (){
                if(_isAppBarExpanded){
                  if(_theme != Colors.white){
                    setState(() {
                      _theme = Colors.white;
                      print('setState is called with white');
                    });
                  }
                }else{
                  if(_theme != Colors.black){
                    setState(() {
                      _theme = Colors.black;
                      print('setState is called with black');
                    });
                  }
                }
              }
    

提交回复
热议问题