mirror of
				https://github.com/flame-engine/flame.git
				synced 2025-10-31 08:56:01 +08:00 
			
		
		
		
	 a1b6ffa04a
			
		
	
	a1b6ffa04a
	
	
	
		
			
			* Game as a component * Fix component stories * Effects are now components * Update effects docs * Handle swap of parent * Fix reAddChildren * Wait for children to be added * BaseComponent and PositionComponent to be non-abstract * Simplify HasGameRef * Revert so that onLoad can be null * Fix example description * Effects as components * Remove gameRef from addChildren * Fix hasGameRef * Start migrating effects * Updated comments of effect fields * Fix comments * Continue to fix sequence and combined effects * Upgrade ordered_set * Fix position_component_test * BaseComponent -> Component * Fix combined and sequence effects * Await components to be added in tests * Remove unnecessary game.update in tests * Fix some tests related to composition * BaseGame should be used in examples * Fix CombinedEffect test * Keyboard code to be based on Component * Fix keyboard tests * Fix analyze problems * Fix sequence_effect * Fix combined_effect_test * Store peak state instead of end state * Fix sequence_effect tests * Update tutorial * Fix tutorial 1 * Remove SimplePositionComponentEffect * Remove unused test variable * Update docs * Removed onMount * Remove onMount * Add missing dartdoc * Fix dart docs * Add super.update where needed * Move reAddChildren to component * Reorganize method order in game widget * preOffset -> initialDelay, postOffset -> peakDelay * Introduce component.onParentChange * Remove tests in wrong file * Fix composed component test * Add game lifecycle test * Use BaseGame for mouse cursor test * Oxygen should (?) not call super.update * Use BaseGame in keyboard_test * Fix onLoad to be properly cached * Re-add unintentionally removed override * Fix info for collision detection tests * Add test for correct lifecycle on parent change * Fix particles example * Add component lifecycle diagram to the docs * Add docs for the game lifecycle * onRemove should be called when a game is removed from the widget * Fix analyze errors * prepare should be called from the component itself, not its parent * Fix dartdoc * onParentChange -> onMount * onMount should have void as return type * Simplify the loaderFuture in GameWidget * Fix mock_canvas * Fix rebase problem * Remove asComponent * Less complex _loaderFuture * Add super.update to no_fcs parallax example * Fix async tests * Revert _loaderFuture * Fix analyze issues * await gameWithCollidables * Keep epsilon small where it can be * tappable methods should return bool * Game lifecycle is now the same as for Component * Remove mustCallSuper from component.update * Make onLoadCache protected * @internal on onLoadCache * Cache/Memoize debugPaint and debugTextPaint * Fix imports * Fix comments * Always call super.onLoad so that mixins can override it * Add forgotten super.onLoad * Bump coverage percentage * HasCollidables should override update * Fix Game comments * Fix some dartdoc * Apply suggestions from code review Co-authored-by: Erick <erickzanardoo@gmail.com> * Game + Loadable as mixins * Update packages/flame/lib/src/game/game_widget/game_widget.dart Co-authored-by: Luan Nico <luanpotter27@gmail.com> * Update loadable docs * Fix comments * Move fps_counter * Fix keyboard example * Fix dartdoc * Remove tutorials temporarily * Fix game lowlevel graph * Fix resize issue Co-authored-by: Erick <erickzanardoo@gmail.com> Co-authored-by: Luan Nico <luanpotter27@gmail.com>
		
			
				
	
	
		
			83 lines
		
	
	
		
			2.1 KiB
		
	
	
	
		
			Dart
		
	
	
	
	
	
			
		
		
	
	
			83 lines
		
	
	
		
			2.1 KiB
		
	
	
	
		
			Dart
		
	
	
	
	
	
| import 'package:flame/components.dart';
 | |
| import 'package:flame/extensions.dart';
 | |
| import 'package:flame/game.dart';
 | |
| import 'package:flame/input.dart';
 | |
| import 'package:flame/palette.dart';
 | |
| import 'package:flame_audio/audio_pool.dart';
 | |
| import 'package:flame_audio/flame_audio.dart';
 | |
| import 'package:flutter/widgets.dart' hide Animation;
 | |
| 
 | |
| void main() async {
 | |
|   runApp(GameWidget(game: AudioGame()));
 | |
| }
 | |
| 
 | |
| /// This example game showcases three possible use cases:
 | |
| ///
 | |
| /// 1. Use the static FlameAudio class to easily fire a sfx using the default
 | |
| /// configs for the button tap.
 | |
| /// 2. Uses a custom AudioPool for extremely efficient audio loading and pooling
 | |
| /// for tapping elsewhere.
 | |
| /// 3. Uses the Bgm utility for background music.
 | |
| class AudioGame extends FlameGame with TapDetector {
 | |
|   static Paint black = BasicPalette.black.paint();
 | |
|   static Paint gray = const PaletteEntry(Color(0xFFCCCCCC)).paint();
 | |
|   static TextPaint text = TextPaint(
 | |
|     config: TextPaintConfig(color: BasicPalette.white.color),
 | |
|   );
 | |
| 
 | |
|   late AudioPool pool;
 | |
| 
 | |
|   @override
 | |
|   Future<void> onLoad() async {
 | |
|     await super.onLoad();
 | |
|     pool = await AudioPool.create('fire_2.mp3', minPlayers: 3, maxPlayers: 4);
 | |
|     startBgmMusic();
 | |
|   }
 | |
| 
 | |
|   Rect get button => Rect.fromLTWH(20, size.y - 300, size.x - 40, 200);
 | |
| 
 | |
|   void startBgmMusic() {
 | |
|     FlameAudio.bgm.initialize();
 | |
|     FlameAudio.bgm.play('music/bg_music.ogg');
 | |
|   }
 | |
| 
 | |
|   void fireOne() {
 | |
|     FlameAudio.audioCache.play('sfx/fire_1.mp3');
 | |
|   }
 | |
| 
 | |
|   void fireTwo() {
 | |
|     pool.start();
 | |
|   }
 | |
| 
 | |
|   @override
 | |
|   void render(Canvas canvas) {
 | |
|     super.render(canvas);
 | |
|     canvas.drawRect(size.toRect(), black);
 | |
| 
 | |
|     text.render(
 | |
|       canvas,
 | |
|       '(click anywhere for 1)',
 | |
|       Vector2(size.x / 2, 200),
 | |
|       anchor: Anchor.topCenter,
 | |
|     );
 | |
| 
 | |
|     canvas.drawRect(button, gray);
 | |
| 
 | |
|     text.render(
 | |
|       canvas,
 | |
|       'click here for 2',
 | |
|       Vector2(size.x / 2, size.y - 200),
 | |
|       anchor: Anchor.bottomCenter,
 | |
|     );
 | |
|   }
 | |
| 
 | |
|   @override
 | |
|   void onTapDown(TapDownInfo details) {
 | |
|     if (button.containsPoint(details.eventPosition.game)) {
 | |
|       fireTwo();
 | |
|     } else {
 | |
|       fireOne();
 | |
|     }
 | |
|   }
 | |
| }
 |