| 1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283 |
- import { computed } from 'vue'
- import { MutationTypes, useStore } from '@/store'
- import { PPTElement, Slide } from '@/types/slides'
- import { ElementAlignCommand, ElementAlignCommands } from '@/types/edit'
- import { getElementListRange } from '@/utils/element'
- import { VIEWPORT_SIZE, VIEWPORT_ASPECT_RATIO } from '@/configs/canvas'
- import useHistorySnapshot from './useHistorySnapshot'
- export default () => {
- const store = useStore()
- const activeElementIdList = computed(() => store.state.activeElementIdList)
- const activeElementList = computed<PPTElement[]>(() => store.getters.activeElementList)
- const currentSlide = computed<Slide>(() => store.getters.currentSlide)
- const { addHistorySnapshot } = useHistorySnapshot()
- /**
- * 将所有选中的元素对齐到画布
- * @param command 对齐方向
- */
- const alignElementToCanvas = (command: ElementAlignCommand) => {
- const viewportWidth = VIEWPORT_SIZE
- const viewportHeight = VIEWPORT_SIZE * VIEWPORT_ASPECT_RATIO
- const { minX, maxX, minY, maxY } = getElementListRange(activeElementList.value)
-
- const newElementList: PPTElement[] = JSON.parse(JSON.stringify(currentSlide.value.elements))
- for (const element of newElementList) {
- if (!activeElementIdList.value.includes(element.id)) continue
-
- // 水平垂直居中
- if (command === ElementAlignCommands.CENTER) {
- const offsetY = minY + (maxY - minY) / 2 - viewportHeight / 2
- const offsetX = minX + (maxX - minX) / 2 - viewportWidth / 2
- element.top = element.top - offsetY
- element.left = element.left - offsetX
- }
- // 顶部对齐
- if (command === ElementAlignCommands.TOP) {
- const offsetY = minY - 0
- element.top = element.top - offsetY
- }
- // 垂直居中
- else if (command === ElementAlignCommands.VERTICAL) {
- const offsetY = minY + (maxY - minY) / 2 - viewportHeight / 2
- element.top = element.top - offsetY
- }
- // 底部对齐
- else if (command === ElementAlignCommands.BOTTOM) {
- const offsetY = maxY - viewportHeight
- element.top = element.top - offsetY
- }
-
- // 左侧对齐
- else if (command === ElementAlignCommands.LEFT) {
- const offsetX = minX - 0
- element.left = element.left - offsetX
- }
- // 水平居中
- else if (command === ElementAlignCommands.HORIZONTAL) {
- const offsetX = minX + (maxX - minX) / 2 - viewportWidth / 2
- element.left = element.left - offsetX
- }
- // 右侧对齐
- else if (command === ElementAlignCommands.RIGHT) {
- const offsetX = maxX - viewportWidth
- element.left = element.left - offsetX
- }
- }
-
- store.commit(MutationTypes.UPDATE_SLIDE, { elements: newElementList })
- addHistorySnapshot()
- }
- return {
- alignElementToCanvas,
- }
- }
|