import 'dart:math'; import 'package:examples/commons/ember.dart'; import 'package:flame/components.dart'; import 'package:flame/game.dart'; import 'package:flame/input.dart'; class BenchmarkExample extends FlameGame with TapDetector { static const description = ''' See how many SpriteAnimationComponent's your platform can handle before it starts to drop in FPS, this is without any sprite batching and such. 100 animation components are added per tap. '''; final emberSize = Vector2.all(20); late final TextComponent emberCounter; final counterPrefix = 'Animations: '; final Random random = Random(); final world = World(); late final CameraComponent cameraComponent; @override Future onLoad() async { cameraComponent = CameraComponent(world: world); addAll([cameraComponent, world]); await cameraComponent.viewport.addAll([ FpsTextComponent( position: size - Vector2(0, 50), anchor: Anchor.bottomRight, ), emberCounter = TextComponent( position: size - Vector2(0, 25), anchor: Anchor.bottomRight, priority: 1, ), ]); world.add(Ember(size: emberSize, position: size / 2)); children.register(); } @override void update(double dt) { super.update(dt); emberCounter.text = '$counterPrefix ${world.children.query().length}'; } @override void onTapDown(TapDownInfo info) { world.addAll( List.generate( 100, (_) => Ember( size: emberSize, position: Vector2( (size.x / 2) * random.nextDouble() * (random.nextBool() ? 1 : -1), (size.y / 2) * random.nextDouble() * (random.nextBool() ? 1 : -1), ), ), ), ); } }