马宇豪
2025-03-04 1b9fea7d4af68d8f933b2dc42bf6084b9646f64c
src/views/intellectInspect/intelligentLine/index.vue
@@ -1,6 +1,6 @@
<template>
    <div class="container" id="screenFull">
        <div class="big-title" @click="goBack()">国泰新华智能巡检系统</div>
        <div class="big-title" @click="goBack()">智能巡检系统</div>
        <div style="height: 20px;font-size: 14px;line-height: 20px; color: #00ffff; margin-top: 4px">{{ present }}</div>
        <div class="btns">
<!--            <div class="fullbtn" @click="onScreenfullClick">-->
@@ -20,7 +20,7 @@
        </div>
        <div class="blocks">
            <div>
            <div class="warning-part">
            <div class="warning-part" ref="draggableElement">
              <div class="warn-tit">异常警报:</div>
              <div class="warn-msg" v-if="excepOrder && excepOrder.length>0">
                <div class="warn-item" v-for="(item,index) in excepOrder" :key="index">
@@ -141,7 +141,13 @@
    data: Array<any>;
    excepOrder: Array<any>;
    id: string;
    defaultImg: string
    defaultImg: string;
    isDragging:boolean
    initialX:number|null
    initialY:number|null
    xOffset:number|null
    yOffset:number|null
    timer: null | any
}
export default {
    name: 'intelligentLine',
@@ -158,22 +164,31 @@
            data: [],
            excepOrder: [],
            id: '',
            defaultImg: new URL('../../../assets/default-img.jpg',import.meta.url).href
            defaultImg: new URL('../../../assets/default-img.jpg',import.meta.url).href,
            isDragging: false,
            initialX: 0,
            initialY: 0,
            xOffset: 0,
            yOffset: 0,
            timer: null
        });
        onMounted(() => {
            setInterval(() => {
            state.timer = setInterval(() => {
                state.present = new Date().toLocaleString();
            }, 1000);
            let curId = route.query.id
            state.id = curId.toString()
            getLine(state.id)
            getUrl(state.id)
            draggableElement.value.addEventListener('mousedown', handleMouseDown);
            draggableElement.value.addEventListener('mousemove', handleMouseMove);
            draggableElement.value.addEventListener('mouseup', handleMouseUp);
        });
      onActivated(()=>{
        onScreenfullClick();
      })
        const draggableElement = ref(null);
        const dataList = computed(() => {
            return userInfos.value.dataList;
        });
@@ -203,9 +218,10 @@
                    // 监听socket消息
                    state.socket.onmessage = (msg) => {
                      console.log(msg.data,'msg.data')
                      console.log(msg.data.rfidInfos,'rfidInfos')
                        if (msg.data === '连接成功') return;
                        userInfos.value.dataList = JSON.parse(msg.data.data.rfidInfos);
                        state.excepOrder = JSON.parse(msg.data.data.excepOrder);
                        userInfos.value.dataList = JSON.parse(msg.data).rfidInfos;
                        state.excepOrder = JSON.parse(msg.data).excepOrder;
                    };
                }
            } else {
@@ -253,6 +269,25 @@
            window.history.go(-1);
        };
      const handleMouseDown = (e) => {
        state.initialX = e.clientX - state.xOffset;
        state.initialY = e.clientY - state.yOffset;
        state.isDragging = true;
      };
      const handleMouseMove = (e) => {
        if (state.isDragging) {
          state.xOffset = e.clientX - state.initialX;
          state.yOffset = e.clientY - state.initialY;
          draggableElement.value.style.transform = `translate3d(${state.xOffset}px, ${state.yOffset}px, 0)`;
        }
      };
      const handleMouseUp = () => {
        state.isDragging = false;
      };
        // 页面关闭处理
        onUnmounted(() => {
            // 销毁监听
@@ -261,9 +296,14 @@
                    console.log('socket已经关闭');
                };
            })
            clearInterval(state.timer)
          draggableElement.value.removeEventListener('mousedown', handleMouseDown);
          draggableElement.value.removeEventListener('mousemove', handleMouseMove);
          draggableElement.value.removeEventListener('mouseup', handleMouseUp);
        });
        return {
            dataList,
            draggableElement,
            goBack,
            onScreenfullClick,
            ...toRefs(state)
@@ -422,16 +462,17 @@
                div {
                    margin-bottom: 5px;
                    display: flex;
                    align-items: flex-start;
                    &:last-of-type {
                        margin-bottom: 0;
                    }
                    span {
                        display: inline-block;
                        white-space: nowrap;
                        width: 50%;
                        font-size: 13px;
                        color: #fff;
                        text-align: left;
                        word-break: break-all;
                        &:first-of-type {
                            text-align: right;
@@ -632,16 +673,17 @@
                div {
                    width: 100%;
                    margin-bottom: 5px;
                    display: flex;
                    align-items: flex-start;
                    &:last-of-type {
                        margin-bottom: 0;
                    }
                    span {
                        display: inline-block;
                        white-space: nowrap;
                        width: 50%;
                        font-size: 13px;
                        color: #fff;
                        text-align: left;
                        word-break: break-all;
                        &:first-of-type {
                            text-align: right;
@@ -841,16 +883,17 @@
                div {
                    width: 100%;
                    margin-bottom: 2px;
                    display: flex;
                    align-items: flex-start;
                    &:last-of-type {
                        margin-bottom: 0;
                    }
                    span {
                        width: 50%;
                        display: inline-block;
                        white-space: nowrap;
                        font-size: 12px;
                        color: #fff;
                        text-align: left;
                        word-break: break-all;
                        &:first-of-type {
                            text-align: right;
@@ -1407,6 +1450,7 @@
              right: 60px;
              padding: 10px;
              color: rgb(0, 255, 255);
              backdrop-filter: blur(5px);
              .warn-tit{
                height: 26px;