Я пытаюсь создать простое приложение для тестирования шаблона Blo C, но в текущей версии шаблона Blo C есть изменение, которое "Текущее состояние" теперь не отправляет с помощью метода mapEventToState как параметр, но согласно онлайн-документу вы можете заменить его только «состоянием», но он не работает со мной,
, и это мой код:
class CounterBloc extends Bloc<CounterEvent, CounterState> {
void onIncrement(){
add(IncrementEvent());
}
void onDecrement() {
add(DecrementEvent());
}
@override
// TODO: implement initialState
CounterState get initialState => CounterState.initial();
@override
Stream<CounterState> mapEventToState(CounterEvent event) async* {
if (event is IncrementEvent) {
yield state..counter += 1;
} else if (event is DecrementEvent) {
yield state..counter -= 1;
}
}
}
, и это Класс состояния счетчика
class CounterState {
int counter;
CounterState._();
factory CounterState.initial() {
return CounterState._()..counter = 0;
}
}
и это мой основной файл дротика приложения
void main() => runApp(MyApp());
class MyApp extends StatelessWidget {
@override
Widget build(BuildContext context) {
return MaterialApp(
title: 'Flutter Demo',
theme: ThemeData(
primarySwatch: Colors.blue,
),
home: MyHomePage(title: 'Flutter Demo Home Page'),
);
}
}
class MyHomePage extends StatefulWidget {
MyHomePage({Key key, this.title}) : super(key: key);
final String title;
@override
_MyHomePageState createState() => _MyHomePageState();
}
class _MyHomePageState extends State<MyHomePage> {
@override
Widget build(BuildContext context) {
return BlocProvider(
create: (context) => CounterBloc(),
child: CounterWidget(widget: widget),
);
}
}
class CounterWidget extends StatelessWidget {
final MyHomePage widget;
const CounterWidget({Key key, @required this.widget}) :super (key: key);
@override
Widget build(BuildContext context) {
return Scaffold(
appBar: AppBar(
title: Text(widget.title),
),
body: BlocBuilder(
bloc: BlocProvider.of<CounterBloc>(context),
builder: (context, CounterState state) {
return Center(
child: Column(
mainAxisAlignment: MainAxisAlignment.center,
children: <Widget>[
Text(
'You have pushed the button this many times:',
),
Text(
'${state.counter}',
style: Theme.of(context).textTheme.display1,
),
],
),
);
},
),
floatingActionButton: Row(
mainAxisAlignment: MainAxisAlignment.end,
children: <Widget>[
FloatingActionButton(
onPressed: () => BlocProvider.of<CounterBloc>(context).onIncrement(),
tooltip: 'Increment',
child: Icon(Icons.add),
),
SizedBox(width: 10,),
FloatingActionButton(
onPressed: () => BlocProvider.of<CounterBloc>(context).onDecrement(),
tooltip: 'Decrement',
child: Icon(Icons.remove),
),
],
)
);
}
}
Пожалуйста, кто-нибудь может мне помочь с этой проблемой?