From d62a5f34ef60949ef6bef74fd9c48c20b4e65d83 Mon Sep 17 00:00:00 2001
From: wangfei <3597712270@qq.com>
Date: 星期五, 09 八月 2024 13:19:37 +0800
Subject: [PATCH] 钢化模块旋转更改,下片台
---
UI-Project/src/views/largescreen/largescreen.vue | 675 ++++++++++++++++++++++++++++++++++----------------------
1 files changed, 408 insertions(+), 267 deletions(-)
diff --git a/UI-Project/src/views/largescreen/largescreen.vue b/UI-Project/src/views/largescreen/largescreen.vue
index 4f2d4ae..bd641d5 100644
--- a/UI-Project/src/views/largescreen/largescreen.vue
+++ b/UI-Project/src/views/largescreen/largescreen.vue
@@ -1,107 +1,116 @@
<template>
- <el-card style="flex: 1;margin-left: 10px;margin-top: 10px;margin-right: 10px;" v-loading="loading">
- <el-scrollbar height="600px">
- <div id="top" style="height: 150px;display: flex;">
- <div v-for="(rect, index) in adjustedRects"
- :key="index"
- :style="{ width: '1000px', height: '100px',margin: '5px',}">
- <div ref="setChartDom(index, $el)" style="width: 100%; height: 100%;"></div>
- <div style="text-align: center;">
- {{ rect.thisProcess }}</div>
- </div>
- </div>
- <div style="display: flex;">
- <div id="centerleft" style="margin-top: 10px;height: 240px;width: 340px;background-color: #911005;">
- <el-table height="240" ref="table" width="340px"
- @selection-change="handleSelectionChange"
- :data="tableData" :header-cell-style="{background:'#F2F3F5 ',color:'#1D2129'}">
- <el-table-column fixed prop="orderId" align="center" :label="$t('large.number')" min-width="110" />
- <el-table-column prop="project" align="center" :label="$t('large.projectname')" min-width="100" />
- <el-table-column prop="responsibleProcess" align="center" :label="$t('large.responsibleprocess')" min-width="100" />
- <el-table-column prop="breakageQuantity" align="center" :label="$t('large.numberfractions')" min-width="110" />
- <el-table-column prop="patchProcesses" align="center" :label="$t('large.process')" min-width="100" />
- <el-table-column fixed="right" :label="$t('large.operate')" align="center" width="100">
- <template #default="scope">
- <el-button size="mini" type="text" plain @click="handleBinda">{{ $t('large.mes') }}</el-button>
- </template>
- </el-table-column>
- </el-table>
- </div>
- <div id="center" style="margin-top: 10px;margin-left: 10px; height: 240px;width: 750px;">
- <img src="../../assets/d1.png" alt="" style="margin-left: -30px; width: 110%;height: 100%;position: relative;">
+ <el-card style="flex: 1;margin-left: 10px;margin-top: 10px;margin-right: 10px;" v-loading="loading">
+ <el-scrollbar height="600px">
+<div id="top" style="height: 150px;display: flex;">
+ <div class="echarts-container">
+ <div v-for="(processData, index) in processesData" :key="index" class="echarts-item">
+ <div :id="'pieChart_' + index" class="pie-chart"></div>
</div>
- <div id="centerright" style="margin-top: 10px;margin-left: 10px; height: 240px;width: 240px;background-color: #911005;">
- <el-table height="240" ref="table" width="340px"
- @selection-change="handleSelectionChange"
- :data="tableDatab" :header-cell-style="{background:'#F2F3F5 ',color:'#1D2129'}">
- <el-table-column prop="projectNo" align="center" :label="$t('large.projectnumber')" min-width="50" />
- <el-table-column prop="projectName" align="center" :label="$t('large.projectname')" min-width="50" />
- </el-table>
- </div>
+</div>
+</div>
+<div style="display: flex;">
+<div id="centerleft" style="margin-top: 10px;height: 240px;width: 340px;background-color: #911005;">
+ <el-table height="240" ref="table" width="340px"
+ @selection-change="handleSelectionChange"
+ :data="tableData" :header-cell-style="{background:'#F2F3F5 ',color:'#1D2129'}">
+ <el-table-column fixed prop="orderId" align="center" :label="$t('large.number')" min-width="110" />
+ <el-table-column prop="project" align="center" :label="$t('large.projectname')" min-width="100" />
+ <el-table-column prop="responsibleProcess" align="center" :label="$t('large.responsibleprocess')" min-width="100" />
+ <el-table-column prop="breakageQuantity" align="center" :label="$t('large.numberfractions')" min-width="110" />
+ <el-table-column prop="patchProcesses" align="center" :label="$t('large.process')" min-width="100" />
+ <el-table-column fixed="right" :label="$t('large.operate')" align="center" width="100">
+ <template #default="scope">
+ <el-button size="mini" type="text" plain @click="handleBinda">{{ $t('large.mes') }}</el-button>
+ </template>
+ </el-table-column>
+ </el-table>
+</div>
+<div id="parent" style="margin-top: 10px;margin-left: 10px; height: 240px;width: 750px;">
+ <img src="../../assets/dpxsa.png" alt="" style="margin-left: -10px; width: 100%;height: 100%;position: relative;">
+ <div id="lipiana" v-show="woshia"></div>
+ <div id="lipianb" v-show="woshia"></div>
+ <div id="lipianc" v-show="woshic"></div>
+ <div id="lipiand" v-show="woshic"></div>
+ <div id="overlay" v-show="flake"></div>
+ <div id="overlayb" v-show="flakeb"></div>
+ <div id="overlayc" v-show="flakec"></div>
+ <div id="overlayd" v-show="flaked"></div>
+ <div id="longa" v-show="dalipiana"></div>
+ <div id="longb" v-show="dalipianb"></div>
+ <div id="shangpianji" v-show="shangpian"></div>
+</div>
+<div id="centerright" style="margin-top: 10px;margin-left: 10px; height: 240px;width: 240px;background-color: #911005;">
+ <el-table height="240" ref="table" width="340px"
+ @selection-change="handleSelectionChange"
+ :data="tableDatab" :header-cell-style="{background:'#F2F3F5 ',color:'#1D2129'}">
+ <el-table-column prop="projectNo" align="center" :label="$t('large.projectnumber')" min-width="50" />
+ <el-table-column prop="projectName" align="center" :label="$t('large.projectname')" min-width="50" />
+ </el-table>
+</div>
</div>
<div id="bottom" style="margin-top: 10px;height: 190px;background-color: #911005;">
- <el-table height="190" ref="table"
- @selection-change="handleSelectionChange"
- :data="tableDatac" :header-cell-style="{background:'#F2F3F5 ',color:'#1D2129'}">
- <el-table-column prop="orderId" align="center" :label="$t('large.orderId')" min-width="50" />
- <el-table-column prop="customerName" align="center" :show-overflow-tooltip="true" :label="$t('large.customerName')" min-width="90" />
- <el-table-column prop="project" align="center" :label="$t('large.project')" min-width="50" />
- <el-table-column prop="area" align="center" :label="$t('large.are')" min-width="50" />
- <el-table-column prop="quantity" align="center" :label="$t('large.quantity')" min-width="50" />
- <el-table-column
- align="center"
- :label="$t('large.warehousing')"
- min-width="50"
- prop="warehousing"
- >
- <template #default="scope">
- <el-tag :type="getStatusType(scope.row.warehousing)">
- {{ getStatusText(scope.row.warehousing) }}
- </el-tag>
- </template>
- </el-table-column>
- <el-table-column prop="deliveryDate" align="center" :label="$t('large.deliveryDate')" min-width="50" />
- </el-table>
+<el-table height="190" ref="table"
+ @selection-change="handleSelectionChange"
+ :data="tableDatac" :header-cell-style="{background:'#F2F3F5 ',color:'#1D2129'}">
+ <el-table-column prop="orderId" align="center" :label="$t('large.orderId')" min-width="50" />
+ <el-table-column prop="customerName" align="center" :show-overflow-tooltip="true" :label="$t('large.customerName')" min-width="90" />
+ <el-table-column prop="project" align="center" :label="$t('large.project')" min-width="50" />
+ <el-table-column prop="area" align="center" :label="$t('large.are')" min-width="50" />
+ <el-table-column prop="quantity" align="center" :label="$t('large.quantity')" min-width="50" />
+ <el-table-column
+ align="center"
+ :label="$t('large.warehousing')"
+ min-width="50"
+ prop="warehousing"
+ >
+ <template #default="scope">
+ <el-tag :type="getStatusType(scope.row.warehousing)">
+ {{ getStatusText(scope.row.warehousing) }}
+ </el-tag>
+ </template>
+ </el-table-column>
+ <el-table-column prop="deliveryDate" align="center" :label="$t('large.deliveryDate')" min-width="50" />
+ </el-table>
</div>
- </el-scrollbar>
- </el-card>
- <el-dialog v-model="blinda" top="10vh" width="80%" :title="$t('large.brokeno')">
- <el-table height="500" ref="table"
- @selection-change="handleSelectionChange"
- :data="tableData" :header-cell-style="{background:'#F2F3F5 ',color:'#1D2129'}">
- <el-table-column prop="reportingWorkTime" fixed align="center" :label="$t('large.time')" min-width="110" />
- <el-table-column prop="orderId" fixed align="center" :label="$t('large.number')" min-width="110" />
- <el-table-column prop="reportingWorkId" align="center" :label="$t('large.jobnumber')" min-width="120" />
- <el-table-column prop="productionId" align="center" :label="$t('large.productionnumber')" min-width="130" />
- <el-table-column prop="processId" align="center" :label="$t('large.cardnumber')" min-width="140" />
- <el-table-column prop="project" align="center" :label="$t('large.projectname')" min-width="110" />
- <el-table-column prop="batch" align="center" :label="$t('large.batch')" min-width="110" />
- <el-table-column prop="reviewer" align="center" :label="$t('large.detailID')" min-width="110" />
- <el-table-column prop="orderSort" align="center" :label="$t('large.serialnumber')" min-width="110" />
- <el-table-column prop="productName" align="center" :label="$t('large.productname')" :show-overflow-tooltip="true" min-width="220" />
- <el-table-column prop="technologyNumber" align="center" :label="$t('large.serial')" min-width="110" />
- <el-table-column prop="glassAddress" align="center" :label="$t('large.slicemarker')" min-width="130" />
- <el-table-column prop="patchNum" align="center" :label="$t('large.numberpatches')" min-width="110" />
- <el-table-column prop="width" align="center" :label="$t('large.width')" min-width="110" />
- <el-table-column prop="height" align="center" :label="$t('large.height')" min-width="110" />
- <el-table-column prop="shape" align="center" :label="$t('large.shape')" min-width="110" />
- <el-table-column prop="responsibleProcess" align="center" :label="$t('large.responsibleprocess')" min-width="110" />
- <el-table-column prop="patchProcesses" align="center" :label="$t('large.process')" min-width="110" />
- <el-table-column prop="breakageQuantity" align="center" :label="$t('large.numberfractions')" min-width="110" />
- <el-table-column prop="patchReason" align="center" :label="$t('large.breakreason')" min-width="110" />
- <el-table-column prop="patchType" align="center" :label="$t('large.breaktype')" min-width="110" />
- <el-table-column prop="responsiblePersonnel" align="center" :label="$t('large.responsiblepersonnel')" min-width="110" />
- <el-table-column prop="responsibleEquipment" align="center" :label="$t('large.responsiblequipment')" min-width="110" />
- <el-table-column prop="responsibleTeam" align="center" :label="$t('large.responsibleteam')" min-width="110" />
- <el-table-column prop="patchArea" align="center" :label="$t('large.area')" min-width="110" />
- <el-table-column prop="qualityInspector" align="center" :label="$t('large.inspector')" min-width="110" />
- </el-table>
- <template #footer>
- <div id="dialog-footer">
- <el-button @click="blinda = false">{{ $t('large.close') }}</el-button>
- </div>
- </template>
- </el-dialog>
+</el-scrollbar>
+</el-card>
+<el-dialog v-model="blinda" top="5vh" width="80%" :title="$t('large.brokeno')">
+ <el-table height="400" ref="table"
+ @selection-change="handleSelectionChange"
+ :data="tableData" :header-cell-style="{background:'#F2F3F5 ',color:'#1D2129'}">
+ <el-table-column prop="reportingWorkTime" fixed align="center" :label="$t('large.time')" min-width="110" />
+ <el-table-column prop="orderId" fixed align="center" :label="$t('large.number')" min-width="110" />
+ <el-table-column prop="reportingWorkId" align="center" :label="$t('large.jobnumber')" min-width="120" />
+ <el-table-column prop="productionId" align="center" :label="$t('large.productionnumber')" min-width="130" />
+ <el-table-column prop="processId" align="center" :label="$t('large.cardnumber')" min-width="140" />
+ <el-table-column prop="project" align="center" :label="$t('large.projectname')" min-width="110" />
+ <el-table-column prop="batch" align="center" :label="$t('large.batch')" min-width="110" />
+ <el-table-column prop="reviewer" align="center" :label="$t('large.detailID')" min-width="110" />
+ <el-table-column prop="orderSort" align="center" :label="$t('large.serialnumber')" min-width="110" />
+ <el-table-column prop="productName" align="center" :label="$t('large.productname')" :show-overflow-tooltip="true" min-width="220" />
+ <el-table-column prop="technologyNumber" align="center" :label="$t('large.serial')" min-width="110" />
+ <el-table-column prop="glassAddress" align="center" :label="$t('large.slicemarker')" min-width="130" />
+ <el-table-column prop="patchNum" align="center" :label="$t('large.numberpatches')" min-width="110" />
+ <el-table-column prop="width" align="center" :label="$t('large.width')" min-width="110" />
+ <el-table-column prop="height" align="center" :label="$t('large.height')" min-width="110" />
+ <el-table-column prop="shape" align="center" :label="$t('large.shape')" min-width="110" />
+ <el-table-column prop="responsibleProcess" align="center" :label="$t('large.responsibleprocess')" min-width="110" />
+ <el-table-column prop="patchProcesses" align="center" :label="$t('large.process')" min-width="110" />
+ <el-table-column prop="breakageQuantity" align="center" :label="$t('large.numberfractions')" min-width="110" />
+ <el-table-column prop="patchReason" align="center" :label="$t('large.breakreason')" min-width="110" />
+ <el-table-column prop="patchType" align="center" :label="$t('large.breaktype')" min-width="110" />
+ <el-table-column prop="responsiblePersonnel" align="center" :label="$t('large.responsiblepersonnel')" min-width="110" />
+ <el-table-column prop="responsibleEquipment" align="center" :label="$t('large.responsiblequipment')" min-width="110" />
+ <el-table-column prop="responsibleTeam" align="center" :label="$t('large.responsibleteam')" min-width="110" />
+ <el-table-column prop="patchArea" align="center" :label="$t('large.area')" min-width="110" />
+ <el-table-column prop="qualityInspector" align="center" :label="$t('large.inspector')" min-width="110" />
+ </el-table>
+ <template #footer>
+ <div id="dialog-footer" style="text-align: center;">
+ <el-button @click="blinda = false">{{ $t('large.close') }}</el-button>
+ </div>
+ </template>
+</el-dialog>
</template>
<script setup>
import { Delete, Upload } from '@element-plus/icons-vue'
@@ -118,194 +127,326 @@
const tableDatac = ref([])
const adjustedRects = ref([]);
const chartRefs = ref([]);
+const flake = ref(false)
+const flakeb = ref(false)
+const flakec = ref(false)
+const flaked = ref(false)
+const woshia = ref(false)
+const woshic = ref(false)
+const dalipiana = ref(false)
+const dalipianb = ref(false)
+const shangpian = ref(false)
+
const thisProcess = ref(); // 鐢ㄤ簬瀛樺偍process_id鐨勫搷搴斿紡寮曠敤
// 瀹氫箟涓�涓搷搴斿紡寮曠敤鏉ュ瓨鍌ㄥ浘琛ㄥ疄渚�
const chartDom = ref(null);
let chartInstance = null;
const blinda = ref(false)
const handleBinda = (row) => {
- blinda.value = true;
+blinda.value = true;
};
+const processesData = ref([]);
function getStatusType(warehousing) {
- switch (warehousing) {
- case 0:
- return 'info';
- case 1:
- return 'warning';
- case 2:
- return 'success';
- }
+switch (warehousing) {
+ case 0:
+ return 'info';
+ case 1:
+ return 'warning';
+ case 2:
+ return 'success';
+}
}
function getStatusText(warehousing) {
- switch (warehousing) {
- case 0:
- return t('large.notstocked');
- case 1:
- return t('large.inboundstatus');
- case 2:
- return t('large.allstatus');
- }
+switch (warehousing) {
+ case 0:
+ return t('large.notstocked');
+ case 1:
+ return t('large.inboundstatus');
+ case 2:
+ return t('large.allstatus');
}
+}
+let socket = null;
+let socket2 = null;
+let socket3 = null;
+let socket4 = null;
+let socket5 = null;
const socketUrl = `ws://${WebSocketHost}:${host}/api/temperingGlass/api/talk/screen`;
const handleMessage = (data) => {
- tableData.value = data.awaitingRepairs[0]
- tableDatab.value = data.DoingTask[0]
- tableDatac.value = data.orders[0]
- // adjustedRects.value = data.device[0].map(rect => ({
- // ...rect,
- // completed: rect.completedQuantity,
- // breakage: rect.breakageQuantity,
- // thisProcess: rect.thisProcess,
- // }));
-};
-let socket;
-// 璁剧疆鍥捐〃 DOM 寮曠敤
-function setChartDom(index, el) {
- if (!chartRefs.value[index]) {
- chartRefs.value[index] = { dom: el, chart: null };
- } else {
- chartRefs.value[index].dom = el;
- }
-}
-onMounted(() => {
- socket = new WebSocket(socketUrl);
+tableData.value = data.awaitingRepairs[0]
+tableDatab.value = data.DoingTask[0]
+tableDatac.value = data.orders[0]
socket.onmessage = (event) => {
- const data = JSON.parse(event.data);
- adjustedRects.value = data.device[0].map(rect => ({
- ...rect,
- completedQuantity: rect.completedQuantity,
- breakageQuantity: rect.breakageQuantity,
- thisProcess: rect.thisProcess,
- }));
- console.log(adjustedRects.value);
- // updateCharts();
+ const data = JSON.parse(event.data);
+ processesData.value = data.device[0].map(rect => ({
+ ...rect,
+ completedQuantity: rect.completedQuantity,
+ breakageQuantity: rect.breakageQuantity,
+ thisProcess: rect.thisProcess,
+ }));
+ renderPieCharts();
+}
+};
+function setChartDom(index, el) {
+if (!chartRefs.value[index]) {
+ chartRefs.value[index] = { dom: el, chart: null };
+} else {
+ chartRefs.value[index].dom = el;
+}
+}
+const socketUrl2 = `ws://${WebSocketHost}:${host}/api/temperingGlass/api/talk/temperingIsRun`;
+const handleMessage2 = (data) => {
+ const tasks = data.temperingTaskType[0];
+ if (tasks && tasks.length >= 4) {
+ flake.value = tasks[0].state === 1;
+ flakeb.value = tasks[1].state === 2;
+ flakec.value = tasks[2].state === 3;
+ flaked.value = tasks[3].state === 4;
+ }
+};
+// 鍗у紡鐞嗙墖
+const socketUrl3 = `ws://${WebSocketHost}:${host}/api/cacheGlass/api/talk/cacheGlassIsRun`;
+const handleMessage3 = (data) => {
+ const tasks = data.taskCaches[0];
+ woshia.value = tasks.some(task => task.endCell == 2001 && task.glassId == 0);
+ woshic.value = tasks.some(task => task.endCell == 2002 && task.glassId == 0);
+};
+// 澶х悊鐗囩
+const socketUrl4 = `ws://${WebSocketHost}:${host}/api/cacheVerticalGlass/api/talk/isRun`;
+const handleMessage4 = (data) => {
+ const tasks = data.bigStorageCageDetailsOutTask[0];
+ const taskss = data.bigStorageCageDetailsFeedTask[0];
+ dalipiana.value = tasks.some(task => task.slot !== null && task.slot !== undefined);
+dalipianb.value = taskss.some(task => task.slot !== null && task.slot !== undefined);
+};
+// 涓婄墖
+const socketUrl5 = `ws://${WebSocketHost}:${host}/api/loadGlass/api/talk/loadGlassIsRun`;
+const handleMessage5 = (data) => {
+ if(data.engineering.length !==0 ){
+ shangpian.value = true;
+}
+};
+const renderPieCharts = () => {
+processesData.value.forEach((data, index) => {
+ const chart = echarts.init(document.getElementById('pieChart_' + index));
+ const options = {
+ title: {
+ text: `${data.thisProcess} `,
+ left: 'center',
+ },
+ tooltip: {
+ trigger: 'item',
+ },
+ series: [
+ {
+ name: `${data.thisProcess} `,
+ type: 'pie',
+ radius: ['40%', '70%'],
+ avoidLabelOverlap: false,
+ data: [
+ { value: data.completedQuantity, name: t('large.completedquantity') },
+ { value: data.breakageQuantity, name: t('large.scrapquantity') }
+ ],
+ emphasis: {
+ itemStyle: {
+ shadowBlur: 10,
+ shadowOffsetX: 0,
+ shadowColor: 'rgba(0, 0, 0, 0.5)'
+ }
+ },
+ label: {
+ show: false,
+ position: 'center',
+ },
+ labelLine: {
+ show: false
+ },
+ }
+ ]
};
- adjustedRects.value.forEach((rect, index) => {
- initChart(index, rect);
- });
- // };
-});
-
-
-function initChart(index, rect) {
- const { dom } = chartRefs.value[index] || { dom: null };
- if (dom) {
- const chart = echarts.init(dom);
- const option = {
- tooltip: {
- trigger: 'item'
- },
- legend: {
- orient: 'vertical',
- left: 'left',
- },
- series: [
- {
- name: '楗肩姸鍥�',
- type: 'pie',
- radius: ['50%','70%'],
- data: [
- {value: rect.completedQuantity, name: '鍔犲伐鏁伴噺'},
- {value: rect.breakageQuantity, name: '娆$牬鏁伴噺'},
- console.log(rect.breakageQuantity)
- ],
- emphasis: {
- itemStyle: {
- shadowBlur: 10,
- shadowOffsetX: 0,
- shadowColor: 'rgba(0, 0, 0, 0.5)'
- }
- }
- }
- ]
- };
- chart.setOption(option);
- chartRefs.value[index] = { ...chartRefs.value[index], chart };
-}
-console.log(chartRefs.value[index]);
-}
-
-// 鏇存柊鍥捐〃
-// function updateCharts() {
-// adjustedRects.value.forEach((rect, index) => {
-// const { chart } = chartRefs.value[index] || { chart: null };
-// if (chart) {
-// chart.setOption({
-// series: [{
-// data: [
-// { value: rect.completedQuantity, name: '鍔犲伐鏁伴噺' },
-// { value: rect.breakageQuantity, name: '娆$牬鏁伴噺' },
-// ],
-// }],
-// });
-// }
-// });
-// }
-// 鍒濆鍖栧浘琛�
-// function initChart(index, rect) {
-// const chartDom = ref(`chartDom${index}`).value;
-// console.log(ref(`chartDom${index}`).value);
-// const chart = echarts.init(chartDom);
-// const option = {
-// tooltip: {
-// trigger: 'item'
-// },
-// legend: {
-// orient: 'vertical',
-// left: 'left',
-// },
-// series: [
-// {
-// name: '楗肩姸鍥�',
-// type: 'pie',
-// radius: ['50%','70%'],
-// data: [
-// {value: rect.completed, name: '鍔犲伐鏁伴噺'},
-// {value: rect.breakage, name: '娆$牬鏁伴噺'},
-// ],
-// emphasis: {
-// itemStyle: {
-// shadowBlur: 10,
-// shadowOffsetX: 0,
-// shadowColor: 'rgba(0, 0, 0, 0.5)'
-// }
-// }
-// }
-// ]
-// };
-// chart.setOption(option);
-// }
-// 娓呯悊 WebSocket 杩炴帴
-onUnmounted(() => {
- socket.close();
-});
-
-onMounted(() => {
- // fetchFlowCardId();
- // fetchTableData(); // 鑾峰彇鏁版嵁
- initializeWebSocket(socketUrl, handleMessage);
+ chart.setOption(options);
});
+};
+
+
+// onUnmounted(() => {
+// socket.close();
+// socket2.close();
+// });
+// onMounted(() => {
+// socket = initializeWebSocket(socketUrl, handleMessage);
+// // socket = new WebSocket(socketUrl);
+// socket.onmessage = (event) => {
+// const data = JSON.parse(event.data);
+// processesData.value = data.device[0].map(rect => ({
+// ...rect,
+// completedQuantity: rect.completedQuantity,
+// breakageQuantity: rect.breakageQuantity,
+// thisProcess: rect.thisProcess,
+// }));
+// renderPieCharts();
+// console.log(processesData.value);
+// // updateCharts();
+// socket2 = initializeWebSocket(socketUrl2, handleMessage2);
+// // socket2 = new WebSocket(socketUrl2);
+// // socket2.onmessage = (event) => {
+// // const data = JSON.parse(event.data);
+// // handleMessage2(data);
+// // };
+// };
+// });
+onMounted(() => {
+ socket = initializeWebSocket(socketUrl, handleMessage);
+ socket2 = initializeWebSocket(socketUrl2, handleMessage2);
+ socket3 = initializeWebSocket(socketUrl3, handleMessage3);
+ socket4 = initializeWebSocket(socketUrl4, handleMessage4);
+ socket5 = initializeWebSocket(socketUrl5, handleMessage5);
+});
+ onUnmounted(() => {
+ if (socket) {
+ closeWebSocket(socket);
+ }
+ if (socket2) {
+ closeWebSocket2(socket2);
+ }
+ if (socket3) {
+ closeWebSocket3(socket3);
+ }
+ if (socket4) {
+ closeWebSocket4(socket4);
+ }
+ if (socket5) {
+ closeWebSocket5(socket5);
+ }
+ });
onBeforeUnmount(() => {
- console.log("鍏抽棴浜�")
- closeWebSocket();
+console.log("鍏抽棴浜�")
+closeWebSocket();
+closeWebSocket2();
+closeWebSocket3();
+closeWebSocket4();
+closeWebSocket5();
});
</script>
-
+
<style scoped>
-.rect {
- border: 1px solid black; /* 璁剧疆鐭╁舰鐨勮竟妗� */
- /* background-color: lightblue; 璁剧疆鐭╁舰鐨勮儗鏅壊 */
-}
-.centered-text {
- /* 璁剧疆鏂囧瓧灞呬腑鏍峰紡 */
- display: flex;
- justify-content: center;
- align-items: center;
- height: 100%; /* 纭繚div鍗犳嵁鏁翠釜鐭╁舰鐨勯珮搴� */
-}
-#dialog-footer{
- text-align: center;
- margin-top: -15px;
+.echarts-container {
+display: flex;
+flex-wrap: wrap;
+gap: 20px;
+}
+.echarts-item {
+width: 150px;
+height: 150px;
+margin: 20px;
+}
+.pie-chart {
+width: 100%;
+height: 100%;
+}
+#parent{
+ position: relative;
+ width: 1500px;
+ margin-left: -300px
+}
+#overlay{
+ position: absolute;
+ z-index: 1;
+ width: 29px;
+ height: 10px;
+ background-color: #529b2e;
+ margin-top: -34px;
+ margin-left: -8px;
+}
+#overlayb{
+ position: absolute;
+ z-index: 1;
+ width: 15px;
+ height: 115px;
+ background-color: #529b2e;
+ margin-top: -197px;
+ margin-left: -3px;
+}
+#overlayc{
+ position: absolute;
+ z-index: 1;
+ width: 14px;
+ height: 16px;
+ background-color: #529b2e;
+ margin-top: -243px;
+ margin-left: -2px;
+}
+#overlayd{
+ position: absolute;
+ z-index: 1;
+ width: 28px;
+ height: 11px;
+ background-color: #529b2e;
+ margin-top: -239px;
+ margin-left: 40px;
+}
+#lipiana{
+ position: absolute;
+ z-index: 1;
+ width: 65px;
+ height: 10px;
+ background-color: #529b2e;
+ margin-top: -57px;
+ margin-left: 240px;
+}
+#lipianb{
+ position: absolute;
+ z-index: 1;
+ width: 16px;
+ height: 10px;
+ background-color: #529b2e;
+ margin-top: -72px;
+ margin-left: 323px;
+}
+#lipianc{
+ position: absolute;
+ z-index: 1;
+ width: 65px;
+ height: 10px;
+ background-color: #529b2e;
+ margin-top: -32px;
+ margin-left: 270px;
+}
+#lipiand{
+ position: absolute;
+ z-index: 1;
+ width: 21px;
+ height: 10px;
+ background-color: #529b2e;
+ margin-top: -48px;
+ margin-left: 354px;
+}
+#longa{
+ position: absolute;
+ z-index: 1;
+ width: 29px;
+ height: 5px;
+ background-color: #529b2e;
+ margin-top: -20px;
+ margin-left: 80px;
+}
+#longb{
+ position: absolute;
+ z-index: 1;
+ width: 29px;
+ height: 5px;
+ background-color: #529b2e;
+ margin-top: -20px;
+ margin-left: 150px;
+}
+#shangpianji{
+ position: absolute;
+ z-index: 1;
+ width: 29px;
+ height: 10px;
+ background-color: #529b2e;
+ margin-top: -90px;
+ margin-left: 568px;
}
</style>
\ No newline at end of file
--
Gitblit v1.8.0