我创建了一个自定义按钮,可以根据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()
),反之亦然。
我该如何实现?
答案 0 :(得分:1)
您可以从父窗口小部件处理状态并将其传递给您的孩子,这是一个如何实现此状态的示例,当然您可以改进代码并可能创建自己的按钮“父”控制器:>
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