import { ref, provide, onMounted, onUnmounted } from 'vue' import { usePreviewFitScale, usePreviewScrollYScale, usePreviewScrollXScale, usePreviewFullScale } from '@/hooks/index' import type { ChartEditStorageType } from '../index.d' import { PreviewScaleEnum } from '@/enums/styleEnum' export const SCALE_KEY = 'scale-value' export const useScale = (localStorageInfo: ChartEditStorageType) => { const entityRef = ref() const previewRef = ref() const width = ref(localStorageInfo.editCanvasConfig.width) const height = ref(localStorageInfo.editCanvasConfig.height) const scaleRef = ref({ width: 1, height: 1 }) provide(SCALE_KEY, scaleRef) // 监听鼠标滚轮 +ctrl 键 const useAddWheelHandle = (removeEvent: Function) => { addEventListener( 'wheel', (e: any) => { if (window?.$KeyboardActive?.ctrl) { e.preventDefault() e.stopPropagation() removeEvent() const fitDom = document.querySelector(".go-preview.fit") as HTMLElement if (fitDom) fitDom.style.overflow = 'auto' const transform = previewRef.value.style.transform // 使用正则解析 scale(1, 1) 中的两个数值 const regRes = transform.match(/scale\((\d+\.?\d*)*/) as RegExpMatchArray const width = regRes[1] if (e.wheelDelta > 0) { previewRef.value.style.transform = `scale(${parseFloat(Number(width).toFixed(2)) + 0.1})` } else { previewRef.value.style.transform = `scale(${parseFloat(Number(width).toFixed(2)) - 0.1})` } } }, { passive: false } ) } const updateScaleRef = (scale: { width: number; height: number }) => { // 这里需要解构,保证赋值给scaleRef的为一个新对象 // 因为scale始终为同一引用 scaleRef.value = { ...scale } } // 屏幕适配 onMounted(() => { switch (localStorageInfo.editCanvasConfig.previewScaleType) { case PreviewScaleEnum.FIT: ;(() => { const { calcRate, windowResize, unWindowResize } = usePreviewFitScale( width.value as number, height.value as number, previewRef.value, updateScaleRef ) calcRate() windowResize() useAddWheelHandle(unWindowResize) onUnmounted(() => { unWindowResize() }) })() break case PreviewScaleEnum.SCROLL_Y: ;(() => { const { calcRate, windowResize, unWindowResize } = usePreviewScrollYScale( width.value as number, height.value as number, previewRef.value, scale => { const dom = entityRef.value dom.style.width = `${width.value * scale.width}px` dom.style.height = `${height.value * scale.height}px` updateScaleRef(scale) } ) calcRate() windowResize() useAddWheelHandle(unWindowResize) onUnmounted(() => { unWindowResize() }) })() break case PreviewScaleEnum.SCROLL_X: ;(() => { const { calcRate, windowResize, unWindowResize } = usePreviewScrollXScale( width.value as number, height.value as number, previewRef.value, scale => { const dom = entityRef.value dom.style.width = `${width.value * scale.width}px` dom.style.height = `${height.value * scale.height}px` updateScaleRef(scale) } ) calcRate() windowResize() useAddWheelHandle(unWindowResize) onUnmounted(() => { unWindowResize() }) })() break case PreviewScaleEnum.FULL: ;(() => { const { calcRate, windowResize, unWindowResize } = usePreviewFullScale( width.value as number, height.value as number, previewRef.value, updateScaleRef ) calcRate() windowResize() useAddWheelHandle(unWindowResize) onUnmounted(() => { unWindowResize() }) })() break } }) return { entityRef, previewRef, scaleRef } }