2023-05-31 08:16:19 +00:00
|
|
|
<template>
|
|
|
|
<div :class="$style['container']">
|
2023-06-17 09:33:08 +00:00
|
|
|
<header2 ref="headerref" :width="'100%'" :height="'100px'" :title="t('messages.南门水房物联监测系统')" :titleTip="[]"
|
|
|
|
:typeFun="['time']" :alarmType="['']"></header2>
|
2023-05-31 08:16:19 +00:00
|
|
|
<div class="main">
|
2023-06-16 09:42:25 +00:00
|
|
|
<div class="left-title">{{ t('messages.数据监测') }}</div>
|
2023-06-15 10:03:49 +00:00
|
|
|
<div class="lt-data item">
|
2023-06-16 09:42:25 +00:00
|
|
|
<div class="left">{{ t('messages.进水') }}</div>
|
2023-06-17 09:33:08 +00:00
|
|
|
<div class="center">{{ allData.in }}</div>
|
2023-06-15 10:03:49 +00:00
|
|
|
</div>
|
|
|
|
<div class="rt-data item">
|
2023-06-16 09:42:25 +00:00
|
|
|
<div class="left">{{ t('messages.出水') }}</div>
|
2023-06-17 09:33:08 +00:00
|
|
|
<div class="center">{{ allData.out }}</div>
|
2023-06-19 00:15:49 +00:00
|
|
|
</div>
|
2023-06-15 10:03:49 +00:00
|
|
|
<div class="lb-data item">
|
2023-06-16 09:42:25 +00:00
|
|
|
<div class="left">{{ t('messages.消耗') }}</div>
|
2023-06-17 09:33:08 +00:00
|
|
|
<div class="center">{{ allData.use }}</div>
|
2023-06-15 10:03:49 +00:00
|
|
|
</div>
|
|
|
|
<div class="rb-data item">
|
2023-06-16 09:42:25 +00:00
|
|
|
<div class="left">{{ t('messages.用电') }}</div>
|
2023-06-17 09:33:08 +00:00
|
|
|
<div class="center">{{ allData.currentCount }}</div>
|
2023-06-15 10:03:49 +00:00
|
|
|
</div>
|
|
|
|
<!-- 总体趋势图 -->
|
2023-06-16 09:42:25 +00:00
|
|
|
<div class="rt-title">{{ t('messages.总体趋势图') }}</div>
|
2023-06-15 10:03:49 +00:00
|
|
|
<div class="rt-radio">
|
2023-06-17 09:33:08 +00:00
|
|
|
<el-radio-group v-model="date" size="small" @change="dateChange">
|
2023-06-16 09:42:25 +00:00
|
|
|
<el-radio-button label="1">{{ t('messages.近一周') }}</el-radio-button>
|
|
|
|
<el-radio-button label="2">{{ t('messages.近一月') }}</el-radio-button>
|
|
|
|
<el-radio-button label="3">{{ t('messages.近三月') }}</el-radio-button>
|
2023-06-15 10:03:49 +00:00
|
|
|
</el-radio-group>
|
|
|
|
</div>
|
|
|
|
<div class="mainChart" ref="mainChart"></div>
|
2023-06-16 02:57:20 +00:00
|
|
|
<div class="math-content">
|
|
|
|
<el-row>
|
|
|
|
<el-col :span="12" class="p-left10"></el-col>
|
2023-06-16 09:42:25 +00:00
|
|
|
<el-col :span="4" class="math-title-color">{{ t('messages.最大值') }}</el-col>
|
|
|
|
<el-col :span="4" class="math-title-color">{{ t('messages.最小值') }}</el-col>
|
|
|
|
<el-col :span="4" class="math-title-color">{{ t('messages.平均值') }}</el-col>
|
2023-06-16 02:57:20 +00:00
|
|
|
</el-row>
|
|
|
|
<el-row v-for="item in mathList">
|
|
|
|
<el-col :span="12" class="p-left10" style="display: flex;justify-content: start;align-items: center;">
|
2023-06-19 00:15:49 +00:00
|
|
|
<div
|
|
|
|
:style="{ 'background': item.color, 'width': '25px', 'height': '20px', 'margin-right': '5px' }">
|
|
|
|
</div>
|
2023-06-16 02:57:20 +00:00
|
|
|
<text>{{ item.name }}</text>
|
|
|
|
</el-col>
|
|
|
|
<el-col :span="4">{{ item.max }}</el-col>
|
|
|
|
<el-col :span="4">{{ item.min }}</el-col>
|
|
|
|
<el-col :span="4">{{ item.avg }}</el-col>
|
|
|
|
</el-row>
|
|
|
|
</div>
|
2023-06-15 10:03:49 +00:00
|
|
|
<!-- 效益&效率 -->
|
2023-06-16 09:42:25 +00:00
|
|
|
<div class="rb-title">{{ t('messages.效益&效率') }}</div>
|
2023-06-15 10:03:49 +00:00
|
|
|
<div class="rb-content">
|
|
|
|
<div class="progress">
|
2023-06-17 09:33:08 +00:00
|
|
|
<el-progress type="circle" :width="150" :percentage="allData.xy" />
|
2023-06-16 09:42:25 +00:00
|
|
|
<div class="progress-text">{{ t('messages.效益') }}</div>
|
2023-06-15 10:03:49 +00:00
|
|
|
</div>
|
|
|
|
<div class="progress">
|
2023-06-17 09:33:08 +00:00
|
|
|
<el-progress type="circle" :width="150" :percentage="allData.xl" />
|
2023-06-19 00:15:49 +00:00
|
|
|
<div class="progress-text">{{ t('messages.效率') }}</div>
|
2023-06-15 10:03:49 +00:00
|
|
|
</div>
|
|
|
|
</div>
|
2023-05-31 08:16:19 +00:00
|
|
|
</div>
|
|
|
|
</div>
|
|
|
|
</template>
|
|
|
|
|
|
|
|
<script setup lang='ts'>
|
|
|
|
import { onMounted, onUnmounted, reactive, ref, getCurrentInstance } from "vue";
|
|
|
|
import header2 from "@/components/headerBox/header2.vue";
|
2023-06-17 09:33:08 +00:00
|
|
|
import { getWaterFlowInfo } from '@/http/waterHouse'
|
2023-06-16 09:42:25 +00:00
|
|
|
import { useI18n } from 'vue-i18n'
|
|
|
|
let { t } = useI18n();
|
2023-05-31 08:16:19 +00:00
|
|
|
let imgUrl = require('@/assets/img/water_room.png')
|
|
|
|
const { proxy } = getCurrentInstance() as any
|
|
|
|
const mainChart = ref(null)
|
|
|
|
let chart = null
|
2023-06-15 10:03:49 +00:00
|
|
|
let date = ref('1')
|
2023-06-17 09:33:08 +00:00
|
|
|
let allData = reactive({
|
|
|
|
in: 0,
|
|
|
|
out: 0,
|
|
|
|
use: 0,
|
|
|
|
currentCount: 0,
|
|
|
|
xl: 0,
|
|
|
|
xy: 0
|
|
|
|
})
|
2023-06-16 09:42:25 +00:00
|
|
|
document.title = t('messages.南门水房物联监测系统')
|
2023-05-31 08:16:19 +00:00
|
|
|
const colors = ['#5470C6', '#91CC75', '#EE6666'];
|
2023-06-16 02:57:20 +00:00
|
|
|
//进水量 出水量 用电量 最大值 最小值 平均值
|
|
|
|
let mathList = reactive([
|
|
|
|
{ color: '#5470C6', name: '进水量', max: 100, min: 0, avg: 50 },
|
|
|
|
{ color: '#91CC75', name: '出水量', max: 100, min: 0, avg: 50 },
|
|
|
|
{ color: '#EE6666', name: '用电量', max: 100, min: 0, avg: 50 }
|
|
|
|
])
|
2023-06-16 09:42:25 +00:00
|
|
|
|
2023-06-19 09:45:24 +00:00
|
|
|
function initChart(date,inChart, outChart, currentChart) {
|
|
|
|
if (!chart) {
|
|
|
|
chart = proxy.$echarts.init(mainChart.value, 'dark');
|
|
|
|
}
|
|
|
|
|
2023-05-31 08:16:19 +00:00
|
|
|
let option = {
|
2023-06-15 10:03:49 +00:00
|
|
|
// title: {
|
|
|
|
// text: '水房数据大屏',
|
|
|
|
// },
|
2023-05-31 08:16:19 +00:00
|
|
|
color: colors,
|
|
|
|
tooltip: {
|
|
|
|
trigger: 'axis'
|
|
|
|
},
|
|
|
|
legend: {
|
|
|
|
data: ['进水量', '出水量', '用电量']
|
|
|
|
},
|
|
|
|
grid: {
|
|
|
|
left: '3%',
|
|
|
|
right: '4%',
|
|
|
|
bottom: '3%',
|
|
|
|
containLabel: true
|
|
|
|
},
|
|
|
|
xAxis: {
|
|
|
|
type: 'category',
|
|
|
|
boundaryGap: false,
|
2023-06-19 09:45:24 +00:00
|
|
|
data: date
|
2023-05-31 08:16:19 +00:00
|
|
|
},
|
|
|
|
yAxis: [
|
|
|
|
{
|
|
|
|
type: 'value',
|
|
|
|
name: '水量',
|
|
|
|
},
|
|
|
|
{
|
|
|
|
type: 'value',
|
|
|
|
name: '电量',
|
|
|
|
position: 'right',
|
|
|
|
axisLine: {
|
|
|
|
show: true,
|
|
|
|
lineStyle: {
|
|
|
|
color: colors[2]
|
|
|
|
}
|
|
|
|
},
|
|
|
|
}
|
|
|
|
],
|
|
|
|
series: [
|
|
|
|
{
|
|
|
|
name: '进水量',
|
|
|
|
type: 'line',
|
2023-06-19 00:15:49 +00:00
|
|
|
smooth: true,
|
2023-06-19 09:45:24 +00:00
|
|
|
data: inChart
|
2023-05-31 08:16:19 +00:00
|
|
|
},
|
|
|
|
{
|
|
|
|
name: '出水量',
|
|
|
|
type: 'line',
|
2023-06-19 00:15:49 +00:00
|
|
|
smooth: true,
|
2023-05-31 08:16:19 +00:00
|
|
|
yAxisIndex: 0,
|
2023-06-19 09:45:24 +00:00
|
|
|
data: outChart
|
2023-05-31 08:16:19 +00:00
|
|
|
},
|
|
|
|
{
|
|
|
|
name: '用电量',
|
|
|
|
type: 'line',
|
2023-06-19 00:15:49 +00:00
|
|
|
smooth: true,
|
2023-05-31 08:16:19 +00:00
|
|
|
yAxisIndex: 1,
|
2023-06-19 09:45:24 +00:00
|
|
|
data: currentChart
|
2023-05-31 08:16:19 +00:00
|
|
|
}
|
|
|
|
]
|
|
|
|
};
|
|
|
|
chart.setOption(option);
|
2023-06-17 09:33:08 +00:00
|
|
|
}
|
|
|
|
function dateChange() {
|
|
|
|
getWaterFlowInfoFun()
|
|
|
|
}
|
|
|
|
async function getWaterFlowInfoFun() {
|
|
|
|
let { code, data }: any = await getWaterFlowInfo(date.value)
|
|
|
|
if (code == 200) {
|
|
|
|
allData.in = data.in
|
|
|
|
allData.out = data.out
|
|
|
|
allData.use = data.use
|
|
|
|
allData.currentCount = data.currentCount
|
2023-06-17 09:38:18 +00:00
|
|
|
allData.xl = data.xl.toFixed(1)
|
|
|
|
allData.xy = data.xy.toFixed(1)
|
2023-06-19 09:45:24 +00:00
|
|
|
initChart(data.date, data.inChart, data.outChart, data.currentChart)
|
|
|
|
|
2023-06-17 09:33:08 +00:00
|
|
|
mathList[0].max = data.math.WaterInflow.max
|
|
|
|
mathList[0].min = data.math.WaterInflow.min
|
|
|
|
mathList[0].avg = data.math.WaterInflow.avg
|
|
|
|
mathList[1].max = data.math.WaterOutflow.max
|
|
|
|
mathList[1].min = data.math.WaterOutflow.min
|
|
|
|
mathList[1].avg = data.math.WaterOutflow.avg
|
|
|
|
mathList[2].max = data.math.CurrentUsage.max
|
|
|
|
mathList[2].min = data.math.CurrentUsage.min
|
|
|
|
mathList[2].avg = data.math.CurrentUsage.avg
|
|
|
|
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
2023-05-31 08:16:19 +00:00
|
|
|
}
|
|
|
|
onMounted(() => {
|
2023-06-17 09:33:08 +00:00
|
|
|
getWaterFlowInfoFun()
|
2023-05-31 08:16:19 +00:00
|
|
|
})
|
|
|
|
</script>
|
|
|
|
<style module>
|
|
|
|
.container {
|
|
|
|
height: 1080px;
|
|
|
|
width: 1920px;
|
|
|
|
color: #20aec5;
|
|
|
|
background-color: #100c2a;
|
|
|
|
box-sizing: border-box;
|
|
|
|
overflow: hidden;
|
|
|
|
}
|
|
|
|
</style>
|
|
|
|
<style scoped>
|
|
|
|
.main {
|
2023-06-15 10:03:49 +00:00
|
|
|
position: relative;
|
2023-05-31 08:16:19 +00:00
|
|
|
width: 100%;
|
|
|
|
height: 980px;
|
2023-06-15 01:31:07 +00:00
|
|
|
background: url('/src/assets/img/water_house_bg.jpg') no-repeat;
|
2023-05-31 08:16:19 +00:00
|
|
|
}
|
|
|
|
|
2023-06-15 10:03:49 +00:00
|
|
|
.left-title {
|
|
|
|
position: absolute;
|
|
|
|
top: 94px;
|
|
|
|
left: 129px;
|
|
|
|
font-size: 28px;
|
|
|
|
color: #fff;
|
|
|
|
/* font-weight: bold; */
|
|
|
|
}
|
|
|
|
|
|
|
|
.lt-data {
|
|
|
|
position: absolute;
|
|
|
|
top: 513px;
|
|
|
|
left: 176px;
|
|
|
|
}
|
|
|
|
|
|
|
|
.rt-data {
|
|
|
|
position: absolute;
|
|
|
|
top: 508px;
|
|
|
|
left: 581px;
|
|
|
|
}
|
|
|
|
|
|
|
|
.lb-data {
|
|
|
|
position: absolute;
|
|
|
|
top: 743px;
|
|
|
|
left: 176px;
|
|
|
|
}
|
|
|
|
|
|
|
|
.rb-data {
|
|
|
|
position: absolute;
|
|
|
|
top: 726px;
|
|
|
|
left: 581px;
|
|
|
|
}
|
|
|
|
|
|
|
|
.item {
|
|
|
|
width: 200px;
|
|
|
|
height: 86px;
|
|
|
|
font-size: 24px;
|
|
|
|
color: #fff;
|
|
|
|
}
|
|
|
|
|
|
|
|
.left {
|
|
|
|
padding-left: 10px;
|
|
|
|
text-align: left;
|
|
|
|
line-height: 50px;
|
|
|
|
}
|
|
|
|
|
|
|
|
.center {
|
|
|
|
line-height: 36px;
|
|
|
|
}
|
|
|
|
|
|
|
|
.rt-title {
|
|
|
|
position: absolute;
|
|
|
|
top: 47px;
|
|
|
|
right: 536px;
|
|
|
|
font-size: 28px;
|
|
|
|
color: #fff;
|
|
|
|
}
|
2023-06-16 02:57:20 +00:00
|
|
|
|
2023-06-15 10:03:49 +00:00
|
|
|
.rt-radio {
|
|
|
|
position: absolute;
|
|
|
|
top: 96px;
|
|
|
|
right: 78px;
|
|
|
|
background: #110C2C;
|
|
|
|
}
|
|
|
|
|
2023-05-31 08:16:19 +00:00
|
|
|
.mainChart {
|
2023-06-15 10:03:49 +00:00
|
|
|
position: absolute;
|
|
|
|
width: 650px;
|
|
|
|
height: 270px;
|
|
|
|
top: 136px;
|
|
|
|
left: 1227px;
|
|
|
|
}
|
2023-06-16 02:57:20 +00:00
|
|
|
|
2023-06-15 10:03:49 +00:00
|
|
|
.math-content {
|
|
|
|
position: absolute;
|
|
|
|
width: 555px;
|
|
|
|
height: 100px;
|
|
|
|
top: 418px;
|
|
|
|
left: 1271px;
|
2023-06-16 02:57:20 +00:00
|
|
|
display: flex;
|
|
|
|
flex-direction: column;
|
|
|
|
justify-content: space-around;
|
|
|
|
color: #fff;
|
2023-06-15 10:03:49 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
.rb-title {
|
|
|
|
position: absolute;
|
|
|
|
bottom: 399px;
|
|
|
|
right: 551px;
|
|
|
|
font-size: 28px;
|
|
|
|
color: #fff;
|
|
|
|
}
|
2023-06-16 02:57:20 +00:00
|
|
|
|
2023-06-15 10:03:49 +00:00
|
|
|
.rb-content {
|
|
|
|
position: absolute;
|
|
|
|
display: flex;
|
|
|
|
justify-content: space-around;
|
|
|
|
align-items: center;
|
|
|
|
bottom: 120px;
|
|
|
|
right: 64px;
|
|
|
|
width: 650px;
|
|
|
|
height: 270px;
|
|
|
|
font-size: 16px;
|
|
|
|
}
|
|
|
|
|
|
|
|
:deep(.progress .el-progress__text) {
|
2023-06-16 02:57:20 +00:00
|
|
|
font-weight: bold;
|
|
|
|
font-size: 30px !important;
|
2023-06-15 10:03:49 +00:00
|
|
|
}
|
2023-06-16 02:57:20 +00:00
|
|
|
|
2023-06-15 10:03:49 +00:00
|
|
|
.progress-text {
|
|
|
|
font-size: 18px;
|
|
|
|
font-weight: bold;
|
|
|
|
margin-top: 5px;
|
|
|
|
color: #fff;
|
2023-05-31 08:16:19 +00:00
|
|
|
}
|
2023-06-16 02:57:20 +00:00
|
|
|
|
|
|
|
.p-left10 {
|
|
|
|
text-align: left;
|
|
|
|
box-sizing: border-box;
|
|
|
|
padding-left: 10px;
|
|
|
|
}
|
2023-06-17 09:33:08 +00:00
|
|
|
|
2023-06-16 02:57:20 +00:00
|
|
|
.math-title-color {
|
|
|
|
color: #025AE5;
|
|
|
|
}
|
2023-05-31 08:16:19 +00:00
|
|
|
</style>
|