feat(img): add img flip feature (#6785)

pull/6799/head
Konv Suu 2023-07-29 11:18:34 +08:00 committed by GitHub
parent e8c2860c7d
commit a3ccdeffc2
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
2 changed files with 31 additions and 2 deletions

View File

@ -11,6 +11,7 @@ import ZoomOutOutlined from '@ant-design/icons-vue/ZoomOutOutlined';
import CloseOutlined from '@ant-design/icons-vue/CloseOutlined';
import LeftOutlined from '@ant-design/icons-vue/LeftOutlined';
import RightOutlined from '@ant-design/icons-vue/RightOutlined';
import SwapOutlined from '@ant-design/icons-vue/SwapOutlined';
import useStyle from './style';
import { anyType } from '../_util/type';
@ -22,6 +23,8 @@ export const icons = {
close: <CloseOutlined />,
left: <LeftOutlined />,
right: <RightOutlined />,
flipX: <SwapOutlined />,
flipY: <SwapOutlined rotate={90} />,
};
const previewGroupProps = () => ({
previewPrefixCls: String,

View File

@ -36,6 +36,8 @@ export interface PreviewProps extends Omit<IDialogChildProps, 'onClose' | 'mask'
close?: VNode;
left?: VNode;
right?: VNode;
flipX?: VNode;
flipY?: VNode;
};
}
@ -60,10 +62,13 @@ const Preview = defineComponent({
props: previewProps,
emits: ['close', 'afterClose'],
setup(props, { emit, attrs }) {
const { rotateLeft, rotateRight, zoomIn, zoomOut, close, left, right } = reactive(props.icons);
const { rotateLeft, rotateRight, zoomIn, zoomOut, close, left, right, flipX, flipY } = reactive(
props.icons,
);
const scale = shallowRef(1);
const rotate = shallowRef(0);
const flip = reactive({ x: 1, y: 1 });
const [position, setPosition] = useFrameSetState<{
x: number;
y: number;
@ -130,6 +135,15 @@ const Preview = defineComponent({
const onRotateLeft = () => {
rotate.value -= 90;
};
const onFlipX = () => {
flip.x = -flip.x;
};
const onFlipY = () => {
flip.y = -flip.y;
};
const onSwitchLeft: MouseEventHandler = event => {
event.preventDefault();
// Without this mask close will abnormal
@ -180,6 +194,16 @@ const Preview = defineComponent({
onClick: onRotateLeft,
type: 'rotateLeft',
},
{
icon: flipX,
onClick: onFlipX,
type: 'flipX',
},
{
icon: flipY,
onClick: onFlipY,
type: 'flipY',
},
];
const onMouseUp: MouseEventHandler = () => {
@ -365,7 +389,9 @@ const Preview = defineComponent({
src={combinationSrc.value}
alt={props.alt}
style={{
transform: `scale3d(${scale.value}, ${scale.value}, 1) rotate(${rotate.value}deg)`,
transform: `scale3d(${flip.x * scale.value}, ${flip.y * scale.value}, 1) rotate(${
rotate.value
}deg)`,
}}
/>
</div>