是否有针对BottomBar的针脚SliverAppBar?

时间:2017-05-23 18:57:09

标签: flutter

我可以固定一个SliverAppBar,然后在其下滚动一个SliverList内容。是否有一个等效的列表滚动在BottomBar下?

诀窍是我希望AppBar和BottomBar同时固定以产生滚动效果。

这是AppBar的渲染

AppBar rendering

这就是Bottom的渲染 Bottom render

我希望在文字输入下滚动显示消息,而不是填充颜色。

这可能吗?谢谢。

1 个答案:

答案 0 :(得分:1)

底部导航栏不能正常滚动。您是否可以将Scaffold放入bottomNavigationBar的{​​{1}}广告位并使用AnimatedCrossFade,如果您想将其带入和退出视野?如果这不能解决您的使用案例,请更具体地说明您想要实现的滚动效果。

修改:如果您只想将小部件放在屏幕底部并将其堆叠在列表上,则可以使用Stack

screenshot

import 'dart:collection';
import 'package:flutter/scheduler.dart';
import 'package:flutter/material.dart';

void main() {
  runApp(new MyApp());
}

class MyApp extends StatelessWidget {
  @override
  Widget build(BuildContext context) {
    return new MaterialApp(
      title: 'Flutter Demo',
      theme: new ThemeData(
        primarySwatch: Colors.blue,
        primaryColorBrightness: Brightness.light,
      ),
      home: new MyHomePage(),
    );
  }
}

class MyHomePage extends StatefulWidget {
  State createState() => new MyHomePageState();
}


class MyHomePageState extends State<MyHomePage> {
  ScrollController _scrollController = new ScrollController();

  List<Widget> _items = new List.generate(60, (index) {
    return new Text("item $index");
  });

  @override
  Widget build(BuildContext context) {
    return new Scaffold(
      body: new Stack(
        children: [
          new ListView(
            controller: _scrollController,
            children: new UnmodifiableListView(_items),
          ),
          new Positioned(
            top: 0.0,
            left: 0.0,
            right: 0.0,
            child: new AppBar(
              elevation: 0.0,
              backgroundColor: Colors.white.withOpacity(0.8),
              title: new Text('Sliver App Bar'),
            ),
          ),
          new Positioned(
            left: 0.0,
            right: 0.0,
            bottom: 0.0,
            child: new Container(
              decoration: new BoxDecoration(
                border: new Border.all(
                  width: 3.0,
                  color: Colors.blue.shade200.withOpacity(0.5)
                ),
                color: Colors.white.withOpacity(0.8),
                borderRadius: new BorderRadius.all(
                  new Radius.circular(10.0),
                ),
              ),
              height: 40.0,
              margin: const EdgeInsets.symmetric(
                horizontal: 20.0, vertical: 10.0)
            ),
          ),
        ],
      ),
    );
  }
}