mirror of
https://github.com/flame-engine/flame.git
synced 2025-10-30 00:17:20 +08:00
* Added Component.childrenFactory * fix some of the lint warnings * more lint warnings * remove changelog entry * more analyzer warnings * one more warning * one more warning * remove more unused imports * fix more warnings * another warning * one more warning * a lot more warnings * some more warnings * fix warnings in flame_svg * fix warnings in flame_bloc * Remove OrderedSet override feature * Remove testRandom change * Remove unnecessary type checks * Re-remove deprecated argument in random_test Co-authored-by: Pasha Stetsenko <stpasha@google.com>
78 lines
1.8 KiB
Dart
78 lines
1.8 KiB
Dart
import 'package:flame/extensions.dart';
|
|
import 'package:flame/game.dart';
|
|
import 'package:flame/input.dart';
|
|
import 'package:flame/palette.dart';
|
|
|
|
/// Showcases how to mix two advanced detectors
|
|
class MultitapAdvancedExample extends FlameGame
|
|
with MultiTouchTapDetector, MultiTouchDragDetector {
|
|
static const String description = '''
|
|
This showcases the use of both `MultiTouchTapDetector` and
|
|
`MultiTouchDragDetector` simultaneously. Drag multiple fingers on the screen
|
|
to see rectangles of different sizes being drawn.
|
|
''';
|
|
|
|
static final whitePaint = BasicPalette.white.paint();
|
|
static final tapSize = Vector2.all(50);
|
|
|
|
final Map<int, Rect> taps = {};
|
|
|
|
Vector2? start;
|
|
Vector2? end;
|
|
Rect? panRect;
|
|
|
|
@override
|
|
void onTapDown(int pointerId, TapDownInfo info) {
|
|
taps[pointerId] = info.eventPosition.game.toPositionedRect(tapSize);
|
|
}
|
|
|
|
@override
|
|
void onTapUp(int pointerId, _) {
|
|
taps.remove(pointerId);
|
|
}
|
|
|
|
@override
|
|
void onTapCancel(int pointerId) {
|
|
taps.remove(pointerId);
|
|
}
|
|
|
|
@override
|
|
void onDragCancel(int pointerId) {
|
|
end = null;
|
|
start = null;
|
|
panRect = null;
|
|
}
|
|
|
|
@override
|
|
void onDragStart(int pointerId, DragStartInfo info) {
|
|
end = null;
|
|
start = info.eventPosition.game;
|
|
}
|
|
|
|
@override
|
|
void onDragUpdate(int pointerId, DragUpdateInfo info) {
|
|
end = info.eventPosition.game;
|
|
}
|
|
|
|
@override
|
|
void onDragEnd(int pointerId, _) {
|
|
final start = this.start, end = this.end;
|
|
if (start != null && end != null) {
|
|
panRect = start.toPositionedRect(end - start);
|
|
}
|
|
}
|
|
|
|
@override
|
|
void render(Canvas canvas) {
|
|
final panRect = this.panRect;
|
|
super.render(canvas);
|
|
taps.values.forEach((rect) {
|
|
canvas.drawRect(rect, whitePaint);
|
|
});
|
|
|
|
if (panRect != null) {
|
|
canvas.drawRect(panRect, whitePaint);
|
|
}
|
|
}
|
|
}
|