mirror of
https://github.com/flame-engine/flame.git
synced 2025-11-15 12:19:40 +08:00
* `TextPaint` to use `TextStyle` instead of `TextPaintConfig` * Update packages/flame/lib/src/text.dart Co-authored-by: Pasha Stetsenko <stpasha@google.com> * Removed BaseTextConfig and TextPaintConfig * Update text docs * Apply suggestions from code review Co-authored-by: Erick <erickzanardoo@gmail.com> * Remove generics * Update TextBoxExample * Update text examples variable names * Fix TextPaint in collision_detection example Co-authored-by: Pasha Stetsenko <stpasha@google.com> Co-authored-by: Erick <erickzanardoo@gmail.com>
47 lines
1.3 KiB
Dart
47 lines
1.3 KiB
Dart
import 'package:flame/game.dart';
|
|
import 'package:flame_oxygen/flame_oxygen.dart';
|
|
import 'package:flutter/material.dart';
|
|
|
|
import '../component/timer_component.dart';
|
|
|
|
class KawabungaSystem extends BaseSystem with UpdateSystem {
|
|
@override
|
|
List<Filter<Component>> get filters => [
|
|
Has<TextComponent>(),
|
|
Has<TimerComponent>(),
|
|
];
|
|
|
|
@override
|
|
void renderEntity(Canvas canvas, Entity entity) {
|
|
final timer = entity.get<TimerComponent>()!;
|
|
final textComponent = entity.get<TextComponent>()!;
|
|
final textRenderer = TextPaint(
|
|
style: textComponent.style.copyWith(
|
|
color: textComponent.style.color!.withOpacity(1 - timer.percentage),
|
|
),
|
|
);
|
|
|
|
textRenderer.render(
|
|
canvas,
|
|
textComponent.text,
|
|
Vector2.zero(),
|
|
);
|
|
}
|
|
|
|
@override
|
|
void update(double delta) {
|
|
for (final entity in entities) {
|
|
final textComponent = entity.get<TextComponent>()!;
|
|
final size = entity.get<SizeComponent>()!.size;
|
|
final textRenderer = TextPaint(style: textComponent.style);
|
|
size.setFrom(textRenderer.measureText(textComponent.text));
|
|
|
|
final timer = entity.get<TimerComponent>()!;
|
|
timer.timePassed = timer.timePassed + delta;
|
|
if (timer.done) {
|
|
entity.dispose();
|
|
}
|
|
}
|
|
}
|
|
}
|