mirror of
				https://github.com/flame-engine/flame.git
				synced 2025-11-04 04:47:13 +08:00 
			
		
		
		
	
		
			
				
	
	
		
			65 lines
		
	
	
		
			1.7 KiB
		
	
	
	
		
			Dart
		
	
	
	
	
	
			
		
		
	
	
			65 lines
		
	
	
		
			1.7 KiB
		
	
	
	
		
			Dart
		
	
	
	
	
	
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<void> 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<Ember>();
 | 
						|
  }
 | 
						|
 | 
						|
  @override
 | 
						|
  void update(double dt) {
 | 
						|
    super.update(dt);
 | 
						|
    emberCounter.text =
 | 
						|
        '$counterPrefix ${world.children.query<Ember>().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),
 | 
						|
          ),
 | 
						|
        ),
 | 
						|
      ),
 | 
						|
    );
 | 
						|
  }
 | 
						|
}
 |