repaint 0.0.8 repaint: ^0.0.8 copied to clipboard
Library for creating and managing a canvas similar to CustomPaint but with more features.
RePaint #
Library for creating and managing a canvas similar to CustomPaint but with more features.
How to #
Handle mouse events #
@override
@mustCallSuper
void onPointerEvent(PointerEvent event) {
case (event) {
case PointerDownEvent e:
case PointerUpEvent e:
case PointerCancelEvent e:
case PointerPanZoomStartEvent e:
case PointerPanZoomUpdateEvent e:
case PointerPanZoomEndEvent e:
case PointerScrollEvent e:
case PointerSignalEvent e:
case PointerHoverEvent e:
break;
case PointerMoveEvent e:
// Move the [_rect] by the [_offset] on mouse drag
final rect = _rect.shift(_offset);
if (!rect.contains(e.localPosition)) return;
_offset += move.delta;
}
}
copied to clipboard
Handle keyboard events #
To handle keyboard events you can use HardwareKeyboard manager:
bool _onKeyEvent(KeyEvent event) {
if (event.deviceType != KeyEventDeviceType.keyboard) return false;
if (event is! KeyDownEvent) return false;
// F1 - do something
switch (event.logicalKey) {
case LogicalKeyboardKey.f1:
doSomething();
return true;
default:
return false;
}
}
@override
void mount(_, __) {
HardwareKeyboard.instance.addHandler(_onKeyEvent);
}
@override
void unmount() {
HardwareKeyboard.instance.removeHandler(_onKeyEvent);
}
copied to clipboard
or wrap RePaint with Focus widget and use onKeyEvent to handle keyboard events:
final painter = RePainterImpl();
Widget build(BuildContext context) {
return Focus(
onKeyEvent: painter.onKeyEvent,
child: RePaint(
painter: painter,
),
);
}
copied to clipboard