mirror of
https://github.com/Comfy-Org/ComfyUI_frontend.git
synced 2026-04-21 23:09:39 +00:00
Backport of #9617 to `core/1.41` Automatically created by backport workflow. ┆Issue is synchronized with this [Notion page](https://www.notion.so/PR-9663-backport-core-1-41-Even-further-app-fixes-31e6d73d365081e0a64bc958cf8d1bbb) by [Unito](https://www.unito.io) Co-authored-by: AustinMroz <austin@comfy.org>
61 lines
1.6 KiB
Vue
61 lines
1.6 KiB
Vue
<script setup lang="ts">
|
|
import { computed, ref, useTemplateRef } from 'vue'
|
|
|
|
const zoomPane = useTemplateRef('zoomPane')
|
|
|
|
const zoom = ref(1.0)
|
|
const panX = ref(0.0)
|
|
const panY = ref(0.0)
|
|
|
|
function handleWheel(e: WheelEvent) {
|
|
const zoomPaneEl = zoomPane.value
|
|
if (!zoomPaneEl || (e.deltaY < 0 ? zoom.value > 1200 : zoom.value < -500))
|
|
return
|
|
|
|
zoom.value -= e.deltaY
|
|
const { x, y, width, height } = zoomPaneEl.getBoundingClientRect()
|
|
const offsetX = e.clientX - x - width / 2
|
|
const offsetY = e.clientY - y - height / 2
|
|
const scaler = 1.1 ** (e.deltaY / -30)
|
|
|
|
panY.value = panY.value * scaler - offsetY * (scaler - 1)
|
|
panX.value = panX.value * scaler - offsetX * (scaler - 1)
|
|
}
|
|
|
|
let dragging = false
|
|
function handleDown(e: PointerEvent) {
|
|
if (e.button !== 0 && e.button !== 1) return
|
|
|
|
const zoomPaneEl = zoomPane.value
|
|
if (!zoomPaneEl) return
|
|
zoomPaneEl.parentElement?.focus()
|
|
|
|
zoomPaneEl.setPointerCapture(e.pointerId)
|
|
dragging = true
|
|
}
|
|
function handleMove(e: PointerEvent) {
|
|
if (!dragging) return
|
|
panX.value += e.movementX
|
|
panY.value += e.movementY
|
|
}
|
|
|
|
const transform = computed(() => {
|
|
const scale = 1.1 ** (zoom.value / 30)
|
|
const matrix = [scale, 0, 0, scale, panX.value, panY.value]
|
|
return `matrix(${matrix.join(',')})`
|
|
})
|
|
</script>
|
|
<template>
|
|
<div
|
|
ref="zoomPane"
|
|
class="place-content-center contain-size"
|
|
@wheel="handleWheel"
|
|
@pointerdown.prevent="handleDown"
|
|
@pointermove="handleMove"
|
|
@pointerup="dragging = false"
|
|
@pointercancel="dragging = false"
|
|
>
|
|
<slot :style="{ transform }" />
|
|
</div>
|
|
</template>
|