mirror of
https://github.com/Comfy-Org/ComfyUI_frontend.git
synced 2026-01-26 19:09:52 +00:00
- Updated all imports from '@comfyorg/litegraph' to '@/lib/litegraph/src/' - Replaced deep dist imports with direct source paths - Updated CSS import in main.ts - All imports now use the @ alias consistently
39 lines
1.0 KiB
TypeScript
39 lines
1.0 KiB
TypeScript
import { useElementBounding } from '@vueuse/core'
|
|
|
|
import type { LGraphCanvas, Vector2 } from '@/lib/litegraph/src/litegraph'
|
|
|
|
/**
|
|
* Convert between canvas and client positions
|
|
* @param canvasElement - The canvas element
|
|
* @param lgCanvas - The litegraph canvas
|
|
* @returns The canvas position conversion functions
|
|
*/
|
|
export const useCanvasPositionConversion = (
|
|
canvasElement: Parameters<typeof useElementBounding>[0],
|
|
lgCanvas: LGraphCanvas
|
|
) => {
|
|
const { left, top, update } = useElementBounding(canvasElement)
|
|
|
|
const clientPosToCanvasPos = (pos: Vector2): Vector2 => {
|
|
const { offset, scale } = lgCanvas.ds
|
|
return [
|
|
(pos[0] - left.value) / scale - offset[0],
|
|
(pos[1] - top.value) / scale - offset[1]
|
|
]
|
|
}
|
|
|
|
const canvasPosToClientPos = (pos: Vector2): Vector2 => {
|
|
const { offset, scale } = lgCanvas.ds
|
|
return [
|
|
(pos[0] + offset[0]) * scale + left.value,
|
|
(pos[1] + offset[1]) * scale + top.value
|
|
]
|
|
}
|
|
|
|
return {
|
|
clientPosToCanvasPos,
|
|
canvasPosToClientPos,
|
|
update
|
|
}
|
|
}
|