mirror of
https://github.com/flame-engine/flame.git
synced 2025-11-01 10:38:17 +08:00
* Transforming PaletteEntry#paint into a full method * Fixing some errors that went unoticed * Update packages/flame/CHANGELOG.md Co-authored-by: Jochum van der Ploeg <jochum@vdploeg.net> * Update packages/flame/CHANGELOG.md Co-authored-by: Jochum van der Ploeg <jochum@vdploeg.net> * followup * format Co-authored-by: Jochum van der Ploeg <jochum@vdploeg.net>
38 lines
927 B
Dart
38 lines
927 B
Dart
import 'package:flame/extensions.dart';
|
|
import 'package:flame/game.dart';
|
|
import 'package:flame/gestures.dart';
|
|
import 'package:flame/palette.dart';
|
|
import 'package:flutter/material.dart';
|
|
|
|
/// Includes an example including advanced detectors
|
|
class MultitapGame extends BaseGame with MultiTouchTapDetector {
|
|
static final whitePaint = BasicPalette.white.paint();
|
|
static final tapSize = Vector2.all(50);
|
|
|
|
final Map<int, Rect> taps = {};
|
|
|
|
@override
|
|
void onTapDown(int pointerId, TapDownDetails details) {
|
|
taps[pointerId] =
|
|
details.globalPosition.toVector2().toPositionedRect(tapSize);
|
|
}
|
|
|
|
@override
|
|
void onTapUp(int pointerId, _) {
|
|
taps.remove(pointerId);
|
|
}
|
|
|
|
@override
|
|
void onTapCancel(int pointerId) {
|
|
taps.remove(pointerId);
|
|
}
|
|
|
|
@override
|
|
void render(Canvas canvas) {
|
|
super.render(canvas);
|
|
taps.values.forEach((rect) {
|
|
canvas.drawRect(rect, whitePaint);
|
|
});
|
|
}
|
|
}
|