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>
		
			
				
	
	
		
			147 lines
		
	
	
		
			4.1 KiB
		
	
	
	
		
			Dart
		
	
	
	
	
	
			
		
		
	
	
			147 lines
		
	
	
		
			4.1 KiB
		
	
	
	
		
			Dart
		
	
	
	
	
	
| import 'dart:math';
 | |
| 
 | |
| import 'package:flame/components.dart';
 | |
| import 'package:flame/effects.dart';
 | |
| import 'package:flame/extensions.dart';
 | |
| import 'package:flame/game.dart';
 | |
| import 'package:flame/geometry.dart';
 | |
| import 'package:flame/input.dart';
 | |
| import 'package:flame/palette.dart';
 | |
| import 'package:flame/sprite.dart';
 | |
| import 'package:flutter/animation.dart';
 | |
| import 'package:flutter/painting.dart';
 | |
| 
 | |
| import 'joystick_player.dart';
 | |
| 
 | |
| class JoystickAdvancedGame extends FlameGame
 | |
|     with HasDraggableComponents, HasTappableComponents {
 | |
|   late final JoystickPlayer player;
 | |
|   late final JoystickComponent joystick;
 | |
|   late final TextComponent speedText;
 | |
|   late final TextComponent directionText;
 | |
| 
 | |
|   @override
 | |
|   Future<void> onLoad() async {
 | |
|     await super.onLoad();
 | |
|     final image = await images.load('joystick.png');
 | |
|     final sheet = SpriteSheet.fromColumnsAndRows(
 | |
|       image: image,
 | |
|       columns: 6,
 | |
|       rows: 1,
 | |
|     );
 | |
|     joystick = JoystickComponent(
 | |
|       knob: SpriteComponent(
 | |
|         sprite: sheet.getSpriteById(1),
 | |
|         size: Vector2.all(100),
 | |
|       ),
 | |
|       background: SpriteComponent(
 | |
|         sprite: sheet.getSpriteById(0),
 | |
|         size: Vector2.all(150),
 | |
|       ),
 | |
|       margin: const EdgeInsets.only(left: 40, bottom: 40),
 | |
|     );
 | |
|     player = JoystickPlayer(joystick);
 | |
| 
 | |
|     final buttonSize = Vector2.all(80);
 | |
|     // A button with margin from the edge of the viewport that flips the
 | |
|     // rendering of the player on the X-axis.
 | |
|     final flipButton = HudButtonComponent(
 | |
|       button: SpriteComponent(
 | |
|         sprite: sheet.getSpriteById(2),
 | |
|         size: buttonSize,
 | |
|       ),
 | |
|       buttonDown: SpriteComponent(
 | |
|         sprite: sheet.getSpriteById(4),
 | |
|         size: buttonSize,
 | |
|       ),
 | |
|       margin: const EdgeInsets.only(
 | |
|         right: 80,
 | |
|         bottom: 60,
 | |
|       ),
 | |
|       onPressed: player.flipHorizontally,
 | |
|     );
 | |
| 
 | |
|     // A button with margin from the edge of the viewport that flips the
 | |
|     // rendering of the player on the Y-axis.
 | |
|     final flopButton = HudButtonComponent(
 | |
|       button: SpriteComponent(
 | |
|         sprite: sheet.getSpriteById(3),
 | |
|         size: buttonSize,
 | |
|       ),
 | |
|       buttonDown: SpriteComponent(
 | |
|         sprite: sheet.getSpriteById(5),
 | |
|         size: buttonSize,
 | |
|       ),
 | |
|       margin: const EdgeInsets.only(
 | |
|         right: 160,
 | |
|         bottom: 60,
 | |
|       ),
 | |
|       onPressed: player.flipVertically,
 | |
|     );
 | |
| 
 | |
|     final rotateEffect = RotateEffect(
 | |
|       angle: 0,
 | |
|       curve: Curves.bounceOut,
 | |
|       isAlternating: true,
 | |
|       speed: 2,
 | |
|     );
 | |
|     final rng = Random();
 | |
|     // A button, created from a shape, that adds a rotation effect to the player
 | |
|     // when it is pressed.
 | |
|     final shapeButton = HudButtonComponent(
 | |
|       button: Circle(radius: 35).toComponent(paint: BasicPalette.white.paint()),
 | |
|       buttonDown: Rectangle(size: buttonSize)
 | |
|           .toComponent(paint: BasicPalette.blue.paint()),
 | |
|       margin: const EdgeInsets.only(
 | |
|         right: 85,
 | |
|         bottom: 150,
 | |
|       ),
 | |
|       onPressed: () => player.add(
 | |
|         rotateEffect..angle = 8 * rng.nextDouble(),
 | |
|       ),
 | |
|     );
 | |
| 
 | |
|     final _regularTextConfig = TextPaintConfig(color: BasicPalette.white.color);
 | |
|     final _regular = TextPaint(config: _regularTextConfig);
 | |
|     speedText = TextComponent(
 | |
|       'Speed: 0',
 | |
|       textRenderer: _regular,
 | |
|     )..isHud = true;
 | |
|     directionText = TextComponent(
 | |
|       'Direction: idle',
 | |
|       textRenderer: _regular,
 | |
|     )..isHud = true;
 | |
| 
 | |
|     final speedWithMargin = HudMarginComponent(
 | |
|       margin: const EdgeInsets.only(
 | |
|         top: 80,
 | |
|         left: 80,
 | |
|       ),
 | |
|     )..add(speedText);
 | |
| 
 | |
|     final directionWithMargin = HudMarginComponent(
 | |
|       margin: const EdgeInsets.only(
 | |
|         top: 110,
 | |
|         left: 80,
 | |
|       ),
 | |
|     )..add(directionText);
 | |
| 
 | |
|     add(player);
 | |
|     add(joystick);
 | |
|     add(flipButton);
 | |
|     add(flopButton);
 | |
|     add(shapeButton);
 | |
|     add(speedWithMargin);
 | |
|     add(directionWithMargin);
 | |
|   }
 | |
| 
 | |
|   @override
 | |
|   void update(double dt) {
 | |
|     super.update(dt);
 | |
|     speedText.text = 'Speed: ${(joystick.intensity * player.maxSpeed).round()}';
 | |
|     final direction =
 | |
|         joystick.direction.toString().replaceAll('JoystickDirection.', '');
 | |
|     directionText.text = 'Direction: $direction';
 | |
|   }
 | |
| }
 |