在Flutter ListView中检测焦点小部件

时间:2018-08-18 12:19:16

标签: listview flutter flutter-layout

我有一个水平的listview.builder小部件,列表中的每个子项大约占总宽度的90 ,,我如何才能检测到哪个小部件处于焦点位置。

这是我的小部件。

new ListView.builder(
                              scrollDirection: Axis.horizontal,
                              itemCount: categories.length,
                              itemBuilder: (context, index) {
                                return new InkWell(
                                  onTap: () {
                                    Navigator
                                        .of(context)
                                        .push(new MaterialPageRoute(
                                          builder: (_) => new StakePage(),
                                        ));
                                  },
                                  child: new Card(
                                    child: new Container(
                                      decoration: new BoxDecoration(
                                        image: new DecorationImage(
                                          fit: BoxFit.cover,
                                          image: categories[index].cover,
                                          colorFilter: new ColorFilter.mode(
                                              Colors.black12,
                                              BlendMode.screen),
                                        ),
                                      ),
                                      constraints: new BoxConstraints(
                                          maxWidth: 400.0,
                                          maxHeight: 600.0),
                                      height: size.height / 2,
                                      width: size.width * 0.85,
                                    ),
                                  ),
                                );
                              }),

It looks like this

1 个答案:

答案 0 :(得分:-1)

您可以用 visibility_detector widget 包裹您的小部件,一旦您的小部件在屏幕上可见,它就会触发回调。