mirror of
https://github.com/bggRGjQaUbCoE/PiliPlus.git
synced 2026-04-20 11:08:03 +08:00
@@ -10,6 +10,11 @@ class CustomHorizontalDragGestureRecognizer
|
||||
});
|
||||
|
||||
Offset? _initialPosition;
|
||||
Offset? get initialPosition => _initialPosition;
|
||||
|
||||
@override
|
||||
DeviceGestureSettings get gestureSettings => _gestureSettings;
|
||||
final _gestureSettings = DeviceGestureSettings(touchSlop: touchSlopH);
|
||||
|
||||
@override
|
||||
void addAllowedPointer(PointerDownEvent event) {
|
||||
|
||||
@@ -1,18 +1,17 @@
|
||||
import 'package:PiliPlus/common/widgets/gesture/horizontal_drag_gesture_recognizer.dart';
|
||||
import 'package:flutter/gestures.dart';
|
||||
|
||||
typedef IsBoundaryAllowed =
|
||||
bool Function(Offset? initialPosition, OffsetPair lastPosition);
|
||||
|
||||
class ImageHorizontalDragGestureRecognizer
|
||||
extends HorizontalDragGestureRecognizer {
|
||||
extends CustomHorizontalDragGestureRecognizer {
|
||||
ImageHorizontalDragGestureRecognizer({
|
||||
super.debugOwner,
|
||||
super.supportedDevices,
|
||||
super.allowedButtonsFilter,
|
||||
});
|
||||
|
||||
Offset? _initialPosition;
|
||||
|
||||
IsBoundaryAllowed? isBoundaryAllowed;
|
||||
|
||||
int? _pointer;
|
||||
@@ -26,20 +25,16 @@ class ImageHorizontalDragGestureRecognizer
|
||||
super.addPointer(event);
|
||||
}
|
||||
|
||||
@override
|
||||
void addAllowedPointer(PointerDownEvent event) {
|
||||
super.addAllowedPointer(event);
|
||||
_initialPosition = event.position;
|
||||
}
|
||||
|
||||
@override
|
||||
bool hasSufficientGlobalDistanceToAccept(
|
||||
PointerDeviceKind pointerDeviceKind,
|
||||
double? deviceTouchSlop,
|
||||
) {
|
||||
return globalDistanceMoved.abs() >
|
||||
computeHitSlop(pointerDeviceKind, gestureSettings) &&
|
||||
(isBoundaryAllowed?.call(_initialPosition, lastPosition) ?? true);
|
||||
return super.hasSufficientGlobalDistanceToAccept(
|
||||
pointerDeviceKind,
|
||||
deviceTouchSlop,
|
||||
) &&
|
||||
(isBoundaryAllowed?.call(initialPosition, lastPosition) ?? true);
|
||||
}
|
||||
|
||||
@override
|
||||
|
||||
@@ -118,8 +118,7 @@ class _GalleryViewerState extends State<GalleryViewer>
|
||||
if (PlatformUtils.isDesktop) {
|
||||
_tapGestureRecognizer.onSecondaryTapUp = _showDesktopMenu;
|
||||
}
|
||||
_horizontalDragGestureRecognizer = ImageHorizontalDragGestureRecognizer()
|
||||
..gestureSettings = gestureSettings;
|
||||
_horizontalDragGestureRecognizer = ImageHorizontalDragGestureRecognizer();
|
||||
_longPressGestureRecognizer = LongPressGestureRecognizer()
|
||||
..onLongPress = _onLongPress
|
||||
..gestureSettings = gestureSettings;
|
||||
|
||||
@@ -605,8 +605,8 @@ class _ImageState extends State<Image> with WidgetsBindingObserver {
|
||||
imgRatio > StyleString.imgMaxRatio &&
|
||||
imgHeight > widget.containerSize.height;
|
||||
if (isLongPic) {
|
||||
minScale =
|
||||
widget.containerSize.width / widget.containerSize.height * imgRatio;
|
||||
final compatWidth = math.min(650.0, widget.containerSize.width);
|
||||
minScale = compatWidth / widget.containerSize.height * imgRatio;
|
||||
maxScale = math.max(widget.maxScale, minScale * 3);
|
||||
}
|
||||
result = Viewer(
|
||||
|
||||
@@ -17,6 +17,8 @@
|
||||
|
||||
import 'dart:math' as math;
|
||||
|
||||
import 'package:PiliPlus/common/widgets/gesture/horizontal_drag_gesture_recognizer.dart'
|
||||
show touchSlopH;
|
||||
import 'package:PiliPlus/common/widgets/gesture/image_horizontal_drag_gesture_recognizer.dart';
|
||||
import 'package:PiliPlus/common/widgets/gesture/image_tap_gesture_recognizer.dart';
|
||||
import 'package:PiliPlus/utils/extension/num_ext.dart';
|
||||
@@ -138,17 +140,16 @@ class _ViewerState extends State<Viewer> with SingleTickerProviderStateMixin {
|
||||
_tapGestureRecognizer = widget.tapGestureRecognizer;
|
||||
_horizontalDragGestureRecognizer = widget.horizontalDragGestureRecognizer;
|
||||
|
||||
final gestureSettings = MediaQuery.maybeGestureSettingsOf(Get.context!);
|
||||
_scaleGestureRecognizer = ScaleGestureRecognizer(debugOwner: this)
|
||||
..dragStartBehavior = .start
|
||||
..onStart = _onScaleStart
|
||||
..onUpdate = _onScaleUpdate
|
||||
..onEnd = _onScaleEnd
|
||||
..gestureSettings = gestureSettings;
|
||||
..gestureSettings = DeviceGestureSettings(touchSlop: touchSlopH);
|
||||
_doubleTapGestureRecognizer = DoubleTapGestureRecognizer(debugOwner: this)
|
||||
..onDoubleTapDown = _onDoubleTapDown
|
||||
..onDoubleTap = _onDoubleTap
|
||||
..gestureSettings = gestureSettings;
|
||||
..gestureSettings = MediaQuery.maybeGestureSettingsOf(Get.context!);
|
||||
}
|
||||
|
||||
@override
|
||||
@@ -418,9 +419,9 @@ class _ViewerState extends State<Viewer> with SingleTickerProviderStateMixin {
|
||||
final dx = (1 - _scale) * containerWidth / 2;
|
||||
final dxOffset = (imageWidth - containerWidth) / 2;
|
||||
if (initialPosition.dx < lastPosition.global.dx) {
|
||||
return _position.dx == dx + dxOffset;
|
||||
return _round(_position.dx) == _round(dx + dxOffset);
|
||||
} else {
|
||||
return _position.dx == dx - dxOffset;
|
||||
return _round(_position.dx) == _round(dx - dxOffset);
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
Reference in New Issue
Block a user