如何为SliverAppBar添加抽屉式菜单

8

这是我从这里复制的代码:

SliverAppBar(
  expandedHeight: 150.0,
  flexibleSpace: const FlexibleSpaceBar(
      title: Text('Available seats'),
    ),
    actions: < Widget > [
      IconButton(
        icon: const Icon(Icons.add_circle),
          tooltip: 'Add new entry',
          onPressed: () { /* ... */ },
      ),
    ]
)

但我需要添加一个抽屉。我该怎么做?
我正在尝试在Flutter中重建我的应用程序。
将Java Android应用程序转换为Flutter

我已经更换了图标,但是如何创建抽屉

leading: IconButton(icon: Icon( Icons.menu ),onPressed: ()=>{},)

我的完整代码

@override
  Widget build(BuildContext context) {

  return NestedScrollView(
      headerSliverBuilder: (BuildContext context, bool innerBoxIsScrolled) {
        return <Widget>[
          SliverAppBar(
            leading: IconButton(
              icon: Icon(Icons.menu),
              onPressed: () => {},
            ),
            actions: <Widget>[
              IconButton(
                onPressed: () => {},
                icon: Icon(Icons.shopping_cart),
              )
            ],
            expandedHeight: 200.0,
            floating: false,
            pinned: true,
            flexibleSpace: FlexibleSpaceBar(
                centerTitle: true,
                title: Text("My Pet Shop",
                    style: TextStyle(
                      color: Colors.white,
                      fontSize: 16.0,
                    )),
                background: Image.network(
                  "https://firebasestorage.googleapis.com/v0/b/my-pet-world.appspot.com/o/images%2Fbannerads%2FxTmAblJI7fMF1l0nUa1gM32Kh9z1%2F734rm6w7bxznp%2FPETWORLD-HOME-SLIDER-KITTENS.webp?alt=media&token=cf7f48bb-6621-47b3-b3f8-d8b36fa89715",
                  fit: BoxFit.cover,
                )),
          ),
        ];
      },
      body: Container(
        margin: EdgeInsets.only(top: 0),
        child: Column(
          children: <Widget>[
            Expanded(
              //getHomePageWidget()
              child: ListView(
                padding: EdgeInsets.all(0.0),
                children: <Widget>[getHomePageWidget()],
              ),
            )
          ],
        ),
      ));
 }

1
您不需要在SliverAppBar中手动添加菜单图标。只要将Scaffold作为其祖先,菜单图标就会神奇地出现。 - dshukertjr
请问您能否更新我的新代码? - Midhilaj
在我的新代码中,应该在哪里添加Scaffold? - Midhilaj
我刚刚完成了。你的代码中有很多不必要的代码,所以我把它们全部剥离了,最后只剩下了getHomePageWidget()。 - dshukertjr
1个回答

20

Drawer是Scaffold的一个属性。一旦您设置了drawer属性,菜单图标将自动出现在SliverAppBar中。

在您的build方法内返回此内容,您将获得您想要的结果。

  return Scaffold(
    body: CustomScrollView(
      slivers: <Widget>[
        SliverAppBar(
          expandedHeight: 200.0,
          flexibleSpace: const FlexibleSpaceBar(
            title: Text('Available seats'),
          ),
          actions: <Widget>[
            IconButton(
              icon: const Icon(Icons.add_circle),
              tooltip: 'Add new entry',
              onPressed: () {},
            ),
          ],
        ),
        SliverList(
          delegate: SliverChildListDelegate([
            getHomePageWidget(),
          ]),
        ),
      ],
    ),
    drawer: Drawer(),
  );

注意:如果您在CustomScrollView上方的树中有多个Scaffold,则Drawer应该位于最底部的Scaffold中。


1
让我检查一下。 - Midhilaj
@Midhilaj 让我知道进展如何。 - dshukertjr
@Midhilaj 你是什么意思? - dshukertjr
@Midhilaj,您提供的代码仍然不是完整的代码。我能看到整个构建函数吗? - dshukertjr
1
你很棒,晚上11:48分你帮助了我,我的朋友们都没有提供这种帮助。 - Midhilaj
显示剩余4条评论

网页内容由stack overflow 提供, 点击上面的
可以查看英文原文,
原文链接