[fix] Rotated crop handle (#3093)

This PR fixes a bug where local rotation was used in cropping handles
rather than absolute rotation.
![Kapture 2024-03-10 at 18 21
51](https://github.com/tldraw/tldraw/assets/23072548/71ee5e46-59de-4c1d-8f54-27052677c0f7)



### Change Type

- [x] `patch` — Bug fix

### Test Plan

1. Crop an image
2. Place the image into a rotated parent
3. Crop the image
4. Rotate the image
5. Crop the image

The handles should be accurately rotated in all cases.

### Release Notes

- Fixed a bug that could cause rotated cropping images to have
incorrectly rotated handles.
This commit is contained in:
Steve Ruiz 2024-03-11 09:03:06 +00:00 committed by GitHub
parent abf69e7107
commit a8b7d4e2d0
No known key found for this signature in database
GPG key ID: B5690EEEBB952194
4 changed files with 14 additions and 16 deletions

View file

@ -67,7 +67,7 @@ export class Cropping extends StateNode {
this.editor.updateInstanceState({ this.editor.updateInstanceState({
cursor: { cursor: {
type: cursorType, type: cursorType,
rotation: selectedShape.rotation, rotation: this.editor.getSelectionRotation(),
}, },
}) })
} }

View file

@ -1,4 +1,4 @@
import { StateNode, TLEventHandlers, TLPointerEventInfo, TLShape } from '@tldraw/editor' import { StateNode, TLEventHandlers, TLPointerEventInfo } from '@tldraw/editor'
import { CursorTypeMap } from './PointingResizeHandle' import { CursorTypeMap } from './PointingResizeHandle'
type TLPointingCropHandleInfo = TLPointerEventInfo & { type TLPointingCropHandleInfo = TLPointerEventInfo & {
@ -12,23 +12,19 @@ export class PointingCropHandle extends StateNode {
private info = {} as TLPointingCropHandleInfo private info = {} as TLPointingCropHandleInfo
private updateCursor(shape: TLShape) {
const cursorType = CursorTypeMap[this.info.handle!]
this.editor.updateInstanceState({
cursor: {
type: cursorType,
rotation: shape.rotation,
},
})
}
override onEnter = (info: TLPointingCropHandleInfo) => { override onEnter = (info: TLPointingCropHandleInfo) => {
this.info = info this.info = info
this.parent.setCurrentToolIdMask(info.onInteractionEnd) this.parent.setCurrentToolIdMask(info.onInteractionEnd)
const selectedShape = this.editor.getSelectedShapes()[0] const selectedShape = this.editor.getSelectedShapes()[0]
if (!selectedShape) return if (!selectedShape) return
this.updateCursor(selectedShape) const cursorType = CursorTypeMap[this.info.handle!]
this.editor.updateInstanceState({
cursor: {
type: cursorType,
rotation: this.editor.getSelectionRotation(),
},
})
this.editor.setCroppingShape(selectedShape.id) this.editor.setCroppingShape(selectedShape.id)
} }

View file

@ -35,7 +35,10 @@ export class PointingResizeHandle extends StateNode {
const selected = this.editor.getSelectedShapes() const selected = this.editor.getSelectedShapes()
const cursorType = CursorTypeMap[this.info.handle!] const cursorType = CursorTypeMap[this.info.handle!]
this.editor.updateInstanceState({ this.editor.updateInstanceState({
cursor: { type: cursorType, rotation: selected.length === 1 ? selected[0].rotation : 0 }, cursor: {
type: cursorType,
rotation: selected.length === 1 ? this.editor.getSelectionRotation() : 0,
},
}) })
} }

View file

@ -11,11 +11,10 @@ export class PointingRotateHandle extends StateNode {
private info = {} as PointingRotateHandleInfo private info = {} as PointingRotateHandleInfo
private updateCursor() { private updateCursor() {
const selectionRotation = this.editor.getSelectionRotation()
this.editor.updateInstanceState({ this.editor.updateInstanceState({
cursor: { cursor: {
type: CursorTypeMap[this.info.handle as RotateCorner], type: CursorTypeMap[this.info.handle as RotateCorner],
rotation: selectionRotation, rotation: this.editor.getSelectionRotation(),
}, },
}) })
} }