ant-design-vue/components/vc-image/src/getFixScaleEleTransPosition.ts

62 lines
1.5 KiB
TypeScript

import { getClientSize } from '../../vc-util/Dom/css';
function fixPoint(key: 'x' | 'y', start: number, width: number, clientWidth: number) {
const startAddWidth = start + width;
const offsetStart = (width - clientWidth) / 2;
if (width > clientWidth) {
if (start > 0) {
return {
[key]: offsetStart,
};
}
if (start < 0 && startAddWidth < clientWidth) {
return {
[key]: -offsetStart,
};
}
} else if (start < 0 || startAddWidth > clientWidth) {
return {
[key]: start < 0 ? offsetStart : -offsetStart,
};
}
return {};
}
/**
* Fix positon x,y point when
*
* Ele width && height < client
* - Back origin
*
* - Ele width | height > clientWidth | clientHeight
* - left | top > 0 -> Back 0
* - left | top + width | height < clientWidth | clientHeight -> Back left | top + width | height === clientWidth | clientHeight
*
* Regardless of other
*/
export default function getFixScaleEleTransPosition(
width: number,
height: number,
left: number,
top: number,
): null | { x: number; y: number } {
const { width: clientWidth, height: clientHeight } = getClientSize();
let fixPos = null;
if (width <= clientWidth && height <= clientHeight) {
fixPos = {
x: 0,
y: 0,
};
} else if (width > clientWidth || height > clientHeight) {
fixPos = {
...fixPoint('x', left, width, clientWidth),
...fixPoint('y', top, height, clientHeight),
};
}
return fixPos;
}