Flutter-从自定义小部件返回onTap并执行动画

时间:2019-02-26 21:29:34

标签: flutter flutter-animation

我有一个名为RowItem的自定义小部件,它是一个有状态的小部件。当用户单击窗口小部件时,它将进行动画处理。但是我也想将onTap事件返回给父窗口小部件,但是我不知道该怎么做...

这是我的RowItem小部件:

class _RowItemState extends State<RowItem> {
  bool isSelected = false;
  double underlineWith = 0;

  @override
  Widget build(context) {
    // Pass the text down to another widget
    return new GestureDetector(
      onTap: () {
        isSelected = !isSelected;
        if (isSelected) {
          setState(() {
            underlineWith = 18.0;
          });
        } else {
          setState(() {
            underlineWith = 0;
          });
        }
      },
      child: new Column(
        children: <Widget>[
          new Padding(
              padding: EdgeInsetsDirectional.fromSTEB(8.0, 0.0, 8.0, 0.0),
              child: new Container(
                child: new Text(
                  widget.text,
                  textAlign: TextAlign.center,
                  overflow: TextOverflow.ellipsis,
                  softWrap: true,
                  style: TextStyle(
                      fontSize: 12.0,
                      fontWeight: FontWeight.bold,
                      color: Color(0x99222222)),
                ),
              )),
          new Padding(
            padding: EdgeInsetsDirectional.fromSTEB(0.0, 5.0, 0.0, 10.0),
            child: new AnimatedContainer(
              height: 2,
              width: underlineWith,
              color: widget.underlineColor,
              duration: Duration(milliseconds: 150),
            ),
          ),
        ],
      ),
    );
  }
}

如果我想返回onTap事件,我可以这样做:

return new GestureDetector(
  onTap: widget.onTap
}

但是我该如何同时做动画和返回onTap事件?

我想在点击 RowItem 时运行代码:

new GridView.builder(
                                  physics: const NeverScrollableScrollPhysics(),
                                  shrinkWrap: true,
                                  itemCount: _subCategories.length,
                                  gridDelegate:
                                  new SliverGridDelegateWithFixedCrossAxisCount(
                                      childAspectRatio: 3.2,
                                      crossAxisCount: 3),
                                  itemBuilder: (BuildContext context, int index) {
                                    return new RowItem(
                                      text: _subCategories[index],
                                      underlineColor: Color(0xff73A6AD),
                                      onTap: () {
                                        setState(() {
                                          //do something;
                                        });
                                      },
                                    );
                                  }
)

2 个答案:

答案 0 :(得分:1)

在RowItem内部创建一个函数handleOnTap()。在此函数中,您更新值和setState,然后调用widget.onTap()

func handleOnTap() {
  isSelected = !isSelected;
  if (isSelected) {
    setState(() {
      underlineWith = 18.0;
    });
  } else {
    setState(() {
      underlineWith = 0;
    });
  }
  widget.onTap();
}

答案 1 :(得分:1)

根据侯赛因的答案找到了解决方案:

handleOnTap(){
    isSelected = !isSelected;
    if (isSelected) {
      setState(() {
        underlineWith = 18.0;
      });
    } else {
      setState(() {
        underlineWith = 0;
      });
    }
    return widget.onTap();
}





@override
Widget build(context) {
    // Pass the text down to another widget
    return new GestureDetector(
      onTap: () => handleOnTap()
      ...