Можно ли использовать прокручиваемые вкладки с прозрачной панелью приложений и нижней панелью приложений?

Я пытаюсь создать макет флаттера с прозрачной панелью приложений и нижней панелью приложений. Однако я хочу иметь возможность перелистывать вкладки. Проблема в том, что у меня могут быть прокручиваемые вкладки, но тело не находится под панелями приложений. Или я могу разместить тело под панелями приложений, но вкладки нельзя пролистывать.

Я уже пробовал использовать Stack (), а не Scaffold (). Однако я думаю, что это помещает TabBarView перед панелями приложений из-за невозможности различать панели тела и приложения.

Это код, в котором панели приложений не видны:

class _AppStateTab extends State<App>{
  @override
  Widget build(BuildContext context) {
    return MaterialApp(
      home: DefaultTabController(
        length: 3,
        child: Stack(
          children: <Widget>[
            Positioned(
              top: 0.0,
              left: 0.0,
              right: 0.0,
              child: AppBar(
                backgroundColor: Colors.transparent,
                elevation: 0.0,
                actions: <Widget>[
                  IconButton(
                    icon: Icon(Icons.search), 
                    color: Colors.white,
                    onPressed: () {},
                  ),
                  IconButton(
                    icon: Icon(Icons.cached), 
                    color: Colors.white,
                    onPressed: () {},
                  ),
                ],
              ),
            ),
            Positioned(
              bottom: 0.0,
              left: 0.0,
              right: 0.0,
              child: BottomAppBar(
                color: Colors.transparent,
                elevation: 0.0,
                child: Row(
                  mainAxisSize: MainAxisSize.max,
                  mainAxisAlignment: MainAxisAlignment.spaceEvenly,
                  children: <Widget>[
                    IconButton(
                      icon: Icon(Icons.dialpad), 
                      color: Colors.white,
                      onPressed: (){},
                    ),
                    IconButton(
                      icon: Icon(Icons.camera_alt),
                      color: Colors.white,
                      onPressed: (){},
                    ),
                    IconButton(
                      icon: Icon(Icons.edit),
                      color: Colors.white,
                      onPressed: (){},
                    ),
                  ],
                ),
              ),
            ),
            TabBarView(
              children: <Widget>[
                Calculator(),
                Camera(),
                Solution(),
              ],
            )
          ],
        ),
      ),
    );
  }
}

И это код, в котором тело не проходит под панелями приложения:

  @override
  Widget build(BuildContext context){
    return Scaffold(
      appBar: AppBar(
        title: Text('data'),
        backgroundColor: Colors.transparent,
        elevation: 0.0,
      ),
      body: TabBarView(
        controller: _tabController,
        children: _tabList,
      ),
      bottomNavigationBar: BottomAppBar(
        color: Colors.transparent,
        elevation: 0.0,
        child: Row(
          mainAxisSize: MainAxisSize.max,
          mainAxisAlignment: MainAxisAlignment.spaceEvenly,
          children: <Widget>[
            IconButton(
              icon: Icon(Icons.dialpad), 
              color: Colors.white,
              onPressed: (){
                _tabController.animateTo(0);
              },
            ),
            IconButton(
              icon: Icon(Icons.camera_alt),
              color: Colors.white,
              onPressed: (){
                _tabController.animateTo(1);
              },
            ),
            IconButton(
              icon: Icon(Icons.edit),
              color: Colors.white,
              onPressed: (){
                _tabController.animateTo(2);
              },
            ),
          ],
        ),
      ),
    );

person kerosenekiwi    schedule 21.04.2019    source источник


Ответы (1)


Хорошо, просто обновление, мне удалось исправить мою проблему. Я не понимал, что порядок в стеке определяет его, так сказать, слой. Первый элемент находится в самом конце, а все остальные элементы идут на один слой впереди. Итак, чтобы исправить это, все, что я сделал, это переставил тело так, чтобы оно было первым элементом, а за ним следовали позиции. Это позволило создать приложение с возможностью прокрутки с прозрачными панелями приложений.

person kerosenekiwi    schedule 26.04.2019