gpt4 book ai didi

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

转载 作者:IT王子 更新时间:2023-10-29 07:12:25 26 4
gpt4 key购买 nike

我有一个名为 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;
});
},
);
}
)

最佳答案

在 RowItem 中创建一个函数 handleOnTap()。在这个函数中你更新你的值和 setState 然后调用 widget.onTap()

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

关于Flutter - 从自定义小部件返回 onTap 并执行动画,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/54894412/

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com