From d41a2db512cf9e143d212c060550a8678acb31fb Mon Sep 17 00:00:00 2001 From: nihilism9 Date: Wed, 18 Sep 2024 20:28:33 +0800 Subject: [PATCH] fix: fix the error of image rotating too many times after reseting image (#3108) --- src/image-viewer/hooks/useRotate.ts | 23 ++++++++++++++++++++--- 1 file changed, 20 insertions(+), 3 deletions(-) diff --git a/src/image-viewer/hooks/useRotate.ts b/src/image-viewer/hooks/useRotate.ts index 3ad0accfb6..f8e9fb5800 100644 --- a/src/image-viewer/hooks/useRotate.ts +++ b/src/image-viewer/hooks/useRotate.ts @@ -1,14 +1,31 @@ // 旋转控制 -import { useCallback, useState } from 'react'; +import { useCallback, useRef, useState } from 'react'; const useRotate = () => { + // There is an useEffect in the line 472 of ImageViewerModal.tsx, so we need to use a ref to store the rotateZ value. + const rotRef = useRef(0); const [rotateZ, setRotateZ] = useState(0); const onRotate = useCallback((ROTATE_COUNT: number) => { - setRotateZ((rotateZ) => rotateZ + ROTATE_COUNT); + setRotateZ((rotateZ) => { + rotRef.current = rotateZ + ROTATE_COUNT; + return rotateZ + ROTATE_COUNT; + }); }, []); - const onResetRotate = useCallback(() => setRotateZ(0), []); + const onResetRotate = useCallback(() => { + let degreeToRotate = rotRef.current % 360; + // make sure we always rotate to the shortest direction + if (Math.abs(degreeToRotate) > 180) { + degreeToRotate = (degreeToRotate + 360) % 360; + } + if (degreeToRotate !== 0) { + setRotateZ((rotateZ) => { + rotRef.current = rotateZ - degreeToRotate; + return rotateZ - degreeToRotate; + }); + } + }, []); return { rotateZ,