mirror of https://github.com/flutter/pinball.git
parent
4cc334a90c
commit
69ba18ea3d
@ -1,27 +1,25 @@
|
|||||||
import 'package:flame/components.dart';
|
import 'package:flame/components.dart';
|
||||||
|
import 'package:flame_bloc/flame_bloc.dart';
|
||||||
import 'package:pinball/game/game.dart';
|
import 'package:pinball/game/game.dart';
|
||||||
import 'package:pinball_components/pinball_components.dart';
|
import 'package:pinball_components/pinball_components.dart';
|
||||||
import 'package:pinball_flame/pinball_flame.dart';
|
import 'package:pinball_flame/pinball_flame.dart';
|
||||||
|
|
||||||
/// Toggle each [Multiplier] when GameState.multiplier changes.
|
/// Toggle each [Multiplier] when GameState.multiplier changes.
|
||||||
class MultipliersBehavior extends Component
|
class MultipliersBehavior extends Component
|
||||||
with HasGameRef<PinballGame>, ParentIsA<Multipliers> {
|
with
|
||||||
|
HasGameRef<PinballGame>,
|
||||||
|
ParentIsA<Multipliers>,
|
||||||
|
BlocComponent<GameBloc, GameState> {
|
||||||
@override
|
@override
|
||||||
void onMount() {
|
bool listenWhen(GameState? previousState, GameState newState) {
|
||||||
super.onMount();
|
return previousState?.multiplier != newState.multiplier;
|
||||||
|
}
|
||||||
var previousMultiplier = 1;
|
|
||||||
|
|
||||||
// TODO(ruimiguel): filter only when multiplier has change.
|
|
||||||
gameRef.read<GameBloc>().stream.listen((state) {
|
|
||||||
if (state.multiplier != previousMultiplier) {
|
|
||||||
previousMultiplier = state.multiplier;
|
|
||||||
|
|
||||||
final multipliers = parent.children.whereType<Multiplier>();
|
@override
|
||||||
for (final multiplier in multipliers) {
|
void onNewState(GameState state) {
|
||||||
multiplier.bloc.next(state.multiplier);
|
final multipliers = parent.children.whereType<Multiplier>();
|
||||||
}
|
for (final multiplier in multipliers) {
|
||||||
}
|
multiplier.bloc.next(state.multiplier);
|
||||||
});
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in new issue