main
wangqiujuan0808 2023-12-14 23:37:34 +08:00
parent b7deb85f71
commit a77af4ca6d
22 changed files with 724 additions and 151 deletions

BIN
dist.7z

Binary file not shown.

View File

@ -126,9 +126,11 @@ aside {
// height: 80px; // height: 80px;
} }
.mr10 { .mr10 {
margin-right: 10px; margin-right: 10px;
} }
.components-container { .components-container {
margin: 30px 50px; margin: 30px 50px;
position: relative; position: relative;
@ -185,9 +187,67 @@ aside {
margin-bottom: 10px; margin-bottom: 10px;
} }
} }
.bim-dialog {
background: #00174b !important;
.el-dialog__title {
color: #fff !important;
}
.el-tree--highlight-current .el-tree-node.is-current>.el-tree-node__content { .el-tree--highlight-current .el-tree-node.is-current>.el-tree-node__content {
background-color: #033b73 !important; background-color: #082859 !important;
} }
.el-tree-node__content {
background-color: #00174b !important;
color: #fff !important;
}
.el-tree-node__content:hover { .el-tree-node__content:hover {
background-color: #033b73 !important; background-color: #082859 !important;
}
.el-input__wrapper {
background: transparent !important;
border: 1px solid #2E6099 !important;
box-shadow: none !important;
&:hover {
outline: none !important;
border: 1px solid #2E6099 !important;
}
}
.el-select__icon {
color: #2E6099 !important;
}
.el-tabs__item,
.el-range-input,
.el-input__inner {
color: #fff !important;
}
.el-tabs__header .el-tabs__item.is-active {
color: #3cbfdf !important;
}
.el-table__cell,
.el-tabs__header,
.el-tabs__header .el-tabs__item,
.el-tabs--card>.el-tabs__header .el-tabs__nav {
border-color:#2E6099 !important;
}
.el-table,
tr,
.el-table__border-left-patch,
.el-table--border::after,
.el-table__header-wrapper th,
.el-table--enable-row-hover .el-table__body tr>td.el-table__cell,
.el-table--enable-row-hover .el-table__body tr:hover>td.el-table__cell,
.el-table__inner-wrapper::after,
.el-table__inner-wrapper::before {
background-color: #00174b !important;
color: #fff !important
}
} }

View File

@ -41,6 +41,5 @@ function handleSetSize(size) {
font-size: 18px; font-size: 18px;
line-height: 50px; line-height: 50px;
padding-right: 7px; padding-right: 7px;
color: #fff;
} }
</style> </style>

View File

@ -1,6 +1,7 @@
<template> <template>
<div class="navbar"> <div class="navbar">
<hamburger id="hamburger-container" :is-active="appStore.sidebar.opened" class="hamburger-container" @toggleClick="toggleSideBar" /> <hamburger id="hamburger-container" :is-active="appStore.sidebar.opened" class="hamburger-container"
@toggleClick="toggleSideBar" />
<breadcrumb id="breadcrumb-container" class="breadcrumb-container" v-if="!settingsStore.topNav" /> <breadcrumb id="breadcrumb-container" class="breadcrumb-container" v-if="!settingsStore.topNav" />
<top-nav id="topmenu-container" class="topmenu-container" v-if="settingsStore.topNav" /> <top-nav id="topmenu-container" class="topmenu-container" v-if="settingsStore.topNav" />
@ -139,7 +140,8 @@ function setLayout() {
float: right; float: right;
height: 100%; height: 100%;
display: flex; display: flex;
color: #fff; color: #000;
&:focus { &:focus {
outline: none; outline: none;
} }
@ -149,10 +151,11 @@ function setLayout() {
padding: 0 8px; padding: 0 8px;
height: 100%; height: 100%;
font-size: 18px; font-size: 18px;
color: #fff; color: #000;
vertical-align: text-bottom; vertical-align: text-bottom;
display: flex; display: flex;
align-items: center; align-items: center;
&.hover-effect { &.hover-effect {
cursor: pointer; cursor: pointer;
transition: background 0.3s; transition: background 0.3s;
@ -186,6 +189,9 @@ function setLayout() {
} }
} }
} }
:deep(.size-icon--style) {
color: #000;
} }
} }
</style> }</style>

View File

@ -25,6 +25,33 @@ const tagsViewStore = useTagsViewStore()
width: 100%; width: 100%;
position: relative; position: relative;
overflow: hidden; overflow: hidden;
:deep(.el-tree--highlight-current .el-tree-node.is-current>.el-tree-node__content) {
background-color: #082859 !important;
}
:deep(.el-tree-node__content:hover) {
background-color: #082859 !important;
}
:deep(.el-input__wrapper) {
background: transparent;
border: 1px solid #2E6099;
box-shadow: none;
&:hover {
outline: none;
border: 1px solid #2E6099;
}
}
:deep(.el-select__icon) {
color: #2E6099
}
:deep(.el-input__inner) {
color: #fff;
}
} }
.fixed-header+.app-main { .fixed-header+.app-main {

View File

@ -1,5 +1,5 @@
<template> <template>
<div class="navbar"> <div class="navbar1">
<!-- <top-nav id="topmenu-container" class="topmenu-container" v-if="settingsStore.topNav" /> --> <!-- <top-nav id="topmenu-container" class="topmenu-container" v-if="settingsStore.topNav" /> -->
<div class="left"> <div class="left">
<!-- <img src="@/assets/logo/logo.png" alt="dark" /> --> <!-- <img src="@/assets/logo/logo.png" alt="dark" /> -->
@ -161,7 +161,7 @@ function setLayout() {
</script> </script>
<style lang='scss' scoped> <style lang='scss' scoped>
.navbar { .navbar1 {
height: 70px; height: 70px;
overflow: hidden; overflow: hidden;
position: relative; position: relative;
@ -302,5 +302,8 @@ function setLayout() {
} }
} }
} }
:deep(.size-icon--style) {
color: #fff;
}
} }
}</style> }</style>

View File

@ -30,9 +30,10 @@ const listData = props.infoList.detail;
<style lang="scss" scoped> <style lang="scss" scoped>
.baseInfo-div { .baseInfo-div {
width: 100%; width: 100%;
height: 80%; // height: 80%;
display: flex; display: flex;
justify-content: space-between; justify-content: space-between;
font-size: 18px;
.left-div { .left-div {
width: 69%; width: 69%;
height: 100%; height: 100%;
@ -40,6 +41,7 @@ const listData = props.infoList.detail;
justify-content: space-between; justify-content: space-between;
flex-wrap: wrap; flex-wrap: wrap;
>div { >div {
padding: 40px 0;
width: 48%; width: 48%;
line-height: 24px; line-height: 24px;
height: 48px; height: 48px;

View File

@ -212,13 +212,5 @@ const handleNodeClick = (value) => {
.el-select { .el-select {
margin: 10px; margin: 10px;
} }
:deep(.el-input__wrapper) {
background: transparent;
}
:deep(.el-input__inner) {
color: #fff;
}
} }
</style> </style>

View File

@ -5,21 +5,25 @@
<el-tab-pane :label="item" v-for="(item, index) of tabData" :key="index" :name="index + ''"> <el-tab-pane :label="item" v-for="(item, index) of tabData" :key="index" :name="index + ''">
</el-tab-pane> </el-tab-pane>
</el-tabs> </el-tabs>
<BasicInfo :infoList="detailData"></BasicInfo> <BasicInfo :infoList="detailData" v-if="activeName == '0'"></BasicInfo>
<RealInfo v-if="activeName == '1'"></RealInfo>
<HistoryInfo v-if="activeName == '2'"></HistoryInfo>
</div> </div>
</template> </template>
<script setup> <script setup>
import bimStore from '@/store/modules/bim'; import bimStore from '@/store/modules/bim';
import BasicInfo from './BasicInfo.vue'; import BasicInfo from './BasicInfo.vue';
import RealInfo from './RealInfo.vue';
import HistoryInfo from './HistoryInfo.vue';
import { ElMessage } from 'element-plus'; import { ElMessage } from 'element-plus';
const deviceData = { const deviceData = {
'EQ0001': { 'EQ0001': {
name: '过滤槽', name: '立仓',
imgUlr: '', imgUlr: '',
detail: [ detail: [
{ {
name: '资产名称', name: '资产名称',
value: '过滤槽' value: '立仓'
}, },
{ {
name: '资产类型', name: '资产类型',
@ -72,12 +76,12 @@ const deviceData = {
] ]
}, },
'EQ0002': { 'EQ0002': {
name: '新风机组', name: '过滤槽',
imgUlr: '', imgUlr: '',
detail: [ detail: [
{ {
name: '资产名称', name: '资产名称',
value: '新风机组' value: '过滤槽'
}, },
{ {
name: '资产类型', name: '资产类型',
@ -147,9 +151,9 @@ const { detailData } = toRefs(data);
const deviceNum = computed(() => bimStore().deviceNum); const deviceNum = computed(() => bimStore().deviceNum);
detailData.value = deviceData[deviceNum.value]; detailData.value = deviceData[deviceNum.value];
const handleClick = (tab, event) => { const handleClick = (tab, event) => {
if(activeName !== '0') { // if(activeName !== '0' && activeName !== '1' && activeName !=='2') {
ElMessage.warning('暂未开发'); // ElMessage.warning('');
} // }
} }
@ -158,12 +162,14 @@ const handleClick = (tab, event) => {
<style lang="scss" scoped> <style lang="scss" scoped>
.detail-div { .detail-div {
height: 700px; height: 700px;
color: #fff;
.title-div { .title-div {
height: 50px; height: 50px;
line-height: 50px; line-height: 50px;
width: 100%; width: 100%;
border: 1px solid #ddd; border: 1px solid #2E6099;
padding: 0 10px; padding: 0 10px;
margin-bottom:5px;
} }
} }
</style> </style>

View File

@ -64,8 +64,8 @@ const data = reactive({
id: "echartDiv0" id: "echartDiv0"
}, },
{ {
type: '空调设备', type: '生产设备',
name: '新风机组', name: '过滤槽',
num: 'EQ0002', num: 'EQ0002',
value: 130, value: 130,
id: "echartDiv1" id: "echartDiv1"
@ -106,8 +106,8 @@ const data = reactive({
id: "echartDiv0" id: "echartDiv0"
}, },
{ {
type: '空调设备', type: '生产设备',
name: '新风机组', name: '过滤槽',
num: 'EQ0002', num: 'EQ0002',
value: 50, value: 50,
id: "echartDiv1" id: "echartDiv1"
@ -149,8 +149,8 @@ const data = reactive({
id: "echartDiv0" id: "echartDiv0"
}, },
{ {
type: '空调设备', type: '生产设备',
name: '新风机组', name: '过滤槽',
num: 'EQ0002', num: 'EQ0002',
value: 80, value: 80,
id: "echartDiv1" id: "echartDiv1"
@ -427,7 +427,7 @@ const viewDetail = (val) => {
.left-div { .left-div {
width: 20%; width: 20%;
height: 100%; height: 100%;
border: 1px solid #3cbfdf; border: 1px solid #2E6099;
.el-tree { .el-tree {
margin: 0 10px; margin: 0 10px;
@ -454,13 +454,13 @@ const viewDetail = (val) => {
.echartDiv100 { .echartDiv100 {
width: 22% !important; width: 22% !important;
height: 100% !important; height: 100% !important;
border: 1px solid #3cbfdf; border: 1px solid #2E6099;
} }
} }
.bottom-div { .bottom-div {
height: 74%; height: 74%;
border: 1px solid #3cbfdf; border: 1px solid #2E6099;
} }
} }
} }

View File

@ -40,11 +40,23 @@ const data = reactive({
}, },
children: [ children: [
{ {
label: '设备一', label: '立仓',
id: '0-1', id: '0-1',
clickName: 'set1', clickName: 'set1',
info: { info: {
name: '设备一', name: '立仓',
type: '生产设备',
status: '启用'
},
children: []
},
{
label: '过滤槽',
id: '0-1',
clickName: 'set6',
info: {
name: '过滤槽',
type: '生产设备', type: '生产设备',
status: '启用' status: '启用'
}, },

View File

@ -0,0 +1,160 @@
<template>
<div class="historyInfo-div">
<div id="line"></div>
</div>
</template>
<script setup>
import * as echarts from "echarts";
onMounted(() => {
nextTick(() => {
getCharts();
})
})
var colors = ['#1890FF', '#24CDFB'];
const getCharts = () => {
var dom = document.getElementById("line");
if (dom) {
//
dom.removeAttribute('_echarts_instance_')
var myChart = echarts.init(dom);
let option = {
title: {
text: ''
},
tooltip: {
trigger: 'axis',
axisPointer: {
type: 'shadow'
}
},
legend: {
textStyle: {
color: "#ffff",
fontFamily: "Alibaba PuHuiTi",
fontSize: 14,
fontWeight: 400,
},
},
grid: {
top: '24%',
left: '5%',
right: '8%',
// bottom: '2%',
height: '80%',
containLabel: true
},
yAxis: [
{
type: 'value',
axisLine: {
show: true,
lineStyle: {
width: 1
}
},
splitLine: {
// 线
lineStyle: {
type: "dotted", //线 dotted线 solid:线
color: "#29507E",
},
show: true,
},
axisLabel: {
textStyle: {
color: "#fff", //X
fontSize: "12", //X
},
},
show: true,
maxInterval: 50000 // min
}
],
xAxis: [
{
type: 'category',
data: ['1月', '2月', '3月', '4月', '5月', '6月', '7月', '8月', '9月', '10月', '11月', '12月'],
axisLine: {
show: true,
lineStyle: {
width: 0
}
},
show: false,
position: 'bottom',
},
{
type: 'category',
data: ['1月', '2月', '3月', '4月', '5月', '6月', '7月', '8月', '9月', '10月', '11月', '12月'],
axisLine: {
show: true,
lineStyle: {
width: 2
}
},
axisLabel: {
textStyle: {
color: "#fff", //X
fontSize: "12", //X
},
},
position: 'bottom',
}
],
series: [
{
name: '温度',
type: 'line',
color: colors[0],
barWidth: 18,
// xAxisIndex:1,
data: [82, 34, 90, 104, 31, 100, 82, 34, 90, 104, 31, 100],
itemStyle: {
normal: {
label: {
show: true,
textStyle: {
color: colors[0],
},
position: "top",
},
}
}
},
{
name: '压力',
type: 'line',
color: colors[1],
// xAxisIndex:1,
data: [193, 234, 310, 121, 134, 181, 193, 234, 310, 121, 134, 181],
itemStyle: {
normal: {
label: {
show: true,
textStyle: {
color: colors[1],
},
position: "top",
},
}
}
}
]
};
option && myChart.setOption(option);
}
}
</script>
<style lang="scss" scoped>
.historyInfo-div {
width: 100%;
height: 80%;
#line {
width: 100%;
height: 100%;
}
}
</style>

View File

@ -0,0 +1,74 @@
<template>
<div class="realInfo-div">
<div v-for="(item, index) of realInfo" :key="index">
<span class="name">{{ item.name }}</span>
<span class="value">{{ item.value }}</span>
</div>
</div>
</template>
<script setup>
const data = reactive({
realInfo: [
{
name: '运行状态',
value: '运行中',
},
{
name: '故障状态',
value: '正常',
},
{
name: '房间温度',
value: '22.6℃',
},
{
name: '供水温度',
value: '16℃',
},
{
name: '回水温度',
value: '22℃',
},
{
name: '回水压力',
value: '4bar',
},
{
name: '送风区域',
value: '1楼大厅',
}
]
});
const { realInfo } = toRefs(data);
</script>
<style lang="scss" scoped>
.realInfo-div {
width: 100%;
// height: 80%;
display: flex;
justify-content: space-between;
font-size: 18px;
flex-wrap: wrap;
>div {
padding: 40px 0;
width: 33%;
line-height: 24px;
height: 48px;
justify-content: space-between;
display: flex;
align-items: center;
.name {
width: 40%;
text-align: right;
}
.value {
width: 59%;
}
}
}</style>

View File

@ -172,7 +172,7 @@ const getEchart = () => {
} }
}, },
] ]
const option = { series, backgroundColor: '#ffffff' } const option = { series, backgroundColor: '#00174b' }
option && myChart.setOption(option); option && myChart.setOption(option);
} }
} }
@ -184,11 +184,12 @@ const getEchart = () => {
display: flex; display: flex;
justify-content: space-between; justify-content: space-between;
flex-direction: column; flex-direction: column;
color:#fff;
.top-div { .top-div {
width: 100%; width: 100%;
height: 25%; height: 25%;
border: 1px solid #3cbfdf; border: 1px solid #2E6099;
display: flex; display: flex;
flex-direction: column; flex-direction: column;
align-items: center; align-items: center;
@ -220,7 +221,7 @@ const getEchart = () => {
.left-div { .left-div {
width: 20%; width: 20%;
height: 100%; height: 100%;
border: 1px solid #3cbfdf; border: 1px solid #2E6099;
display: flex; display: flex;
flex-direction: column; flex-direction: column;
justify-content: center; justify-content: center;
@ -231,7 +232,7 @@ const getEchart = () => {
} }
.span-div { .span-div {
padding: 5px 25px; padding: 5px 25px;
background: #3cbfdf; background: #2E6099;
border-radius: 15px; border-radius: 15px;
color:#fff; color:#fff;
} }
@ -240,7 +241,7 @@ const getEchart = () => {
.right-div { .right-div {
width: 79%; width: 79%;
height: 100%; height: 100%;
border: 1px solid #3cbfdf; border: 1px solid #2E6099;
display: flex; display: flex;
flex-direction: column; flex-direction: column;
justify-content: space-between; justify-content: space-between;
@ -266,6 +267,16 @@ const getEchart = () => {
transform: translateX(50%); transform: translateX(50%);
width: 25%; width: 25%;
} }
.timestamp {
color: #fff;;
}
:deep(.el-card) {
border: none;
margin-top:5px;
}
:deep(.el-card__body) {
color: #fff;
}
} }
:deep(.el-timeline-item__tail) { :deep(.el-timeline-item__tail) {

View File

@ -9,6 +9,9 @@
<div class="button" @click="setLabel"> <div class="button" @click="setLabel">
{{ isAddLabel ? '添加标签' : '移除标签' }} {{ isAddLabel ? '添加标签' : '移除标签' }}
</div> </div>
<div class="button" @click="setBottom()">
{{ isRemoveBottom ? '移除地板' : '恢复地板' }}
</div>
<div class="button" @click="roam()"> <div class="button" @click="roam()">
漫游 漫游
</div> </div>
@ -42,9 +45,10 @@ let i = 1;
let mouse = new THREE.Vector2(); let mouse = new THREE.Vector2();
let labelRenderer = new CSS2DRenderer(); //CSS2DRenderer let labelRenderer = new CSS2DRenderer(); //CSS2DRenderer
const data = reactive({ const data = reactive({
isAddLabel: true isAddLabel: true,
isRemoveBottom: true
}); });
const { isAddLabel } = toRefs(data); const { isAddLabel,isRemoveBottom } = toRefs(data);
// //
Bus.on('clickBuild', (isParent) => { Bus.on('clickBuild', (isParent) => {
// Todo // Todo
@ -370,6 +374,18 @@ const removeLabel = () => {
document.body.removeChild(labelRenderer.domElement); document.body.removeChild(labelRenderer.domElement);
} }
//
const setBottom = () => {
var target = scene.getObjectByName('set1');
if (isRemoveBottom.value) {
var target = scene.getObjectByName('set1');
target.visible = false;
} else {
target.visible = true;
}
isRemoveBottom.value = !isRemoveBottom.value;
}
</script> </script>
<style lang='scss'> <style lang='scss'>
#gltf { #gltf {

View File

@ -24,14 +24,15 @@
<!-- 实时数据 --> <!-- 实时数据 -->
<RealData v-if="activateIndex == 2" @openDialog="openDialog1"></RealData> <RealData v-if="activateIndex == 2" @openDialog="openDialog1"></RealData>
<!-- 资产信息弹出框 --> <!-- 资产信息弹出框 -->
<el-dialog v-model="dialogVisible" title="资产信息" width="1200px" append-to-body> <el-dialog v-model="dialogVisible" title="资产信息" width="1200px" custom-class="bim-dialog" append-to-body>
<DeviceInfoDialog @viewDetail="viewDetail"></DeviceInfoDialog> <DeviceInfoDialog @viewDetail="viewDetail"></DeviceInfoDialog>
</el-dialog> </el-dialog>
<el-dialog v-model="dialogVisible1" title="实时数据" width="1200px" append-to-body> <el-dialog v-model="dialogVisible1" title="实时数据" width="1200px" custom-class="bim-dialog" append-to-body>
<RealInfoDialog></RealInfoDialog> <RealInfoDialog></RealInfoDialog>
</el-dialog> </el-dialog>
<!-- 资产详情 --> <!-- 资产详情 -->
<el-dialog v-model="dialogVisible2" v-if="dialogVisible2" title="资产详情" width="1500px" append-to-body> <el-dialog v-model="dialogVisible2" v-if="dialogVisible2" title="资产详情" width="1500px" custom-class="bim-dialog"
append-to-body>
<DeviceDetial></DeviceDetial> <DeviceDetial></DeviceDetial>
</el-dialog> </el-dialog>

View File

@ -12,7 +12,7 @@ onMounted(() => {
getCharts(); getCharts();
}) })
}) })
var colors = ['#24CDFB','#1890FF'];
const getCharts = () => { const getCharts = () => {
var dom = document.getElementById("bar"); var dom = document.getElementById("bar");
if (dom) { if (dom) {
@ -59,7 +59,11 @@ const getCharts = () => {
}, },
splitLine: { splitLine: {
// 线 // 线
show: false, lineStyle: {
type: "dotted", //线 dotted线 solid:线
color: "#29507E",
},
show: true,
}, },
show: true, show: true,
maxInterval: 50000 // min maxInterval: 50000 // min
@ -88,7 +92,8 @@ const getCharts = () => {
{ {
name: '2023资产', name: '2023资产',
type: 'bar', type: 'bar',
barWidth: 36, color: colors[0],
barWidth: 20,
// xAxisIndex:1, // xAxisIndex:1,
data: [182, 234, 290, 104, 131, 100], data: [182, 234, 290, 104, 131, 100],
itemStyle: { itemStyle: {
@ -96,7 +101,7 @@ const getCharts = () => {
label: { label: {
show: true, show: true,
textStyle: { textStyle: {
color: "#5470c6", color: colors[0],
}, },
position: "right", position: "right",
}, },
@ -106,15 +111,16 @@ const getCharts = () => {
{ {
name: '2022资产', name: '2022资产',
type: 'bar', type: 'bar',
barWidth: 16, color: colors[1],
barWidth: 20,
// xAxisIndex:1, // xAxisIndex:1,
data: [193, 234, 310, 121, 134, 681], data: [93, 300, 30, 530, 34, 681],
itemStyle: { itemStyle: {
normal: { normal: {
label: { label: {
show: true, show: true,
textStyle: { textStyle: {
color: "#91cc75", color: colors[1],
}, },
position: "right", position: "right",
}, },

View File

@ -2,7 +2,11 @@
<dv-border-box-12 class="device-div"> <dv-border-box-12 class="device-div">
<div class="device-list"> <div class="device-list">
<div v-for="(item, index) of deviceList" :key="index"> <div v-for="(item, index) of deviceList" :key="index">
<img :src="item.imgUrl" alt="" width="60"> <!-- <img :src="item.imgUrl" alt="" width="60"> -->
<el-icon size="60" color="#1890ff" v-if="index==0"><Suitcase /></el-icon>
<el-icon size="60" color="#1890ff" v-if="index==1"><TakeawayBox /></el-icon>
<el-icon size="60" color="#1890ff" v-if="index==2"><Box /></el-icon>
<el-icon size="60" color="#1890ff" v-if="index==3"><SoldOut /></el-icon>
<font class="num" :style="{ 'color': item.color }">{{ item.num }}</font> <font class="num" :style="{ 'color': item.color }">{{ item.num }}</font>
<span>{{ item.name }}</span> <span>{{ item.name }}</span>
</div> </div>
@ -18,26 +22,30 @@ const deviceList = [
{ {
name: '资产总数', name: '资产总数',
num: '8909', num: '8909',
color: '#0f40f5', color: '#fff',
imgUrl: IconPd imgUrl: IconPd,
icon: 'Suitcase'
}, },
{ {
name: '维修未完成总数', name: '维修未完成总数',
num: '89', num: '89',
color: '#e99f81', color: '#fff',
imgUrl: IconWx imgUrl: IconWx,
icon: 'TakeawayBox'
}, },
{ {
name: '待巡检执行总数', name: '待巡检执行总数',
num: '58', num: '58',
color: '#81b337', color: '#fff',
imgUrl: IconXj imgUrl: IconXj,
icon: 'Box'
}, },
{ {
name: '待保养执行总数', name: '待保养执行总数',
num: '46', num: '46',
color: '#347caf', color: '#fff',
imgUrl: IconBy imgUrl: IconBy,
icon: 'SoldOut'
} }
] ]
</script> </script>
@ -61,7 +69,7 @@ const deviceList = [
color: #fff; color: #fff;
.num { .num {
font-size: 48px; font-size: 36px;
} }
} }
} }

View File

@ -11,7 +11,7 @@ onMounted(() => {
getCharts(); getCharts();
}) })
}) })
var colors = ['#1890FF','#24CDFB'];
const getCharts = () => { const getCharts = () => {
var dom = document.getElementById("line"); var dom = document.getElementById("line");
if (dom) { if (dom) {
@ -55,7 +55,11 @@ const getCharts = () => {
}, },
splitLine: { splitLine: {
// 线 // 线
show: false, lineStyle: {
type: "dotted", //线 dotted线 solid:线
color: "#29507E",
},
show: true,
}, },
axisLabel: { axisLabel: {
textStyle: { textStyle: {
@ -102,6 +106,7 @@ const getCharts = () => {
{ {
name: '生产数据', name: '生产数据',
type: 'bar', type: 'bar',
color: colors[0],
barWidth: 18, barWidth: 18,
// xAxisIndex:1, // xAxisIndex:1,
data: [182, 234, 290, 104, 131, 100, 182, 234, 290, 104, 131, 100], data: [182, 234, 290, 104, 131, 100, 182, 234, 290, 104, 131, 100],
@ -110,7 +115,7 @@ const getCharts = () => {
label: { label: {
show: true, show: true,
textStyle: { textStyle: {
color: "#5470c6", color: colors[0],
}, },
position: "top", position: "top",
}, },
@ -120,6 +125,7 @@ const getCharts = () => {
{ {
name: '销售数据', name: '销售数据',
type: 'line', type: 'line',
color: colors[1],
// xAxisIndex:1, // xAxisIndex:1,
data: [193, 234, 310, 121, 134, 181, 193, 234, 310, 121, 134, 181], data: [193, 234, 310, 121, 134, 181, 193, 234, 310, 121, 134, 181],
itemStyle: { itemStyle: {
@ -127,7 +133,7 @@ const getCharts = () => {
label: { label: {
show: true, show: true,
textStyle: { textStyle: {
color: "#91cc75", color: colors[1],
}, },
position: "top", position: "top",
}, },

View File

@ -12,80 +12,239 @@ onMounted(() => {
getCharts(); getCharts();
}) })
}) })
var wei = 10;
var yi = 20;
var doing = 8;
var total = 38;
const getCharts = () => { const getCharts = () => {
var dom = document.getElementById("pie"); var dom = document.getElementById("pie");
if (dom) { if (dom) {
// //
dom.removeAttribute('_echarts_instance_') dom.removeAttribute('_echarts_instance_')
var myChart = echarts.init(dom); var myChart = echarts.init(dom);
let option = { var option = {
// backgroundColor: 'white',
tooltip: { tooltip: {
show: true, trigger: "item",
trigger: 'item', confine: true, //
//{a}(){b}(),{c}(),{d}() backgroundColor: "#1E2857", //rgba
formatter: "{a} <br/>{b} : {c}", borderColor: "#1E2857",
backgroundColor: "rgba(1, 13, 19, 0.5)", color: "#fff",
borderWidth: 0,
textStyle: { textStyle: {
color: "rgba(212, 232, 254, 1)", color: "#fff",
// fontSize: fontChart(0.24), },
axisPointer: {
type: "cross",
label: {
backgroundColor: "#6a7985",
},
},
// {a}, {b}{c}{d}{e} {a}{b}{c}, {d}
//formatter: "{a} <br/>{b} : {c} ({d}%)",
formatter(data) {
return (
data.name +
" : " +
data.value +
" (" +
data.percent.toFixed(1) +
"%)"
);
},
},
grid: {
top: "0%",
left: "0%",
right: "0%",
bottom: "0%",
},
graphic: {
elements: [
{
type: "text",
left: "27%",
top: "middle",
style: {
text: total + "\n" + "总数",
fill: "#fff",
},
},
],
},
legend: [
{
top: "25%",
left: "60%",
itemWidth: 12,
itemHeight: 5,
orient: "vertical",
itemGap: 30,
data: ["数据一"],
formatter: () => {
const arr = [
"{b|" + "数据一" + "}\xa0\xa0\xa0",
"{a|" + wei + "}\xa0\xa0\xa0\xa0",
];
return arr.join("");
},
textStyle: {
rich: {
a: {
fontSize: 18,
color: "#FD2525",
},
b: {
fontSize: 16,
color: "#fff",
},
},
},
},
{
top: "45%",
left: "60%",
itemWidth: 12,
itemHeight: 5,
orient: "vertical",
itemGap: 30,
data: ["数据二"],
formatter: () => {
const arr = [
"{b|" + "数据二" + "}\xa0\xa0\xa0",
"{a|" + yi + "}\xa0\xa0\xa0\xa0",
];
return arr.join("");
},
textStyle: {
rich: {
a: {
fontSize: 18,
color: "#33AAFF",
},
b: {
fontSize: 16,
color: "#fff",
},
},
},
},
{
top: "65%",
left: "60%",
itemWidth: 12,
itemHeight: 5,
orient: "vertical",
itemGap: 30,
data: ["数据三"],
formatter: () => {
const arr = [
"{b|" + "数据三" + "}\xa0\xa0\xa0",
"{a|" + doing + "}\xa0\xa0\xa0\xa0",
];
return arr.join("");
},
textStyle: {
rich: {
a: {
fontSize: 18,
color: "#E7BF69",
},
b: {
fontSize: 16,
color: "#fff",
},
},
},
},
],
series: [
//
{
name: "",
type: "pie",
radius: ["40%", "60%"],
center: ["30%", "50%"],
avoidLabelOverlap: false,
label: {
show: false,
position: "center",
},
labelLine: {
show: false,
},
z: 10,
emphasis: {
scale: false, //
},
data: [
{
value: wei,
name: "数据一",
itemStyle: {
borderRadius: 10,
color: "#FD2525",
opacity: 0.6,
},
},
{
value: yi,
name: "数据二",
itemStyle: {
color: "#1f5189",
opacity: 0.6,
},
},
{
value: doing,
name: "数据三",
itemStyle: {
color: "#e7bf69",
opacity: 0.8,
},
},
],
},
//
{
name: "",
type: "pie",
radius: ["50%", "60%"],
center: ["30%", "50%"],
avoidLabelOverlap: false,
label: {
show: false,
position: "center",
},
labelLine: {
show: false,
},
z: 11,
data: [
{
value: wei,
name: "数据一",
itemStyle: {
color: "#aa2b3d",
}, },
}, },
legend: {
// orient: 'vertical',
left: 'center',
top: '5%',
itemWidth: 15,
itemHeight: 10,
itemGap: 25,
borderRadius: 4,
textStyle: {
color: "#ffff",
fontFamily: "Alibaba PuHuiTi",
fontSize: 14,
fontWeight: 400,
},
},
series: [
{ {
name: '', value: yi,
type: 'pie', name: "数据二",
radius: '50%',
center: ['50%', '50%'],
data: [
{ value: 1048, name: '数据一' },
{ value: 735, name: '数据二' },
{ value: 580, name: '数据三' },
],
label: {
normal: {
formatter: ["{b|{b}}", "{c|{c}}"].join("\n"),
rich: {
c: {
color: "inherit",
fontSize: 20,
fontWeight: "bold",
lineHeight: 5,
},
b: {
fontSize: 15,
height: 40,
},
},
},
},
emphasis: {
itemStyle: { itemStyle: {
shadowBlur: 10, color: "#1f5189",
shadowOffsetX: 0,
shadowColor: 'rgba(0, 0, 0, 0.5)'
}
}
}, },
] },
{
value: doing,
name: "数据三",
itemStyle: {
color: "#655e64",
},
},
],
},
],
}; };
option && myChart.setOption(option); option && myChart.setOption(option);

View File

@ -59,7 +59,11 @@ const getCharts = () => {
}, },
splitLine: { splitLine: {
// 线 // 线
show: false, lineStyle: {
type: "dotted", //线 dotted线 solid:线
color: "#29507E",
},
show: true,
}, },
show: true, show: true,
maxInterval: 50000 // min maxInterval: 50000 // min
@ -89,14 +93,30 @@ const getCharts = () => {
name: '系统数据分析', name: '系统数据分析',
type: 'bar', type: 'bar',
barWidth: 16, barWidth: 16,
color: new echarts.graphic.LinearGradient( //
0,
0,
1,
1,
[{
offset: 0,
color: "#146fdd" //
},
{
offset: 1,
color: "#42bffc" //
}
],
false
),
// xAxisIndex:1, // xAxisIndex:1,
data: [182, 234, 290, 104, 131, 100], data: [182, 234, 280, 104, 131, 100, 50, 200, 100, 60],
itemStyle: { itemStyle: {
normal: { normal: {
label: { label: {
show: true, show: true,
textStyle: { textStyle: {
color: "#5470c6", color: "#42bffc",
}, },
position: "right", position: "right",
}, },

View File

@ -54,7 +54,7 @@ const gotoPage = (item) => {
display: flex; display: flex;
align-items: center; align-items: center;
// background: #3d5d9a; // background: #3d5d9a;
background: #030e23; background: #08376f;
color: #fff; color: #fff;
> div { > div {
width: 260px; width: 260px;
@ -65,6 +65,7 @@ const gotoPage = (item) => {
border-right: 1px solid #020c45; border-right: 1px solid #020c45;
justify-content: center; justify-content: center;
font-size: 20px; font-size: 20px;
// background: #3d5d9a;
} }
} }
.home-page { .home-page {
@ -84,22 +85,25 @@ const gotoPage = (item) => {
top: 10px; top: 10px;
left: 10px; left: 10px;
padding: 15px; padding: 15px;
background-image: linear-gradient(to right,rgba(30,45,123,.7),rgba(174,179,249,.1));
} }
.bar-div { .bar-div {
position: absolute; position: absolute;
width: 400px; width: 400px;
height: 98%; height: 818px;
top: 10px; top: 10px;
right: 10px; right: 10px;
padding: 15px; padding: 15px;
background-image: linear-gradient(to left,rgba(30,45,123,.7),rgba(174,179,249,.1));
} }
.xt-bar-div { .xt-bar-div {
position: absolute; position: absolute;
width: 400px; width: 400px;
height: 460px; height: 460px;
top: 370px; bottom: 5px;
left: 10px; left: 10px;
padding: 15px; padding: 15px;
background-image: linear-gradient(to right,rgba(30,45,123,.7),rgba(174,179,249,.1));
} }
.device-div { .device-div {
position: absolute; position: absolute;
@ -108,16 +112,17 @@ const gotoPage = (item) => {
width: calc(100% - 840px); width: calc(100% - 840px);
height: 200px; height: 200px;
padding: 15px; padding: 15px;
// background: #b2cae0; background-image: linear-gradient(to bottom,rgba(30,45,123,.7),rgba(174,179,249,.1));
} }
.line-div { .line-div {
position: absolute; position: absolute;
bottom: 10px; bottom: 5px;
left: 420px; left: 420px;
width: calc(100% - 840px); width: calc(100% - 840px);
height: 200px; height: 200px;
padding: 15px; padding: 15px;
// background: #b2cae0; // background: #b2cae0;
background-image: linear-gradient(to top,rgba(30,45,123,.7),rgba(174,179,249,.1));
} }
} }
} }