Skip to content

Commit

Permalink
fix: Pause forge2d when backgrounded
Browse files Browse the repository at this point in the history
fix: Pause forge2d when backgrounded

chore: temporarily add print statements

Revert "chore: temporarily add print statements"

This reverts commit 5f672df.

fix: prevent duplicate `pauseEngine` calls

ref: move `pauseWhenBackgrounded` to `FlameGame`

fix: remove outdated comment

ref: move test to flame package

chore: dart format .

chore: remove unused import

ref: move variables closer to usage

ref: remove `pauseWhenBackgrounded` from constructor

feat: make pauseWhenBackgrounded true by default

docs: mention only working on mobile

docs: add doc for pauseWhenBackgrounded flag
  • Loading branch information
adil192 committed Sep 18, 2023
1 parent e051298 commit 61998e3
Show file tree
Hide file tree
Showing 5 changed files with 87 additions and 0 deletions.
3 changes: 3 additions & 0 deletions .github/.cspell/gamedev_dictionary.txt
Original file line number Diff line number Diff line change
Expand Up @@ -24,6 +24,8 @@ arial # name of a typeface
arities # plural of arity
arity # number of parameters a function takes
autofocus # auto focus event
backgrounded # moving the app to the background
backgrounding # moving the app to the background
backpressure # strategy to deal with excess flow of data
backquote # another word for backtick
backtick # the back tick character "`"
Expand All @@ -39,6 +41,7 @@ coord # coordinate
coords # plural of coord
deduplication # removal of duplicates
easings # Easing functions specify the rate of change of a parameter over time
foregrounded # moving the app to the foreground
fullscreen # mode in which a program or app occupies the entire screen with no borders
goldens # test files used as reference for Golden Tests
hardcoding # putting a value as a literal instead of computing it
Expand Down
18 changes: 18 additions & 0 deletions doc/flame/game.md
Original file line number Diff line number Diff line change
Expand Up @@ -222,3 +222,21 @@ renders will happen until it is resumed.
While the game is paused, it is possible to advanced it frame by frame using the `stepEngine` method.
It might not be much useful in the final game, but can be very helpful in inspecting game state step
by step during the development cycle.


### Backgrounding

The game will be automatically paused when the app is sent to the background,
and resumed when it comes back to the foreground. This behavior can be disabled by setting
`pauseWhenBackgrounded` to `false`.

```dart
class MyGame extends FlameGame {
MyGame() {
pauseWhenBackgrounded = false;
}
}
```

On the current Flutter stable (3.13), this flag is effectively ignored on
non-mobile platforms including the web.
40 changes: 40 additions & 0 deletions packages/flame/lib/src/game/flame_game.dart
Original file line number Diff line number Diff line change
Expand Up @@ -217,4 +217,44 @@ class FlameGame extends ComponentTreeRoot
}
}
}

/// Whether the game should pause when the app is backgrounded.
///
/// On the latest Flutter stable at the time of writing (3.13),
/// this is only working on Android and iOS.
///
/// Defaults to true.
bool pauseWhenBackgrounded = true;
bool _pausedBecauseBackgrounded = false;

@override
@mustCallSuper
void lifecycleStateChange(AppLifecycleState state) {
switch (state) {
case AppLifecycleState.resumed:
case AppLifecycleState.inactive:
if (_pausedBecauseBackgrounded) {
resumeEngine();
}
case AppLifecycleState.paused:
case AppLifecycleState.detached:
case AppLifecycleState.hidden:
if (pauseWhenBackgrounded && !paused) {
pauseEngine();
_pausedBecauseBackgrounded = true;
}
}
}

@override
void pauseEngine() {
_pausedBecauseBackgrounded = false;
super.pauseEngine();
}

@override
void resumeEngine() {
_pausedBecauseBackgrounded = false;
super.resumeEngine();
}
}
4 changes: 4 additions & 0 deletions packages/flame/lib/src/game/game_render_box.dart
Original file line number Diff line number Diff line change
Expand Up @@ -132,10 +132,14 @@ class GameRenderBox extends RenderBox with WidgetsBindingObserver {

void _bindLifecycleListener() {
WidgetsBinding.instance.addObserver(this);
didChangeAppLifecycleState(
WidgetsBinding.instance.lifecycleState ?? AppLifecycleState.resumed,
);
}

void _unbindLifecycleListener() {
WidgetsBinding.instance.removeObserver(this);
didChangeAppLifecycleState(AppLifecycleState.paused);
}

@override
Expand Down
22 changes: 22 additions & 0 deletions packages/flame/test/game/flame_game_test.dart
Original file line number Diff line number Diff line change
Expand Up @@ -693,6 +693,28 @@ void main() {
});
});
});

group('pauseWhenBackgrounded:', () {
testWithFlameGame('true', (game) async {
game.pauseWhenBackgrounded = true;

game.lifecycleStateChange(AppLifecycleState.paused);
expect(game.paused, true);

game.lifecycleStateChange(AppLifecycleState.resumed);
expect(game.paused, false);
});

testWithFlameGame('false', (game) async {
game.pauseWhenBackgrounded = false;

game.lifecycleStateChange(AppLifecycleState.paused);
expect(game.paused, false);

game.lifecycleStateChange(AppLifecycleState.resumed);
expect(game.paused, false);
});
});
});
}

Expand Down

0 comments on commit 61998e3

Please sign in to comment.