feat!: use raw pointer scale (>1 meaning zoom in, <1 meaning zoom out) rather than binary -1/1 for DelegateInputHandler
This commit is contained in:
@@ -269,7 +269,6 @@ class DelegateInputHandler implements InputHandler {
|
|||||||
// noop
|
// noop
|
||||||
}
|
}
|
||||||
|
|
||||||
double? _lastScale;
|
|
||||||
|
|
||||||
@override
|
@override
|
||||||
Future<void> onScaleUpdate(
|
Future<void> onScaleUpdate(
|
||||||
@@ -284,21 +283,8 @@ class DelegateInputHandler implements InputHandler {
|
|||||||
if (pointerCount == 1) {
|
if (pointerCount == 1) {
|
||||||
_inputDeltas[InputType.SCALE1] =
|
_inputDeltas[InputType.SCALE1] =
|
||||||
Vector3(focalPointDelta.x, focalPointDelta.y, 0);
|
Vector3(focalPointDelta.x, focalPointDelta.y, 0);
|
||||||
} else if (pointerCount == 2) {
|
} else if (pointerCount == 2) {
|
||||||
var zoomDelta = 0.0;
|
_inputDeltas[InputType.SCALE2] = Vector3(0, 0, scale);
|
||||||
if (_lastScale == null) {
|
|
||||||
if (scale < 0) {
|
|
||||||
zoomDelta = 1;
|
|
||||||
} else if (scale > 0) {
|
|
||||||
zoomDelta = -1;
|
|
||||||
}
|
|
||||||
_lastScale = scale;
|
|
||||||
} else {
|
|
||||||
zoomDelta = scale < _lastScale! ? 1 : -1;
|
|
||||||
_lastScale = scale;
|
|
||||||
}
|
|
||||||
|
|
||||||
_inputDeltas[InputType.SCALE2] = Vector3(0, 0, zoomDelta);
|
|
||||||
} else {
|
} else {
|
||||||
throw UnimplementedError("Only pointerCount <= 2 supported");
|
throw UnimplementedError("Only pointerCount <= 2 supported");
|
||||||
}
|
}
|
||||||
|
|||||||
Reference in New Issue
Block a user