#
luxiaotao1123
2024-03-15 ee9e27f969ccd8acb5b71546fcb9bd7e44bca8b7
zy-asrs-flow/src/pages/map/utils.js
@@ -1,4 +1,5 @@
import * as PIXI from 'pixi.js';
import * as TWEEDLE from 'tweedle.js';
let app = null;
let mapContainer = null;
@@ -21,8 +22,8 @@
})
export const SENSOR_TYPE = Object.freeze({
    AGV: "AGV",
    SHELF: "SHELF",
    AGV: "AGV",
})
export const getRealPosition = (x, y, mapContainer) => {
@@ -240,4 +241,81 @@
export const deepCopy = (data) => {
    return JSON.parse(JSON.stringify(data));
}
export const pureNumStr = (param) => {
    if (param) {
        return Number(param);
    } else {
        return '';
    }
}
export const findSpriteByUuid = (uuid) => {
    return mapContainer?.children?.find(child => child?.data?.uuid === uuid);
}
export const sensorTypeSelectOptions = (intl) => {
    let options = [];
    Object.entries(SENSOR_TYPE).forEach(([key, value]) => {
        switch (key) {
            case SENSOR_TYPE.SHELF:
                options.push({
                    value: value,
                    label: intl.formatMessage({ id: 'map.sensor.type.shelf', defaultMessage: '货架' })
                })
                break;
            case SENSOR_TYPE.AGV:
                options.push({
                    value: value,
                    label: intl.formatMessage({ id: 'map.sensor.type.agv', defaultMessage: '无人小车' })
                })
                break;
            default:
                break;
        }
    })
    return options;
}
export const adaptScreen = () => {
    if (!mapContainer || !app) {
        return;
    }
    if (mapContainer.children.length === 0) {
        return;
    }
    let minX, maxX, minY, maxY;
    for (let sprite of mapContainer.children) {
        let bounds = sprite.getBounds();
        minX = minX !== undefined ? Math.min(minX, bounds.x) : bounds.x;
        minY = minY !== undefined ? Math.min(minY, bounds.y) : bounds.y;
        maxX = maxX !== undefined ? Math.max(maxX, bounds.x + bounds.width) : bounds.x + bounds.width;
        maxY = maxY !== undefined ? Math.max(maxY, bounds.y + bounds.height) : bounds.y + bounds.height;
    }
    // 矩形中心
    let centerPoint = {
        x: (minX + maxX) / 2 * mapContainer.scale.x,
        y: (minY + maxY) / 2 * mapContainer.scale.y
    };
    let newScale = Math.min(
        app.renderer.width / (maxX - minX) * 0.9, // 90%的宽度
        app.renderer.height / (maxY - minY) * 0.9 // 90%的高度
    );
    new TWEEDLE.Tween(mapContainer.scale).easing(TWEEDLE.Easing.Quadratic.Out)
        .to({
            x: newScale,
            y: newScale
        }, 200).start();
    new TWEEDLE.Tween(mapContainer.position).easing(TWEEDLE.Easing.Quadratic.Out)
        .to({
            x: app.renderer.width / 2 - centerPoint.x * newScale,
            y: app.renderer.height / 2 - centerPoint.y * newScale
        }, 200).start();
}