在此示例中,我试图了解是否需要使用FutureBuilder,以便为我的onTap方法提供“选择的”布尔值。
return Card(
color: Color.fromARGB(255, 233, 30, 99),
elevation: 5.0,
child: InkWell(
splashColor: Colors.blueGrey,
onTap: () {
return setState(
() {
this.selected = !this.selected;
selected == true
? model.disAllowTouchSounds()
: model.allowTouchSounds();
},
);
},
child: Padding(
padding: EdgeInsets.only(left: 10.0, right: 10.0),
child: StreamBuilder<String>(
stream: stream1,
builder: (context, snapshot1) {
return StreamBuilder<String>(
stream: stream2,
builder: (context, snapshot2) {
if (snapshot1.hasData && snapshot2.hasData) {
if (snapshot1.data
.toString()
.contains('TOUCH SOUNDS ALLOWED') ||
snapshot2.data.toString().contains('DND OFF')) {
selected = false;
return TouchOn();
} else if (snapshot2.data
.toString()
.contains('ALARMS ONLY ON') ||
snapshot2.data.toString().contains('DND ON')) {
selected = true;
isDisabled = true;
return TouchOff();
}
}
由于我的Streambuilder可能需要一些时间来构建,所以我想知道this.selected =!this.selected是否可以正常工作。
我要问的原因是,我有时不得不点按两次以启动disAllowTouchSounds()方法。理想情况下,我想避免这种情况。