gpt4 book ai didi

dart - 选择另一个按钮时取消选择一个按钮

转载 作者:IT王子 更新时间:2023-10-29 06:59:52 27 4
gpt4 key购买 nike

我创建了一个自定义按钮,它根据 bool pressAttention 参数更改其图像和文本颜色。

class UserButton extends StatefulWidget {
final String unselectedImagePath;
final String selectedImagePath;
final String text;

UserButton({
this.unselectedImagePath,
this.selectedImagePath,
this.text,
});

@override
State<StatefulWidget> createState() => _UserButtonState();
}

class _UserButtonState extends State<UserButton> {
bool pressAttention = false;

@override
Widget build(BuildContext context) {
return Column(
children: <Widget>[
Ink.image(
image: pressAttention
? AssetImage(widget.selectedImagePath)
: AssetImage(widget.unselectedImagePath),
fit: BoxFit.cover,
width: 150.0,
height: 150.0,
child: InkWell(
splashColor: Colors.transparent,
highlightColor: Colors.transparent,
onTap: () {
setState(() {
pressAttention = !pressAttention;
});
},
),
),
Padding(
padding: EdgeInsets.only(top: 30.0),
child: Text(
widget.text,
style: TextStyle(
color: pressAttention
? Theme.of(context).accentColor
: Colors.white,
fontFamily: "Roboto",
fontSize: 18.0
),
),
)
],
);
}
}

然后像这样在我的主类中给它们充气:

Padding(
padding: EdgeInsets.only(top: 100.0),
child: Row(
mainAxisAlignment: MainAxisAlignment.center,
children: <Widget>[
UserButton(
selectedImagePath: 'assets/whistle_orange.png',
unselectedImagePath: 'assets/whistle.png',
text: "Coach",
),
Container(width: 30.0,),
UserButton(
selectedImagePath: 'assets/weight_orange.png',
unselectedImagePath: 'assets/weight.png',
text: "Student",
)
],
),
),

虽然这两个按钮本身可以正常工作,但我需要禁用第一个按钮(更改 pressAttention 并调用 setState()),反之亦然。

我怎样才能做到这一点?

最佳答案

您可以处理来自父小部件的状态并将其传递给您的 child ,这是一个如何实现它的示例,当然您可以改进代码并创建您自己的按钮“父” Controller :

    class UserButton extends StatefulWidget {
final String unselectedImagePath;
final String selectedImagePath;
final String text;
final VoidCallback onTap;
final bool selected;

UserButton({
this.unselectedImagePath,
this.selectedImagePath,
this.text,
this.selected,
this.onTap,
});

@override
State<StatefulWidget> createState() => _UserButtonState();
}

class _UserButtonState extends State<UserButton> {
bool pressAttention = false;

@override
Widget build(BuildContext context) {
pressAttention = widget.selected;
return Column(
children: <Widget>[
Ink.image(
image: pressAttention
? AssetImage(widget.selectedImagePath)
: AssetImage(widget.unselectedImagePath),
fit: BoxFit.cover,
width: 150.0,
height: 150.0,
child: InkWell(
splashColor: Colors.transparent,
highlightColor: Colors.transparent,
onTap: () {
setState(() {
pressAttention = !pressAttention;
});
if (widget.onTap != null) widget.onTap();
},
),
),
Padding(
padding: EdgeInsets.only(top: 30.0),
child: Text(
widget.text,
style: TextStyle(
color: pressAttention
? Theme.of(context).accentColor
: Colors.white,
fontFamily: "Roboto",
fontSize: 18.0),
),
)
],
);
}
}

class ParentMain extends StatefulWidget {
@override
_ParentMainState createState() => _ParentMainState();
}

class _ParentMainState extends State<ParentMain> {
bool selectedButtonCoach = false;
bool selectedButtonStudent = false;

@override
Widget build(BuildContext context) {
return Container(
child: Padding(
padding: EdgeInsets.only(top: 100.0),
child: Row(
mainAxisAlignment: MainAxisAlignment.center,
children: <Widget>[
UserButton(
selectedImagePath: 'assets/whistle_orange.png',
unselectedImagePath: 'assets/whistle.png',
text: "Coach",
selected: selectedButtonCoach,
onTap: () {
setState(() {
selectedButtonCoach = true;
selectedButtonStudent = false;
});
},
),
Container(
width: 30.0,
),
UserButton(
selectedImagePath: 'assets/weight_orange.png',
unselectedImagePath: 'assets/weight.png',
text: "Student",
selected: selectedButtonStudent,
onTap: () {
setState(() {
selectedButtonCoach = false;
selectedButtonStudent = true;
});
},
)
],
),
),
);
}
}

看看 Radio 小部件是如何工作的:https://github.com/flutter/flutter/blob/master/examples/flutter_gallery/lib/demo/material/selection_controls_demo.dart

https://docs.flutter.io/flutter/material/Radio-class.html

关于dart - 选择另一个按钮时取消选择一个按钮,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/52918862/

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