mirror of
				https://github.com/flame-engine/flame.git
				synced 2025-11-04 04:47:13 +08:00 
			
		
		
		
	
		
			
				
	
	
		
			60 lines
		
	
	
		
			1.7 KiB
		
	
	
	
		
			Dart
		
	
	
	
	
	
			
		
		
	
	
			60 lines
		
	
	
		
			1.7 KiB
		
	
	
	
		
			Dart
		
	
	
	
	
	
import 'dart:ui';
 | 
						|
 | 
						|
import 'package:flame/anchor.dart';
 | 
						|
import 'package:flame/components/text_box_component.dart';
 | 
						|
import 'package:flame/components/text_component.dart';
 | 
						|
import 'package:flame/flame.dart';
 | 
						|
import 'package:flame/game.dart';
 | 
						|
import 'package:flame/palette.dart';
 | 
						|
import 'package:flame/text_config.dart';
 | 
						|
import 'package:flame/extensions/vector2.dart';
 | 
						|
import 'package:flutter/material.dart';
 | 
						|
 | 
						|
void main() async {
 | 
						|
  final Vector2 size = await Flame.util.initialDimensions();
 | 
						|
  runApp(MyGame(size).widget);
 | 
						|
}
 | 
						|
 | 
						|
TextConfig regular = TextConfig(color: BasicPalette.white.color);
 | 
						|
TextConfig tiny = regular.withFontSize(12.0);
 | 
						|
 | 
						|
class MyTextBox extends TextBoxComponent {
 | 
						|
  MyTextBox(String text)
 | 
						|
      : super(text, config: tiny, boxConfig: TextBoxConfig(timePerChar: 0.05));
 | 
						|
 | 
						|
  @override
 | 
						|
  void drawBackground(Canvas c) {
 | 
						|
    final Rect rect = Rect.fromLTWH(0, 0, width, height);
 | 
						|
    c.drawRect(rect, Paint()..color = const Color(0xFFFF00FF));
 | 
						|
    c.drawRect(
 | 
						|
        rect.deflate(boxConfig.margin),
 | 
						|
        Paint()
 | 
						|
          ..color = BasicPalette.black.color
 | 
						|
          ..style = PaintingStyle.stroke);
 | 
						|
  }
 | 
						|
}
 | 
						|
 | 
						|
class MyGame extends BaseGame {
 | 
						|
  MyGame(Vector2 screenSize) {
 | 
						|
    size = screenSize;
 | 
						|
    add(TextComponent('Hello, Flame', config: regular)
 | 
						|
      ..anchor = Anchor.topCenter
 | 
						|
      ..x = size.x / 2
 | 
						|
      ..y = 32.0);
 | 
						|
 | 
						|
    add(TextComponent('center', config: tiny)
 | 
						|
      ..anchor = Anchor.center
 | 
						|
      ..position = size / 2);
 | 
						|
 | 
						|
    add(TextComponent('bottomRight', config: tiny)
 | 
						|
      ..anchor = Anchor.bottomRight
 | 
						|
      ..position = size);
 | 
						|
 | 
						|
    add(MyTextBox(
 | 
						|
      'Lorem ipsum dolor sit amet, consectetur adipiscing elit. Etiam eget ligula eu lectus lobortis condimentum.',
 | 
						|
    )
 | 
						|
      ..anchor = Anchor.bottomLeft
 | 
						|
      ..y = size.y);
 | 
						|
  }
 | 
						|
}
 |