From 0630126012170da25291d55f0a1bd3130e64f434 Mon Sep 17 00:00:00 2001
From: liuying <1427574514@qq.com>
Date: 周一, 28 4月 2025 15:45:28 +0800
Subject: [PATCH] 一汽大屏 未提交的代码
---
yiqi_screen1216二维.rar | 0
yiqi_screen/src/assets/images/8.gif | 0
yiqi_screen/src/assets/images/quan2.png | 0
yiqi_screen/src/components/ProductionStatistics1.vue | 303 +++++
yiqi_screen/src/components/ProductionStatistics copy.vue | 277 ++++
yiqi_screen/src/components/ProductionStatistics备份1113.vue | 458 ++++++++
yiqi_screen/src/components/EquipmentRunStatus5.vue | 67 +
yiqi_screen/src/components/img/t.js | 2
yiqi_screen/src/components/Content备份.vue | 658 +++++++++++
yiqi_screen/package.json | 1
yiqi_screen/src/components/ProductionStatistics copy1113.vue | 325 +++++
yiqi_screen/src/assets/t.js | 2
yiqi_screen/src/components/EquipmentRunStatus4.vue | 71 +
yiqi_screen/src/components/ProductionStatistics.vue | 130 -
yiqi_screen/src/components/ProductionCompletionTrend.vue | 55
yiqi_screen/src/assets/images/blue/zhuozi.png | 0
yiqi_screen/src/assets/images/9.png | 0
yiqi_screen/src/App.vue | 3
yiqi_screen/src/components/EquipmentRunStatus3.vue | 67 +
yiqi_screen/src/assets/images/quan.png | 0
yiqi_screen/src/assets/images/yellow/zhuozi.png | 0
yiqi_screen/package-lock.json | 39
yiqi_screen/src/assets/images/40.png | 0
yiqi_screen/src/assets/images/white/zhuozi.png | 0
yiqi_screen/src/components/EquipmentRunStatus2.vue | 71 +
yiqi_screen/src/assets/images/6.gif | 0
yiqi_screen/src/assets/images/green/zhuozi.png | 0
yiqi_screen/src/assets/images/red/zhuozi.png | 0
yiqi_screen/src/components/Content.vue | 318 ++++-
yiqi_screen/src/components/ProductionStatistics copy 2.vue | 458 ++++++++
yiqi_screen/src/api/api.js | 4
31 files changed, 3,104 insertions(+), 205 deletions(-)
diff --git a/yiqi_screen/package-lock.json b/yiqi_screen/package-lock.json
index 08504af..0deeb98 100644
--- a/yiqi_screen/package-lock.json
+++ b/yiqi_screen/package-lock.json
@@ -9,6 +9,7 @@
"version": "0.1.0",
"dependencies": {
"@jiaminghi/data-view": "^2.10.0",
+ "animejs": "^3.2.2",
"axios": "^1.6.0",
"core-js": "^3.8.3",
"echarts": "^5.4.3",
@@ -3459,6 +3460,11 @@
"ajv": "^6.9.1"
}
},
+ "node_modules/animejs": {
+ "version": "3.2.2",
+ "resolved": "https://registry.npmmirror.com/animejs/-/animejs-3.2.2.tgz",
+ "integrity": "sha512-Ao95qWLpDPXXM+WrmwcKbl6uNlC5tjnowlaRYtuVDHHoygjtIPfDUoK9NthrlZsQSKjZXlmji2TrBUAVbiH0LQ=="
+ },
"node_modules/ansi-colors": {
"version": "4.1.3",
"resolved": "https://registry.npmmirror.com/ansi-colors/-/ansi-colors-4.1.3.tgz",
@@ -5351,12 +5357,12 @@
}
},
"node_modules/echarts": {
- "version": "5.4.3",
- "resolved": "https://registry.npmmirror.com/echarts/-/echarts-5.4.3.tgz",
- "integrity": "sha512-mYKxLxhzy6zyTi/FaEbJMOZU1ULGEQHaeIeuMR5L+JnJTpz+YR03mnnpBhbR4+UYJAgiXgpyTVLffPAjOTLkZA==",
+ "version": "5.5.1",
+ "resolved": "https://registry.npmmirror.com/echarts/-/echarts-5.5.1.tgz",
+ "integrity": "sha512-Fce8upazaAXUVUVsjgV6mBnGuqgO+JNDlcgF79Dksy4+wgGpQB2lmYoO4TSweFg/mZITdpGHomw/cNBJZj1icA==",
"dependencies": {
"tslib": "2.3.0",
- "zrender": "5.4.4"
+ "zrender": "5.6.0"
}
},
"node_modules/echarts/node_modules/tslib": {
@@ -12822,9 +12828,9 @@
"dev": true
},
"node_modules/zrender": {
- "version": "5.4.4",
- "resolved": "https://registry.npmmirror.com/zrender/-/zrender-5.4.4.tgz",
- "integrity": "sha512-0VxCNJ7AGOMCWeHVyTrGzUgrK4asT4ml9PEkeGirAkKNYXYzoPJCLvmyfdoOXcjTHPs10OZVMfD1Rwg16AZyYw==",
+ "version": "5.6.0",
+ "resolved": "https://registry.npmmirror.com/zrender/-/zrender-5.6.0.tgz",
+ "integrity": "sha512-uzgraf4njmmHAbEUxMJ8Oxg+P3fT04O+9p7gY+wJRVxo8Ge+KmYv0WJev945EH4wFuc4OY2NLXz46FZrWS9xJg==",
"dependencies": {
"tslib": "2.3.0"
}
@@ -15447,6 +15453,11 @@
"dev": true,
"requires": {}
},
+ "animejs": {
+ "version": "3.2.2",
+ "resolved": "https://registry.npmmirror.com/animejs/-/animejs-3.2.2.tgz",
+ "integrity": "sha512-Ao95qWLpDPXXM+WrmwcKbl6uNlC5tjnowlaRYtuVDHHoygjtIPfDUoK9NthrlZsQSKjZXlmji2TrBUAVbiH0LQ=="
+ },
"ansi-colors": {
"version": "4.1.3",
"resolved": "https://registry.npmmirror.com/ansi-colors/-/ansi-colors-4.1.3.tgz",
@@ -16958,12 +16969,12 @@
"dev": true
},
"echarts": {
- "version": "5.4.3",
- "resolved": "https://registry.npmmirror.com/echarts/-/echarts-5.4.3.tgz",
- "integrity": "sha512-mYKxLxhzy6zyTi/FaEbJMOZU1ULGEQHaeIeuMR5L+JnJTpz+YR03mnnpBhbR4+UYJAgiXgpyTVLffPAjOTLkZA==",
+ "version": "5.5.1",
+ "resolved": "https://registry.npmmirror.com/echarts/-/echarts-5.5.1.tgz",
+ "integrity": "sha512-Fce8upazaAXUVUVsjgV6mBnGuqgO+JNDlcgF79Dksy4+wgGpQB2lmYoO4TSweFg/mZITdpGHomw/cNBJZj1icA==",
"requires": {
"tslib": "2.3.0",
- "zrender": "5.4.4"
+ "zrender": "5.6.0"
},
"dependencies": {
"tslib": {
@@ -22854,9 +22865,9 @@
}
},
"zrender": {
- "version": "5.4.4",
- "resolved": "https://registry.npmmirror.com/zrender/-/zrender-5.4.4.tgz",
- "integrity": "sha512-0VxCNJ7AGOMCWeHVyTrGzUgrK4asT4ml9PEkeGirAkKNYXYzoPJCLvmyfdoOXcjTHPs10OZVMfD1Rwg16AZyYw==",
+ "version": "5.6.0",
+ "resolved": "https://registry.npmmirror.com/zrender/-/zrender-5.6.0.tgz",
+ "integrity": "sha512-uzgraf4njmmHAbEUxMJ8Oxg+P3fT04O+9p7gY+wJRVxo8Ge+KmYv0WJev945EH4wFuc4OY2NLXz46FZrWS9xJg==",
"requires": {
"tslib": "2.3.0"
},
diff --git a/yiqi_screen/package.json b/yiqi_screen/package.json
index 2e16487..bf49fa9 100644
--- a/yiqi_screen/package.json
+++ b/yiqi_screen/package.json
@@ -9,6 +9,7 @@
},
"dependencies": {
"@jiaminghi/data-view": "^2.10.0",
+ "animejs": "^3.2.2",
"axios": "^1.6.0",
"core-js": "^3.8.3",
"echarts": "^5.4.3",
diff --git a/yiqi_screen/src/App.vue b/yiqi_screen/src/App.vue
index 3559a15..e5cb343 100644
--- a/yiqi_screen/src/App.vue
+++ b/yiqi_screen/src/App.vue
@@ -20,11 +20,12 @@
<style>
html, body {
+ font-size: 79.5833px !important;
width: 1910px;
height: 1070px;
/* width:100%; */
/* height:100%; */
- overflow: hidden;
+ overflow: hidden;
background-color: #00083b;
/* font-size: 80px !important; */
/* background-image: url('~@/assets/images/bg.png'); */
diff --git a/yiqi_screen/src/api/api.js b/yiqi_screen/src/api/api.js
index 4e4b29d..e512858 100644
--- a/yiqi_screen/src/api/api.js
+++ b/yiqi_screen/src/api/api.js
@@ -6,8 +6,8 @@
// if(process.env.NODE_ENV === "development"){
// baseURL = "http://localhost:7788/" //杩欓噷鍙湪vue.config.js鍋氫竴涓唬鐞嗐�愪唬鐞嗕唬鐮佽涓嬨��
// }else{
- // baseURL = "http://localhost:7788/api"
- baseURL = "http://192.168.216.203:7788/api" // 绾夸笂鐜鍦板潃
+ baseURL = "http://localhost:7788/api"
+ // baseURL = "http://192.168.216.203:7788/api" // 绾夸笂鐜鍦板潃
// }
// baseURL = "http://localhost:7788/api" //鏈湴娴嬭瘯鐜
diff --git a/yiqi_screen/src/assets/images/40.png b/yiqi_screen/src/assets/images/40.png
new file mode 100644
index 0000000..4ec77cb
--- /dev/null
+++ b/yiqi_screen/src/assets/images/40.png
Binary files differ
diff --git a/yiqi_screen/src/assets/images/6.gif b/yiqi_screen/src/assets/images/6.gif
new file mode 100644
index 0000000..9b3a60a
--- /dev/null
+++ b/yiqi_screen/src/assets/images/6.gif
Binary files differ
diff --git a/yiqi_screen/src/assets/images/8.gif b/yiqi_screen/src/assets/images/8.gif
new file mode 100644
index 0000000..6a7aa3d
--- /dev/null
+++ b/yiqi_screen/src/assets/images/8.gif
Binary files differ
diff --git a/yiqi_screen/src/assets/images/9.png b/yiqi_screen/src/assets/images/9.png
new file mode 100644
index 0000000..4ec77cb
--- /dev/null
+++ b/yiqi_screen/src/assets/images/9.png
Binary files differ
diff --git a/yiqi_screen/src/assets/images/blue/zhuozi.png b/yiqi_screen/src/assets/images/blue/zhuozi.png
new file mode 100644
index 0000000..5f306b9
--- /dev/null
+++ b/yiqi_screen/src/assets/images/blue/zhuozi.png
Binary files differ
diff --git a/yiqi_screen/src/assets/images/green/zhuozi.png b/yiqi_screen/src/assets/images/green/zhuozi.png
new file mode 100644
index 0000000..dbc09aa
--- /dev/null
+++ b/yiqi_screen/src/assets/images/green/zhuozi.png
Binary files differ
diff --git a/yiqi_screen/src/assets/images/quan.png b/yiqi_screen/src/assets/images/quan.png
index 8c2bef0..4343132 100644
--- a/yiqi_screen/src/assets/images/quan.png
+++ b/yiqi_screen/src/assets/images/quan.png
Binary files differ
diff --git a/yiqi_screen/src/assets/images/quan2.png b/yiqi_screen/src/assets/images/quan2.png
new file mode 100644
index 0000000..8c2bef0
--- /dev/null
+++ b/yiqi_screen/src/assets/images/quan2.png
Binary files differ
diff --git a/yiqi_screen/src/assets/images/red/zhuozi.png b/yiqi_screen/src/assets/images/red/zhuozi.png
new file mode 100644
index 0000000..bbede40
--- /dev/null
+++ b/yiqi_screen/src/assets/images/red/zhuozi.png
Binary files differ
diff --git a/yiqi_screen/src/assets/images/white/zhuozi.png b/yiqi_screen/src/assets/images/white/zhuozi.png
new file mode 100644
index 0000000..bf654a0
--- /dev/null
+++ b/yiqi_screen/src/assets/images/white/zhuozi.png
Binary files differ
diff --git a/yiqi_screen/src/assets/images/yellow/zhuozi.png b/yiqi_screen/src/assets/images/yellow/zhuozi.png
new file mode 100644
index 0000000..e906e3b
--- /dev/null
+++ b/yiqi_screen/src/assets/images/yellow/zhuozi.png
Binary files differ
diff --git a/yiqi_screen/src/assets/t.js b/yiqi_screen/src/assets/t.js
index 36e8e8a..63fb1fd 100644
--- a/yiqi_screen/src/assets/t.js
+++ b/yiqi_screen/src/assets/t.js
@@ -1 +1 @@
-export let zhu = ""
\ No newline at end of file
+export let zhu = '';
\ No newline at end of file
diff --git a/yiqi_screen/src/components/Content.vue b/yiqi_screen/src/components/Content.vue
index b0010f1..9c43bf8 100644
--- a/yiqi_screen/src/components/Content.vue
+++ b/yiqi_screen/src/components/Content.vue
@@ -20,30 +20,59 @@
<div class="main">
<div class="main-top">
<div class="main-top_ly">
+ <!-- 浜х嚎甯冨眬鍥� -->
<img
src="~@/assets/images/prodline_all.png"
class="prodline"
alt="line"
/>
- <!-- <img
- alt="t10"
- :src="require(`@/assets/images/10.png`)"
- class="OP88"
- id="animatedImage"
- />
+ <!-- <img src="~@/assets/images/9.png" class="line100" alt="line100" />
+ <p style="color: white;"> {{equipmentStatusData}} </p> -->
+
+
+ <!-- 椤堕儴 -->
+ <div v-for="item in equipmentStatusData">
+ <!-- <p style="color: white;font-size: 32px"> {{ item.equipmentCurrentState }} </p> -->
+
+ <img
+ :alt="item.workingProcedure"
+ :src="
+ require(`@/assets/images/${
+ imageColor[item.workingProcedure]
+ }/zhuozi.png`)
+ "
+ class="prodline_op325"
+ />
+
+ <img
+ :alt="item.workingProcedure"
+ v-if="
+ item.equipmentCurrentState == 1 &&
+ item.workingProcedure == 'OP30'
+ "
+ src="~@/assets/images/6.gif"
+ class="box100"
+ />
+ <img
+ v-if="
+ item.equipmentCurrentState == 1 &&
+ item.workingProcedure == 'OP20'
+ "
+ src="~@/assets/images/8.gif"
+ class="box200"
+ />
+ <img
+ v-if="
+ item.equipmentCurrentState == 1 &&
+ item.workingProcedure == 'OP50'
+ "
+ src="~@/assets/images/8.gif"
+ class="box300"
+ />
+ </div>
+
<img
- alt="t10"
- :src="require(`@/assets/images/10.png`)"
- class="OP89"
- />
- <img
- alt="t10"
- :src="require(`@/assets/images/10.png`)"
- class="OP90"
- /> -->
- <img
- alt="t1"
v-for="item in equipmentStatusData"
:key="item.id"
:src="
@@ -54,14 +83,16 @@
:class="`euip ${item.workingProcedure}`"
/>
- <img alt="t2" src="~@/assets/images/OP35.png" class="prodline_op35" />
<img
- alt="t3"
+ src="~@/assets/images/OP35.png"
+ class="prodline_op325"
+ />
+
+ <img
:src="require(`@/assets/images/${imageColor['OP10']}/OP40.png`)"
class="euip OP40"
/>
<img
- alt="t4"
:src="require(`@/assets/images/${imageColor['unit']}/unit.png`)"
class="euip unit"
/>
@@ -70,15 +101,21 @@
<!-- <button @click="flag=true">data鏀瑰彉</button> -->
<div class="main-bottom">
<div class="echarts-box border_left1">
- <div class="echarts-title">璁惧杩愯鐘舵�佺粺璁″浘</div>
+ <div class="echarts-title">
+ <span class="title1"> 璁惧杩愯鐘舵�佺粺璁″浘 </span>
+ </div>
<EquipmentRunStatus :equipmentStatusData="equipmentStatusData" />
</div>
<div class="echarts-box border_left2">
- <div class="echarts-title">浜х嚎鍋ュ悍鑳藉姏鍥�</div>
+ <div class="echarts-title">
+ <span class="title1"> 浜х嚎鍋ュ悍鑳藉姏鍥� </span>
+ </div>
<ProdlineHealthy />
</div>
<div class="echarts-box border_middle">
- <div class="echarts-title">璐ㄩ噺鏁版嵁瓒嬪娍鍥�</div>
+ <div class="echarts-title">
+ <span class="title1"> 璐ㄩ噺鏁版嵁瓒嬪娍鍥� </span>
+ </div>
<div class="box11">
{{ qualityData.qualityType }}
</div>
@@ -111,7 +148,18 @@
</div>
</div>
<div class="echarts-box border_right1">
- <div class="echarts-title">鏈彮/鏈湀浜ч噺缁熻</div>
+ <div class="echarts-title">
+ <span class="title1"> 鏈彮/鏈湀浜ч噺缁熻 </span>
+ </div>
+
+ <!--
+ <div class="ring-container quan1">
+ <div class="outer-ring"></div>
+ <div class="inner-ring"></div>
+ </div> -->
+
+ <div class="quan1"></div>
+ <div class="quan2"></div>
<ProductionStatistics :produceStatisData="produceStatisData" />
<div class="pie-label-left">
@@ -140,7 +188,9 @@
</div>
</div>
<div class="echarts-box border_right2">
- <div class="echarts-title">鐢熶骇瀹屾垚瓒嬪娍</div>
+ <div class="echarts-title">
+ <span class="title1"> 鐢熶骇瀹屾垚瓒嬪娍 </span>
+ </div>
<ProductionCompletionTrend
:produceCompletionData="produceCompletionData"
/>
@@ -270,11 +320,15 @@
(obj) => obj.workingProcedure == item.workingProcedure
);
if (res.length > 0) {
+ // item.equipmentCurrentState =5; 娴嬭瘯
equipmentData.push(item);
}
});
this.equipmentStatusData = equipmentData;
+ console.log(88888888);
+ console.log(JSON.stringify(this.equipmentStatusData) );
this.getImageColor(data);
+
} catch (error) {
console.log(error);
}
@@ -290,7 +344,8 @@
this.imageColor[item.workingProcedure] = result[0].color;
}
});
- // console.log(this.imageColor, "getImageColor");
+ console.log(5555555555);
+ console.log(this.imageColor, "getImageColor");
},
// 鑾峰彇璐ㄩ噺鏁版嵁
async getQualityData() {
@@ -335,35 +390,7 @@
},
},
mounted() {
- // var timeline = anime.timeline({
- // easing: "easeOutExpo", // 杩愬姩鏁堟灉
- // loop: true, // 璁剧疆鏃犻檺寰幆
- // });
- // // 绗竴涓姩鐢伙細妯悜绉诲姩
- // timeline
- // .add({
- // targets: "#animatedImage",
- // translateX: 280, // 鍚戝彸绉诲姩280px
- // duration: 2000, // 鍔ㄧ敾鎸佺画鏃堕棿
- // })
- // // 绗簩涓姩鐢伙細鍚戜笅绉诲姩
- // .add({
- // targets: "#animatedImage",
- // translateY: 50, // 鍚戜笅绉诲姩50px
- // duration: 2000, // 鍔ㄧ敾鎸佺画鏃堕棿
- // })
- // // 闂撮殧鏃堕棿鍥炲埌鍒濆浣嶇疆
- // .add({
- // targets: "#animatedImage",
- // translateX: 0, // 鍥炲埌鍒濆浣嶇疆
- // translateY: 0, // 鍥炲埌鍒濆浣嶇疆
- // duration: 0, // 涓嶉渶瑕佸姩鐢�
- // delay: 1000, // 闅旀柇鏃堕棿1绉�
- // });
- // setTimeout(() => {
- // timeline.pause(); // 鏆傚仠鍔ㄧ敾
- // document.getElementById('animatedImage').classList.add('hidden');
- // }, 8000);
+
},
// beforeDestroy(){
@@ -424,28 +451,28 @@
}
.left-text {
- font-size: 20px;
+ font-size: 16px;
color: #fff;
position: absolute;
- top: 63px;
+ top: 79px;
left: 37px;
width: 368px;
text-align: right;
- line-height: 48px;
+ line-height: 23px;
font-weight: 700;
- letter-spacing: -2px;
+ transform: scaleY(2);
}
.right-text {
- font-size: 18px;
+ font-size: 16px;
text-align: right;
color: #fff;
position: absolute;
- top: 63px;
+ top: 79px;
right: 268px;
- line-height: 48px;
+ line-height: 23px;
font-weight: 700;
- letter-spacing: -2px;
+ transform: scaleY(2);
}
}
@@ -472,7 +499,7 @@
width: 95%;
margin: 0 auto;
position: relative;
- height: 6.8rem;
+ height: 526px;
}
.prodline {
@@ -482,14 +509,22 @@
top: 50%;
left: 50%;
transform: translate(-50%, -50%);
+ height: 225px;
}
.prodline_op35 {
- display: none;
- // position: absolute;
- // top: 2.72rem;
- // left: 4.3rem;
- // width:1.8%;
+ position: absolute;
+ top: 246px;
+ left: 106px;
+ width: 40px;
+ z-index: 0;
+ }
+ .prodline_op325 {
+ position: absolute;
+ top: 254px;
+ left: 108px;
+ width: 38px;
+ height: 63px;
}
.euip {
@@ -500,41 +535,41 @@
}
.OP05 {
- top: -76px;
- left: -220px;
+ top: -122px;
+ left: -223px;
}
.OP10,
.OP40 {
- top: -90px;
- left: -236px;
- width: 112%;
- height: 902px;
+ top: -133px;
+ left: -145px;
+ height: 904px;
}
.OP20 {
top: -95px;
- left: 31px;
+ left: -77px;
width: 86%;
- transform: scale(1.5, 1.2);
}
.OP30 {
- top: -183px;
- left: -247px;
+ top: -152px;
+ left: -226px;
width: 2061px;
height: 923px;
}
.OP35 {
- top: -104px;
+ top: -151px;
left: -182px;
+ width: 100%;
+ z-index: 999;
}
.OP50 {
- top: -168px;
- left: -75px;
- width: 100%;
+ top: -108px;
+ left: 11px;
+ width: 90%;
}
.OP60 {
@@ -549,8 +584,13 @@
width: 101%;
}
- .OP80,
.unit {
+ top: -113px;
+ left: 86px;
+ transform: scale(1.2);
+ }
+
+ .OP80 {
top: -1.95rem;
left: 1.98rem;
}
@@ -563,7 +603,7 @@
}
.main-bottom {
- height: 320px;
+ height: 336px;
display: flex;
justify-content: center;
.border_left1 {
@@ -624,7 +664,6 @@
color: #00f8c6;
text-align: center;
border-bottom: 2px solid #0739a3;
-
}
}
@@ -697,4 +736,111 @@
.hidden {
display: none; /* 闅愯棌鍏冪礌 */
}
+
+// .ring-container {
+// position: relative;
+// width: 85px;
+// height: 85px;
+// display: flex;
+// justify-content: center;
+// align-items: center;
+// }
+
+// .outer-ring {
+// position: absolute;
+// width: 100%;
+// height: 100%;
+// border-radius: 50%;
+// background: transparent;
+// border: 1px solid #3498db; /* 澶栫幆棰滆壊 */
+// }
+
+// .inner-ring {
+// position: absolute;
+// width: 80%;
+// height: 80%;
+// border-radius: 50%;
+// background: transparent;
+// box-shadow: inset 0 0 30px #084b71;
+// border: 1px solid #3c5da9;
+// }
+
+// .quan1{
+// position: absolute;
+// top: 142px;
+// left: 19px;
+// }
+
+.quan1 {
+ position: absolute;
+ background-size: 100% 100%;
+ content: "";
+ width: 125px;
+ height: 118px;
+ z-index: -1;
+ top: 117px;
+ left: 3px;
+ transform: scaleY(2);
+ border-radius: 100%;
+ background-image: url("@/assets/images/quan.png"); /* 鏇挎崲涓烘偍鐨勮儗鏅浘璺緞 */
+ background-size: cover; /* 鎴栦娇鐢� contain锛屾牴鎹渶瑕侀�夋嫨 */
+ background-repeat: no-repeat;
+ background-size: 95%;
+}
+
+.quan2 {
+ position: absolute;
+ background-size: 100% 100%;
+ content: "";
+ width: 125px;
+ height: 118px;
+ z-index: -1;
+ top: 117px;
+ left: 120px;
+ transform: scaleY(2);
+ border-radius: 100%;
+ background-image: url("@/assets/images/quan.png"); /* 鏇挎崲涓烘偍鐨勮儗鏅浘璺緞 */
+ background-size: cover; /* 鎴栦娇鐢� contain锛屾牴鎹渶瑕侀�夋嫨 */
+ background-repeat: no-repeat;
+ background-size: 95%;
+}
+.box100 {
+ position: absolute;
+ left: 25%;
+ top: 35%;
+ width: 67px;
+ z-index: 9999;
+}
+
+.box200 {
+ position: absolute;
+ left: 4%;
+ top: 48%;
+ width: 77px;
+ z-index: 9999;
+}
+.box300 {
+ position: absolute;
+ left: 44%;
+ top: 49%;
+ width: 75px;
+ z-index: 9999;
+}
+.title1 {
+ transform: scaleY(2);
+ font-size: 12px;
+ display: block;
+ margin-top: 7px;
+}
+.zuozi {
+ position: absolute;
+ top: 10px;
+ left: 10px;
+}
+.line100 {
+ position: absolute;
+ left: 5px;
+ top: 64%;
+ height: 18px;
+}
</style>
diff --git "a/yiqi_screen/src/components/Content\345\244\207\344\273\275.vue" "b/yiqi_screen/src/components/Content\345\244\207\344\273\275.vue"
new file mode 100644
index 0000000..76bbcde
--- /dev/null
+++ "b/yiqi_screen/src/components/Content\345\244\207\344\273\275.vue"
@@ -0,0 +1,658 @@
+<template>
+ <!-- 涓婂崐閮ㄥ垎涔熷垎涓夋牸 -->
+ <div class="container">
+ <div class="header">
+ <div class="title">4GC涓変唬鍙戝姩鏈鸿繛鏉嗙嚎888</div>
+ <div class="left-text">
+ <div style="line-height: 30px">{{ nowTime }}</div>
+ <div style="padding-left: 25px">
+ 瀹夊叏鐢熶骇:{{ produceStatisData.currentSafeProductionDay }}澶�
+ </div>
+ </div>
+
+ <div class="right-text">
+ <div style="line-height: 30px">
+ 褰撳墠鐝:{{ produceStatisData.currentTeamName }}
+ </div>
+ <!-- style="padding-left:25px" -->
+ <div>鐝暱:{{ produceStatisData.currentTeamLeader }}</div>
+ </div>
+ </div>
+ <div class="main">
+ <div class="main-top">
+ <div class="width_left">
+ <div class="box1">
+ <div class="echarts-box border_left1">
+ <div class="echarts-title">缁熻鍥�1</div>
+ <EquipmentRunStatus2 :equipmentStatusData="equipmentStatusData" />
+ </div>
+ </div>
+ <br>
+ <br> <br>
+ <div class="box1">
+ <div class="echarts-box border_left1">
+ <div class="echarts-title">缁熻鍥�2</div>
+ <EquipmentRunStatus3 :equipmentStatusData="equipmentStatusData" />
+ </div>
+ </div>
+ </div>
+
+ <div class="width_middle">
+ <img src="~@/assets/images/prodline_all.png" class="prodline" />
+
+ <img
+ v-for="item in equipmentStatusData"
+ :key="item.id"
+ :src="
+ require(`@/assets/images/${imageColor[item.workingProcedure]}/${
+ item.workingProcedure
+ }.png`)
+ "
+ :class="`euip ${item.workingProcedure}`"
+ />
+
+ <img src="~@/assets/images/OP35.png" class="prodline_op35" />
+ <img
+ :src="require(`@/assets/images/${imageColor['OP10']}/OP40.png`)"
+ class="euip OP40"
+ />
+ <img
+ :src="require(`@/assets/images/${imageColor['unit']}/unit.png`)"
+ class="euip unit"
+ />
+ </div>
+
+ <div class="width_right">
+ <div class="box1">
+ <div class="echarts-box border_left1">
+ <div class="echarts-title">缁熻鍥�3</div>
+ <EquipmentRunStatus4 :equipmentStatusData="equipmentStatusData" />
+ </div>
+ </div>
+ <br>
+ <br> <br>
+ <div class="box1">
+ <div class="echarts-box border_left1">
+ <div class="echarts-title">缁熻鍥�4</div>
+ <EquipmentRunStatus5 :equipmentStatusData="equipmentStatusData" />
+ </div>
+ </div>
+ </div>
+ </div>
+
+ <!-- <button @click="flag=true">data鏀瑰彉</button> -->
+ <div class="main-bottom">
+ <div class="echarts-box border_left1">
+ <div class="echarts-title">璁惧杩愯鐘舵�佺粺璁″浘</div>
+ <EquipmentRunStatus :equipmentStatusData="equipmentStatusData" />
+ </div>
+ <div class="echarts-box border_left2">
+ <div class="echarts-title">浜х嚎鍋ュ悍鑳藉姏鍥�</div>
+ <ProdlineHealthy />
+ </div>
+ <div class="echarts-box border_middle">
+ <div class="echarts-title">璐ㄩ噺鏁版嵁瓒嬪娍鍥�</div>
+ <div
+ style="
+ color: #fff;
+ margin: 0 0.13rem;
+ text-align: center;
+ font-size: 0.17rem;
+ "
+ >
+ {{ qualityData.qualityType }}
+ </div>
+ <div>
+ <div
+ style="
+ margin: 0 0.13rem;
+ height: 0.13rem;
+ background-color: #f14158;
+ "
+ ></div>
+ <div
+ style="
+ margin: 0 0.13rem;
+ height: 0.13rem;
+ background-color: #a7cf29;
+ "
+ ></div>
+ </div>
+ <QualityDataTrendse :qualityData="qualityData.list" />
+ <div>
+ <div
+ style="
+ margin: 0 0.13rem;
+ height: 0.13rem;
+ background-color: #a7cf29;
+ "
+ ></div>
+ <div
+ style="
+ margin: 0 0.13rem;
+ height: 0.13rem;
+ background-color: #f14158;
+ "
+ ></div>
+ </div>
+ </div>
+ <div class="echarts-box border_right1">
+ <div class="echarts-title">鏈彮/鏈湀浜ч噺缁熻</div>
+ <ProductionStatistics :produceStatisData="produceStatisData" />
+ <div class="pie-label-left">
+ {{ produceStatisData.currentShiftProduceNum }}
+ <span
+ v-if="
+ produceStatisData.currentShiftPlanNum ||
+ produceStatisData.currentShiftPlanNum == 0
+ "
+ >/</span
+ >
+ {{ produceStatisData.currentShiftPlanNum }}
+ </div>
+ <div class="pie-label-right">
+ {{ produceStatisData.currentMonthProduceNum }}
+ <span
+ v-if="
+ produceStatisData.currentMonthPlanNum ||
+ produceStatisData.currentMonthPlanNum == 0
+ "
+ >/</span
+ >
+ {{ produceStatisData.currentMonthPlanNum }}
+ </div>
+ </div>
+ <div class="echarts-box border_right2">
+ <div class="echarts-title">鐢熶骇瀹屾垚瓒嬪娍</div>
+ <ProductionCompletionTrend
+ :produceCompletionData="produceCompletionData"
+ />
+ </div>
+ </div>
+ </div>
+ </div>
+</template>
+
+<script>
+// import OperationalAvailability from "./OperationalAvailability.vue";
+// import EquipmentStatus from "./EquipmentStatus.vue";
+// import ProductionCapacity from "./ProductionCapacity.vue";
+import EquipmentRunStatus from "./EquipmentRunStatus.vue";
+import EquipmentRunStatus2 from "./EquipmentRunStatus2.vue";
+import EquipmentRunStatus3 from "./EquipmentRunStatus3.vue";
+import EquipmentRunStatus4 from "./EquipmentRunStatus4.vue";
+import EquipmentRunStatus5 from "./EquipmentRunStatus5.vue";
+
+import ProdlineHealthy from "./ProdlineHealthy.vue";
+import ProductionCompletionTrend from "./ProductionCompletionTrend.vue";
+import ProductionStatistics from "./ProductionStatistics.vue";
+import QualityDataTrendse from "./QualityDataTrends.vue";
+import moment from "moment";
+
+import {
+ GetEquipmentCurrentState,
+ getQualityData,
+ getLargeScreenFrequency,
+ getProduceCompletionStatus,
+ getCurrentProduceInfo,
+} from "@/api/common";
+
+export default {
+ name: "MainContentZg",
+ components: {
+ EquipmentRunStatus,
+ EquipmentRunStatus2,
+ EquipmentRunStatus3,
+ EquipmentRunStatus4,
+ EquipmentRunStatus5,
+ ProductionStatistics,
+ ProductionCompletionTrend,
+ QualityDataTrendse,
+ ProdlineHealthy,
+ },
+ data() {
+ return {
+ dataTimer: null,
+ dateTimer: null,
+ time: 5000,
+ nowTime: moment(new Date()).format("YYYY-MM-DD HH:mm:ss"),
+ // flag: false,
+ option: {},
+ myChart: {},
+ EquipmentEnums: [
+ {
+ code: 1,
+ color: "green",
+ },
+ {
+ code: 2,
+ color: "white",
+ },
+ {
+ code: 3,
+ color: "blue",
+ },
+ {
+ code: 4,
+ color: "yellow",
+ },
+ {
+ code: 5,
+ color: "red",
+ },
+ ],
+ imageColor: {
+ OP05: "blue",
+ OP10: "blue",
+ OP20: "blue",
+ OP30: "blue",
+ OP35: "blue",
+ OP40: "blue",
+ OP50: "blue",
+ OP60: "blue",
+ OP70: "blue",
+ OP80: "blue",
+ unit: "blue",
+ },
+ equipmentStatusData: [
+ { workingProcedure: "OP05" },
+ { workingProcedure: "OP10" },
+ { workingProcedure: "OP20" },
+ { workingProcedure: "OP30" },
+ { workingProcedure: "OP35" },
+ { workingProcedure: "OP40" },
+ { workingProcedure: "OP50" },
+ { workingProcedure: "OP60" },
+ { workingProcedure: "OP70" },
+ { workingProcedure: "OP80" },
+ { workingProcedure: "unit" },
+ ],
+ qualityData: [],
+ produceCompletionData: [],
+ produceStatisData: {},
+ };
+ },
+ watch: {},
+ created() {
+ this.getLargeScreenFrequency();
+ this.getEquipmentCurrentState();
+ this.getQualityData();
+ this.getProduceCompletionStatus();
+ this.getCurrentProduceInfo();
+ this.dataTimer = setInterval(this.timerHandler, this.time);
+ this.dateTimer = setInterval(() => {
+ this.nowTime = moment(new Date()).format("YYYY-MM-DD HH:mm:ss");
+ }, 1000);
+ },
+ methods: {
+ // 瀹氭椂鍣ㄥ嚱鏁�
+ timerHandler() {
+ this.getEquipmentCurrentState();
+ this.getQualityData();
+ this.getProduceCompletionStatus();
+ this.getCurrentProduceInfo();
+ },
+ // 鑾峰彇璁惧鐘舵��
+ async getEquipmentCurrentState() {
+ try {
+ let { data } = await GetEquipmentCurrentState();
+ let equipmentData = [];
+ data.forEach((item) => {
+ const res = this.equipmentStatusData.filter(
+ (obj) => obj.workingProcedure == item.workingProcedure
+ );
+ if (res.length > 0) {
+ equipmentData.push(item);
+ }
+ });
+ this.equipmentStatusData = equipmentData;
+ this.getImageColor(data);
+ } catch (error) {
+ console.log(error);
+ }
+ },
+ // 鏍规嵁璁惧鐘舵�佽缃澶囬鑹�
+ getImageColor(data) {
+ data.forEach((item) => {
+ let result = this.EquipmentEnums.filter(
+ (obj) => obj.code == item.equipmentCurrentState
+ );
+ // console.log(item.equipmentCurrentState);
+ if (result.length > 0) {
+ this.imageColor[item.workingProcedure] = result[0].color;
+ }
+ });
+ // console.log(this.imageColor, "getImageColor");
+ },
+ // 鑾峰彇璐ㄩ噺鏁版嵁
+ async getQualityData() {
+ let { qualityData } = this;
+ try {
+ let { data } = await getQualityData({
+ qualityType: qualityData.qualityType,
+ });
+ this.qualityData = data;
+ // console.log(this.qualityData);
+ } catch (error) {
+ console.log(error);
+ }
+ },
+ // 鑾峰彇鐢熶骇瀹屾垚瓒嬪娍鏁版嵁
+ async getProduceCompletionStatus() {
+ try {
+ let { data } = await getProduceCompletionStatus();
+ this.produceCompletionData = data;
+ } catch (error) {
+ console.log(error);
+ }
+ },
+ // 鑾峰彇浜ч噺缁熻鏁版嵁
+ async getCurrentProduceInfo() {
+ try {
+ let { data } = await getCurrentProduceInfo();
+ this.produceStatisData = data;
+ // console.log(data);
+ } catch (error) {
+ console.log(error);
+ }
+ },
+ // 鑾峰彇瀹氭椂鍣ㄦ椂闂�
+ async getLargeScreenFrequency() {
+ try {
+ let { data } = await getLargeScreenFrequency();
+ this.time = data;
+ } catch (error) {
+ console.log(error);
+ }
+ },
+ },
+ // beforeDestroy(){
+ // clearInterval(this.dataTimer)
+ // clearInterval(this.dateTimer)
+ // }
+};
+</script>
+
+<style lang="scss" scoped>
+$allHeight: 13.5rem;
+$titleHeight: 2rem;
+
+.container {
+ width: 100%;
+ height: auto;
+
+ .header {
+ width: 100%;
+ height: 2rem;
+ background-image: url("~@/assets/images/title.png");
+ background-repeat: no-repeat;
+ background-size: 100% 100%;
+ margin-bottom: 0.25rem;
+ position: relative;
+
+ .title {
+ color: #41c7de;
+ font-size: 0.38rem;
+ font-weight: 700;
+ position: absolute;
+ top: 0.31rem;
+ left: 50%;
+ transform: translate(-50%);
+ letter-spacing: 8px;
+ }
+
+ .left-text {
+ font-size: 0.19rem;
+ color: #fff;
+ position: absolute;
+ top: 1.15rem;
+ left: 5rem;
+ }
+
+ .right-text {
+ font-size: 0.19rem;
+ text-align: right;
+ color: #fff;
+ position: absolute;
+ top: 1.15rem;
+ right: 5.3rem;
+ }
+ }
+
+ .main {
+ width: 100%;
+ height: auto;
+ // display: flex;
+ // flex-direction: column;
+ // justify-content: space-between;
+ padding: 0 0.28rem 0.19rem;
+
+ .main-top {
+ width: 100%;
+ margin: 0 auto;
+ height: 7.42rem;
+ display: flex;
+ margin-bottom: 0.29rem;
+
+ .width_left {
+ width: 18%;
+ height: 7.42rem;
+ }
+ .width_right {
+ width: 18%;
+ height: 7.42rem;
+ }
+
+ .width_middle {
+ width: 60%;
+ margin: 0 auto;
+ height: 7.42rem;
+ // background-color: #fff;
+ background-image: url("~@/assets/images/border_prodline.png");
+ background-size: 100% 100%;
+ // background-size: 101.1% 101.8%;
+ // background-position: -0.13rem -0.13rem;
+ position: relative;
+ .prodline {
+ width: 95%;
+ display: block;
+ position: absolute;
+ top: 50%;
+ left: 50%;
+ transform: translate(-50%, -50%);
+ }
+
+ .prodline_op35 {
+ position: absolute;
+ top: 2.82rem;
+ left: 2.6rem;
+ width: 1.8%;
+ }
+
+ .euip {
+ // width: 95%;
+ // position: absolute;
+ // top: -1.59rem;
+ // left: 1.28rem;
+
+ margin-top: 1.9rem;
+ width: 100%;
+ position: absolute;
+ margin-left: -.2rem;
+
+ }
+
+ .OP05 {
+ top: -1.58rem;
+ left: 0.12rem;
+ }
+
+ .OP10,
+ .OP40 {
+ top: -1.48rem;
+ left: 0.5rem;
+ }
+
+ .OP20 {
+ top: -1.8rem;
+ left: 0.3rem;
+ }
+
+ .OP30 {
+ top: -2.05rem;
+ left: 0.3rem;
+ }
+
+ .OP35 {
+ top: -1.8rem;
+ left: 0.2rem;
+ }
+
+ .OP50 {
+ top: -1.69rem;
+ left: 0.5rem;
+ }
+
+ .OP60 {
+ top: -1.65rem;
+ left: .7rem;
+ }
+
+ .OP70 {
+ top: -1.52rem;
+ left: 0.9rem;
+ }
+
+ .OP80,
+ .unit {
+ top: -1.95rem;
+ left: 0.8rem;
+ }
+ }
+
+ // img:nth-child(2) {
+ // width:100%;
+ // top: -2.05rem;
+ // left: 1.07rem;
+ // }
+ }
+
+ .main-bottom,
+ .main-top {
+ height: auto;
+ display: flex;
+ // background-color: skyblue;
+
+ .border_left1 {
+ width: 3.84rem;
+ margin-right: 0.14rem;
+ border: 0 !important;
+ background-image: url("~@/assets/images/border_left1.png");
+ background-size: 107.5% 104%;
+ background-position: -0.14rem -0.13rem;
+ background-repeat: no-repeat;
+ }
+
+ .border_left2 {
+ width: 3.02rem;
+ margin-right: 0.16rem;
+ border: 0 !important;
+ background-image: url("~@/assets/images/border_left2.png");
+ background-size: 109.3% 104%;
+ background-position: -0.14rem -0.13rem;
+ background-repeat: no-repeat;
+ }
+
+ .border_middle {
+ width: 6.09rem;
+ margin-right: 0.16rem;
+ border: 0 !important;
+ background-image: url("~@/assets/images/border_middle.png");
+ background-size: 102.7% 104%;
+ background-position: -0.14rem -0.13rem;
+ background-repeat: no-repeat;
+ }
+
+ .border_right1 {
+ width: 3.75rem;
+ margin-right: 0.15rem;
+ border: 0 !important;
+ background-image: url("~@/assets/images/border_right1.png");
+ background-size: 107.5% 104%;
+ background-position: -0.14rem -0.13rem;
+ background-repeat: no-repeat;
+ }
+
+ .border_right2 {
+ width: 6.09rem;
+ border: 0 !important;
+ background-image: url("~@/assets/images/border_right2.png");
+ background-size: 104.4% 104%;
+ background-position: -0.14rem -0.13rem;
+ background-repeat: no-repeat;
+ }
+
+ .echarts-box {
+ height: auto;
+ border: 2px solid #3a45de;
+
+ .echarts-title {
+ font-size: 0.18rem;
+ height: 0.75rem;
+ padding: 0.31rem 0 0.26rem;
+ margin: 0 0.23rem;
+ font-weight: 700;
+ color: #00afb9;
+ text-align: center;
+ border-bottom: 2px solid #3c37bf;
+ }
+ }
+
+ .echarts-box:nth-child(4) {
+ position: relative;
+
+ .pie-label-left {
+ position: absolute;
+ bottom: 0.1rem;
+ left: 0.7rem;
+ color: #fff;
+ font-size: 0.2rem;
+ font-weight: 300;
+ }
+
+ .pie-label-right {
+ position: absolute;
+ bottom: 0.1rem;
+ right: 0.7rem;
+ color: #fff;
+ font-size: 0.2rem;
+ font-weight: 300;
+ }
+ }
+
+ .box-container {
+ width: 100%;
+ height: 2.6rem;
+ // background-color: rgb(196, 231, 178);
+ }
+
+ .bgi {
+ background-image: url("~@/assets/bg1.png");
+ background-size: contain;
+ background-repeat: no-repeat;
+ background-position: center center;
+ }
+ }
+ }
+
+ .box1{
+ .echarts-box{
+ width: 100% !important;
+ }
+ .border_left1{
+ margin-right: 0 !important;
+ }
+ }
+
+}
+</style>
diff --git a/yiqi_screen/src/components/EquipmentRunStatus2.vue b/yiqi_screen/src/components/EquipmentRunStatus2.vue
new file mode 100644
index 0000000..b404971
--- /dev/null
+++ b/yiqi_screen/src/components/EquipmentRunStatus2.vue
@@ -0,0 +1,71 @@
+<template>
+ <div class="box-container" id="echarts10"></div>
+</template>
+
+<script>
+let timer = null;
+export default {
+ data() {
+ return {
+ option: {},
+ myChart: {},
+ currentIndex: -1,
+ lineData: [], // 娣诲姞鐢ㄤ簬瀛樺偍鏇茬嚎鍥炬暟鎹殑灞炴��
+ };
+ },
+ mounted() {
+ this.myChart = this.$echarts.init(document.getElementById("echarts10"));
+
+ // 鐢熸垚鍋囨暟鎹�
+ this.generateFakeData();
+
+ this.option = {
+ tooltip: {
+ trigger: 'axis'
+ },
+ xAxis: {
+ type: 'category',
+ data: this.lineData.map(item => item.time) // 浣跨敤鍋囨暟鎹腑鐨勬椂闂翠綔涓� x 杞�
+ },
+ yAxis: {
+ type: 'value'
+ },
+ series: [{
+ name: '鐘舵�佹暟鎹�',
+ type: 'line',
+ data: this.lineData.map(item => item.value), // 浣跨敤鍋囨暟鎹腑鐨勫�间綔涓� y 杞�
+ smooth: true // 骞虫粦鏇茬嚎
+ }]
+ };
+
+ this.myChart.setOption(this.option);
+ const that = this;
+ window.addEventListener("resize", () => {
+ that.myChart.resize();
+ });
+ },
+ methods: {
+ generateFakeData() {
+ // 鐢熸垚 10 涓亣鏁版嵁鐐�
+ const fakeData = [];
+ for (let i = 0; i < 10; i++) {
+ fakeData.push({
+ time: `鏃堕棿${i + 1}`,
+ value: Math.floor(Math.random() * 100) + 1 // 闅忔満鐢熸垚 1-100 鐨勫��
+ });
+ }
+ this.lineData = fakeData;
+ },
+ },
+};
+</script>
+
+<style>
+#echarts10 {
+ width: 3.84rem;
+}
+.box-container{
+ margin: 0 auto;
+ display: block;
+}
+</style>
diff --git a/yiqi_screen/src/components/EquipmentRunStatus3.vue b/yiqi_screen/src/components/EquipmentRunStatus3.vue
new file mode 100644
index 0000000..15ffb40
--- /dev/null
+++ b/yiqi_screen/src/components/EquipmentRunStatus3.vue
@@ -0,0 +1,67 @@
+<template>
+ <div class="box-container" id="echarts30"></div>
+</template>
+
+<script>
+let timer = null;
+export default {
+ data() {
+ return {
+ option: {},
+ myChart: {},
+ currentIndex: -1,
+ lineData: [], // 娣诲姞鐢ㄤ簬瀛樺偍鏇茬嚎鍥炬暟鎹殑灞炴��
+ };
+ },
+ mounted() {
+ this.myChart = this.$echarts.init(document.getElementById("echarts30"));
+
+ // 鐢熸垚鍋囨暟鎹�
+ this.generateFakeData();
+
+ this.option = {
+ tooltip: {
+ trigger: 'axis'
+ },
+ xAxis: {
+ type: 'category',
+ data: this.lineData.map(item => item.time) // 浣跨敤鍋囨暟鎹腑鐨勬暟鎹綔涓� x 杞�
+ },
+ yAxis: {
+ type: 'value'
+ },
+ series: [{
+ name: '鐘舵�佹暟鎹�',
+ type: 'line',
+ data: this.lineData.map(item => item.value), // 浣跨敤鍋囨暟鎹腑鐨勫�间綔涓� y 杞�
+ smooth: true // 骞虫粦鏇茬嚎
+ }]
+ };
+
+ this.myChart.setOption(this.option);
+ const that = this;
+ window.addEventListener("resize", () => {
+ that.myChart.resize();
+ });
+ },
+ methods: {
+ generateFakeData() {
+ // 鐢熸垚 10 涓亣鏁版嵁鐐�
+ const fakeData = [];
+ for (let i = 0; i < 10; i++) {
+ fakeData.push({
+ time: `鏁版嵁${i + 1}`,
+ value: Math.floor(Math.random() * 100) + 1 // 闅忔満鐢熸垚 1-100 鐨勫��
+ });
+ }
+ this.lineData = fakeData;
+ },
+ },
+};
+</script>
+
+<style>
+#echarts30 {
+ width: 3.84rem;
+}
+</style>
diff --git a/yiqi_screen/src/components/EquipmentRunStatus4.vue b/yiqi_screen/src/components/EquipmentRunStatus4.vue
new file mode 100644
index 0000000..74c2085
--- /dev/null
+++ b/yiqi_screen/src/components/EquipmentRunStatus4.vue
@@ -0,0 +1,71 @@
+<template>
+ <div class="box-container" id="echarts40"></div>
+</template>
+
+<script>
+let timer = null;
+export default {
+ data() {
+ return {
+ option: {},
+ myChart: {},
+ currentIndex: -1,
+ lineData: [], // 娣诲姞鐢ㄤ簬瀛樺偍楗煎浘鏁版嵁鐨勫睘鎬�
+ };
+ },
+ mounted() {
+ this.myChart = this.$echarts.init(document.getElementById("echarts40"));
+
+ // 鐢熸垚鍋囨暟鎹�
+ this.generateFakeData();
+
+ this.option = {
+ tooltip: {
+ trigger: 'item' // 淇敼涓� 'item' 浠ラ�傚簲楗煎浘
+ },
+ series: [{
+ name: '鐘舵�佹暟鎹�',
+ type: 'pie', // 淇敼涓� 'pie'
+ radius: '50%',
+ data: this.lineData.map(item => ({
+ name: item.time, // 楗煎浘涓殑姣忎竴椤瑰悕绉�
+ value: item.value // 瀵瑰簲鐨勬暟鍊�
+ })),
+ emphasis: {
+ itemStyle: {
+ shadowBlur: 10,
+ shadowOffsetX: 0,
+ shadowColor: 'rgba(0, 0, 0, 0.5)'
+ }
+ }
+ }]
+ };
+
+ this.myChart.setOption(this.option);
+ const that = this;
+ window.addEventListener("resize", () => {
+ that.myChart.resize();
+ });
+ },
+ methods: {
+ generateFakeData() {
+ // 鐢熸垚 4 涓亣鏁版嵁鐐�
+ const fakeData = [];
+ for (let i = 0; i < 4; i++) {
+ fakeData.push({
+ time: `鏁版嵁${i + 1}`,
+ value: Math.floor(Math.random() * 100) + 1 // 闅忔満鐢熸垚 1-100 鐨勫��
+ });
+ }
+ this.lineData = fakeData;
+},
+
+ },
+};
+</script>
+
+<style>
+#echarts40 {
+ width: 3.84rem;
+}
+</style>
diff --git a/yiqi_screen/src/components/EquipmentRunStatus5.vue b/yiqi_screen/src/components/EquipmentRunStatus5.vue
new file mode 100644
index 0000000..5839230
--- /dev/null
+++ b/yiqi_screen/src/components/EquipmentRunStatus5.vue
@@ -0,0 +1,67 @@
+<template>
+ <div class="box-container" id="echarts50"></div>
+</template>
+
+<script>
+let timer = null;
+export default {
+ data() {
+ return {
+ option: {},
+ myChart: {},
+ currentIndex: -1,
+ lineData: [], // 娣诲姞鐢ㄤ簬瀛樺偍鏇茬嚎鍥炬暟鎹殑灞炴��
+ };
+ },
+ mounted() {
+ this.myChart = this.$echarts.init(document.getElementById("echarts50"));
+
+ // 鐢熸垚鍋囨暟鎹�
+ this.generateFakeData();
+
+ this.option = {
+ tooltip: {
+ trigger: 'axis'
+ },
+ xAxis: {
+ type: 'category',
+ data: this.lineData.map(item => item.time) // 浣跨敤鍋囨暟鎹腑鐨勬暟鎹綔涓� x 杞�
+ },
+ yAxis: {
+ type: 'value'
+ },
+ series: [{
+ name: '鐘舵�佹暟鎹�',
+ type: 'bar',
+ data: this.lineData.map(item => item.value), // 浣跨敤鍋囨暟鎹腑鐨勫�间綔涓� y 杞�
+ smooth: true // 骞虫粦鏇茬嚎
+ }]
+ };
+
+ this.myChart.setOption(this.option);
+ const that = this;
+ window.addEventListener("resize", () => {
+ that.myChart.resize();
+ });
+ },
+ methods: {
+ generateFakeData() {
+ // 鐢熸垚 10 涓亣鏁版嵁鐐�
+ const fakeData = [];
+ for (let i = 0; i < 10; i++) {
+ fakeData.push({
+ time: `鏁版嵁${i + 1}`,
+ value: Math.floor(Math.random() * 100) + 1 // 闅忔満鐢熸垚 1-100 鐨勫��
+ });
+ }
+ this.lineData = fakeData;
+ },
+ },
+};
+</script>
+
+<style>
+#echarts50 {
+ width: 3.84rem;
+}
+</style>
diff --git a/yiqi_screen/src/components/ProductionCompletionTrend.vue b/yiqi_screen/src/components/ProductionCompletionTrend.vue
index 0410158..54bd1e1 100644
--- a/yiqi_screen/src/components/ProductionCompletionTrend.vue
+++ b/yiqi_screen/src/components/ProductionCompletionTrend.vue
@@ -1,12 +1,16 @@
<template>
<div>
- <div class="box-container" id="echarts5" style="width: 100%;height:230px"></div>
+ <div
+ class="box-container"
+ id="echarts5"
+ style="width: 100%; height: 230px"
+ ></div>
</div>
</template>
<script>
import * as echarts from "echarts";
-import {zhu} from './img/t.js'
+import { zhu } from "./img/t.js";
export default {
props: {
@@ -20,7 +24,6 @@
option: {},
myChart: {},
timechartes: null,
-
myChart2: null,
textureImg: null,
// img,
@@ -33,15 +36,30 @@
yData2 = [],
yData3 = [];
val.forEach((item) => {
- console.log('ceshi', item.completionNum);
+ console.log("ceshi", item.completionNum);
xData.push(item.month);
yData1.push({
- value: item.completionNum,
+ // value: item.completionNum,
+ value: 100,
symbolRepeat: false,
}); //瀹為檯
// yData1.push(item.completionNum); //瀹為檯
- yData2.push(item.planCompletionRate); //planCompletionRate
- yData3.push(item.planCompletionNum); //璁″垝
+ var num = 0; //宸插畬鎴愭暟 / 璁″垝瀹屾垚鏁�
+ if (item.completionNum > 0) {
+ if (item.planCompletionNum > item.completionNum) {
+ // 5/10
+ num = item.completionNum / item.planCompletionNum;
+ } else if (item.planCompletionNum <= 0) {
+ // 10/0
+ num = 100;
+ } else if (item.completionNum >= item.planCompletionNum) {
+ // 10/5
+ num = 100;
+ }
+ }
+ yData2.push(num.toFixed(2)); //planCompletionRate
+ // yData2.push(item.planCompletionRate); //planCompletionRate
+ // yData3.push(item.planCompletionNum); //璁″垝
});
this.$set(this.option.xAxis, "data", xData);
this.$set(this.option.series[0], "data", yData1);
@@ -58,7 +76,7 @@
trigger: "axis",
formatter:
"{b0}鏈�<br />" +
- '<a style="display:inline-block;width:10px;height:10px;background:linear-gradient(to bottom,#13e5f2,#01afba);border-radius:50%"></a> {a0}: {c0}<br />' +
+ // '<a style="display:inline-block;width:10px;height:10px;background:linear-gradient(to bottom,#13e5f2,#01afba);border-radius:50%"></a> {a0}: {c0}<br />' +
// '<a style="display:inline-block;width:10px;height:10px;background:linear-gradient(to bottom,#ffc107,#fd7e14);border-radius:50%"></a> {a2}: {c2}<br />' +
'<a style="display:inline-block;width:10px;height:10px;background:linear-gradient(to bottom,#fff,#eee);border-radius:50%"></a> {a1}: {c1}%<br />', // 娣诲姞鐢熶骇璁″垝鏁版彁绀�
backgroundColor: "rgba(0,0,0,0.7)",
@@ -77,7 +95,7 @@
type: "category",
axisLabel: {
color: "#326e92",
- interval: 0,
+ interval: 0,
fontSize: 13,
// formatter: '{value}鏈�'
},
@@ -87,7 +105,6 @@
axisLine: {
lineStyle: {
color: "#326e92",
-
},
},
},
@@ -105,7 +122,7 @@
show: true,
margin: 5,
color: "#326e92",
- // formatter: '{value}%'
+ formatter: "{value}%",
},
alignTicks: false,
nameTextStyle: {
@@ -148,9 +165,8 @@
name: "鐢熶骇瀹屾垚鏁�",
type: "pictorialBar",
// type: "bar",
- symbol: 'image://'+zhu,
- data: [],
-
+ symbol: "image://" + zhu,
+ data: [],
// yAxisIndex: 0,
// color: {
// type: "linear",
@@ -174,10 +190,11 @@
name: "鐢熶骇瀹屾垚鐜�",
type: "line",
data: [],
+ z: 5,
showSymbol: true,
yAxisIndex: 1,
smooth: true, // 浣挎姌绾垮浘骞虫粦
- color: "rgba(255,205,86,0.85)",
+ color: "#ff9600",
lineStyle: {
width: 1,
},
@@ -216,7 +233,6 @@
// window.addEventListener("resize", ()=> {
// this.myChart.resize();
// });
-
// this.init()
},
methods: {
@@ -270,8 +286,8 @@
var chartDom = document.getElementById("main");
var myChart = echarts.init(chartDom);
var option;
- var rocket =''
-
+ var rocket = "";
+
option = {
legend: {
data: ["tu1", "barbg1"],
@@ -286,7 +302,7 @@
{
type: "pictorialBar",
name: "tu1",
- symbol: 'image://'+zhu,
+ symbol: "image://" + zhu,
data: [
{
value: 60,
@@ -310,7 +326,6 @@
};
myChart.setOption(option);
},
-
},
};
</script>
diff --git a/yiqi_screen/src/components/ProductionStatistics copy 2.vue b/yiqi_screen/src/components/ProductionStatistics copy 2.vue
new file mode 100644
index 0000000..b8c860f
--- /dev/null
+++ b/yiqi_screen/src/components/ProductionStatistics copy 2.vue
@@ -0,0 +1,458 @@
+<template>
+ <!-- 鏈彮/鏈湀浜ч噺缁熻 -->
+ <div class="box-container box4" id="echarts4"></div>
+</template>
+
+<script>
+let timer = null;
+import * as echarts from "echarts";
+export default {
+ props: {
+ produceStatisData: {
+ type: Object,
+ default: () => {},
+ },
+ },
+ data() {
+ return {
+ option: {},
+ myChart: {},
+ currentIndex: -1,
+ data1: [],
+ data2: [{ actualData: 2782, planData: 11128 }],
+ };
+ },
+ // watch: {
+ // produceStatisData(val) {
+ // // 娴嬭瘯鐢細
+ // val.currentShiftProduceNum = 280;
+ // val.currentShiftPlanNum = 300;
+ // // 褰撳墠鐝粍瀹為檯鐢熶骇鏁伴噺 currentShiftProduceNum
+ // // 褰撳墠鐝粍璁″垝鐢熶骇鏁伴噺 currentShiftPlanNum
+ // var num1 = val.currentShiftProduceNum; //瀹為檯鐢熶骇鏁伴噺
+ // var num2 = val.currentShiftPlanNum - val.currentShiftProduceNum; //璁″垝鐢熶骇鏁伴噺
+ // if (val.currentShiftPlanNum == 0) {
+ // //鍒嗘瘝涓�0 鏄剧ず0%
+ // num1 = 0;
+ // num2 = 10;
+ // }
+ // this.$set(this.option.series[0], "data", [
+ // // { value: 1 }, //瀹為檯鐢熶骇鏁伴噺 1/ (9+1) = 10%
+ // // { value: 9 },
+ // {
+ // value: num1,
+ // }, //瀹為檯鐢熶骇鏁伴噺
+ // {
+ // value: num2,
+ // },
+ // ]);
+ // var num3 = val.currentMonthProduceNum;
+ // var num4 = val.currentMonthPlanNum - val.currentMonthProduceNum;
+ // if (val.currentMonthPlanNum == 0) {
+ // //鍒嗘瘝涓�0 鏄剧ず0%
+ // num3 = 0;
+ // num4 = 10;
+ // }
+ // this.$set(this.option.series[1], "data", [
+ // { value: num3 },
+ // { value: num4 },
+ // ]);
+
+ // this.myChart.setOption(this.option);
+ // this.hignLightPie();
+ // },
+ // },
+ mounted() {
+ this.myChart = this.$echarts.init(document.getElementById("echarts4"));
+ var value = 60;
+ var value2 = 15;
+ let data1 = [
+ {
+ value: value,
+ name: "",
+ itemStyle: {
+ normal: {
+ color: "#62fbf8",
+ },
+ },
+ },
+ {
+ value: 100 - value,
+ name: "",
+ label: {
+ normal: {
+ show: false,
+ },
+ },
+ itemStyle: {
+ normal: {
+ color: "rgba(0,0,0,0)",
+ },
+ },
+ },
+ ];
+
+ let data2 = [
+ {
+ value: value2,
+ name: "",
+ itemStyle: {
+ normal: {
+ color: "rgb(105,206,195)",
+ },
+ },
+ },
+ {
+ value: 100 - value2,
+ name: "",
+ label: {
+ normal: {
+ show: false,
+ },
+ },
+ itemStyle: {
+ normal: {
+ color: "rgba(0,0,0,0)",
+ },
+ },
+ },
+ ];
+
+ this.option = {
+ color: ["#00f6fe", "rgba(5, 19, 96, 0.5)"],
+ // 鎻掑叆鑳屾櫙鍥�
+ // graphic: [
+ // {
+ // type: "image",
+ // id: "background1",
+ // left: "13px", // 鏍规嵁鐜舰鍥剧殑浣嶇疆璋冩暣
+ // top: "61px", // 鏍规嵁鐜舰鍥剧殑浣嶇疆璋冩暣
+ // z: -10,
+ // bounding: "raw",
+ // origin: [0, 0],
+ // style: {
+ // image: require(`@/assets/images/quan.png`), // 绗竴涓幆褰㈠浘鐨勮儗鏅浘鐗囪矾寰�
+ // width: 100,
+ // height: 100,
+ // },
+ // },
+ // {
+ // type: "image",
+ // id: "background2",
+ // left: "131px", // 鏍规嵁鐜舰鍥剧殑浣嶇疆璋冩暣
+ // top: "61px", // 鏍规嵁鐜舰鍥剧殑浣嶇疆璋冩暣
+ // z: -10,
+ // bounding: "raw",
+ // origin: [0, 0],
+ // style: {
+ // image: require(`@/assets/images/quan.png`), // 绗竴涓幆褰㈠浘鐨勮儗鏅浘鐗囪矾寰�
+ // width: 100,
+ // height: 100,
+ // },
+ // },
+ // ],
+ series: [
+ // 宸︿晶
+ {
+ name: "宸�-鏁版嵁",
+ type: "pie",
+ // radius: ['65%', '75%'],
+ radius: ["29%", "36%"], //鐜彉缁�
+ center: ["25%", "49%"],
+ silent: true,
+ // clockwise: false,
+ startAngle: 90,
+ z: 1,
+ zlevel: 0,
+ label: {
+ normal: {
+ position: "center",
+ },
+ },
+ data: data1,
+ },
+ {
+ name: "宸�-涓棿娓愬彉",
+ type: "pie",
+ startAngle: 90,
+ z: 20,
+ zlevel: 20,
+ radius: "28%",
+ hoverAnimation: false,
+ center: ["25%", "49%"],
+
+ // zlevel: 2,
+ itemStyle: {
+ normal: {
+ labelLine: {
+ show: false,
+ },
+ color: new echarts.graphic.RadialGradient(0.5, 0.5, 1, [
+ {
+ offset: 1,
+ color: "rgba(55,70,130, 1)",
+ },
+ {
+ offset: 0,
+ color: "rgba(55,70,130, 0)",
+ },
+ ]),
+ shadowBlur: 10,
+ // shadowColor: 'rgba(55,70,130, 1)'
+ },
+ },
+ data: [
+ {
+ value: 100,
+ },
+ ],
+ },
+ {
+ name: "宸�-鍒诲害闂撮殧",
+ z: 2,
+ // zlevel: 1,
+ type: "gauge",
+ radius: "57%",
+ center: ["25%", "49%"],
+ startAngle: 20,
+ endAngle: -360,
+ splitNumber: 10,
+ hoverAnimation: true,
+ axisTick: {
+ show: true,
+ splitNumber: 1,
+ length: 14, //鍒诲害闀垮害
+ // Distance: 40, //鍒诲害闂撮殧璺濈
+ lineStyle: {
+ width: 5,
+ color: new echarts.graphic.LinearGradient(
+ 0,
+ 0,
+ 0,
+ 1,
+ [
+ {
+ offset: 0,
+ color: "rgba(8, 52, 106, 0.039)", // 0% 澶勭殑棰滆壊
+ },
+ {
+ offset: 1,
+ color: "rgba(8, 52, 106, 0.239)", // 100% 澶勭殑棰滆壊
+ },
+ ],
+ false
+ ),
+ },
+ },
+ splitLine: {
+ show: false,
+ },
+ axisLabel: {
+ show: false,
+ },
+ pointer: {
+ show: false,
+ },
+ axisLine: {
+ lineStyle: {
+ opacity: 0,
+ },
+ },
+ detail: {
+ show: false,
+ },
+ data: [100],
+ },
+
+ // 鍙充晶
+ {
+ name: "鍙�-鏁版嵁",
+ type: "pie",
+ // radius: ['65%', '75%'],
+ radius: ["29%", "36%"], //鐜彉缁�
+ center: ["74%", "49%"],
+ silent: true,
+ // clockwise: false,
+ startAngle: 90,
+ z: 1,
+ zlevel: 0,
+ label: {
+ normal: {
+ position: "center",
+ },
+ },
+ data: data2,
+ },
+ {
+ name: "鍙�-涓棿娓愬彉",
+ type: "pie",
+ startAngle: 90,
+ radius: "28%",
+ hoverAnimation: false,
+ center: ["74%", "49%"],
+ itemStyle: {
+ normal: {
+ labelLine: {
+ show: false,
+ },
+ color: new echarts.graphic.RadialGradient(0.5, 0.5, 1, [
+ {
+ offset: 1,
+ color: "rgba(55,70,130, 1)",
+ },
+ {
+ offset: 0,
+ color: "rgba(55,70,130, 0)",
+ },
+ ]),
+ shadowBlur: 10,
+ // shadowColor: 'rgba(55,70,130, 1)'
+ },
+ },
+ data: [
+ {
+ value: 100,
+ },
+ ],
+ },
+ {
+ name: "鍙�-鍒诲害闂撮殧",
+ z: 2,
+ type: "gauge",
+ radius: "45%",
+ center: ["74%", "49%"],
+ startAngle: 90,
+ endAngle: -360,
+ splitNumber: 10,
+ hoverAnimation: true,
+ axisTick: {
+ show: true,
+ splitNumber: 1,
+ length: 20,
+ lineStyle: {
+ width: 10,
+ color: "#1183a7",
+ shadowColor: "rgb(4,31,62, 0.5)",
+ },
+ },
+ splitLine: {
+ show: false,
+ },
+ axisLabel: {
+ show: false,
+ },
+ pointer: {
+ show: false,
+ },
+ axisLine: {
+ lineStyle: {
+ opacity: 0,
+ },
+ },
+ detail: {
+ show: false,
+ },
+ data: [100],
+ },
+ ],
+ };
+ this.myChart.setOption(this.option);
+ const that = this;
+ window.addEventListener("resize", () => {
+ that.myChart.resize();
+ });
+ // this.getData();
+ this.defineEvent();
+ // this.selectPie();
+ this.hignLightPie();
+ // timer = setInterval(this.selectPie, 1500);
+ },
+ methods: {
+ // getData() {
+ // this.data1 = [{ actualData: 144, planData: 288 }];
+ // this.$set(this.option.series[0], "data", [
+ // { value: this.data1[0].actualData },
+ // { value: this.data1[0].planData - this.data1[0].actualData },
+ // ]);
+ // this.$set(this.option.series[1], "data", [
+ // { value: this.data2[0].actualData },
+ // { value: this.data2[0].planData - this.data2[0].actualData },
+ // ]);
+ // console.log(this.option.series[0].data);
+ // this.myChart.setOption(this.option);
+ // },
+ selectPie() {
+ let dataLen = this.option.series[0].data.length;
+ this.currentIndex = (this.currentIndex + 1) % dataLen;
+ this.hignLightPie();
+ },
+ // 杞挱鐐逛寒楗煎浘
+ hignLightPie() {
+ const dataPie = this.option.series[0].data;
+ // 鐔勭伃鎵�鏈夋墖褰㈠尯鍩�
+ for (var index in dataPie) {
+ this.myChart.dispatchAction({
+ type: "downplay",
+ seriesIndex: 0,
+ dataIndex: index,
+ });
+
+ this.myChart.dispatchAction({
+ type: "downplay",
+ seriesIndex: 1,
+ dataIndex: index,
+ });
+ }
+
+ // 鐐逛寒褰撳墠鎵囧舰鍖哄煙
+ this.myChart.dispatchAction({
+ type: "highlight",
+ seriesIndex: 0,
+ dataIndex: 0,
+ });
+
+ this.myChart.dispatchAction({
+ type: "highlight",
+ seriesIndex: 1,
+ dataIndex: 0,
+ });
+ },
+
+ // 榧犳爣瑙︽懜杞挱鎮仠浜嬩欢
+ defineEvent() {
+ // 榧犳爣绉诲嚭杞挱缁х画
+ this.myChart.on("mouseout", () => {
+ if (timer) clearInterval(timer);
+ timer = setInterval(this.selectPie, 1500);
+ });
+
+ // 榧犳爣杩涘叆杞挱鎮仠
+ this.myChart.on("mouseover", (params) => {
+ clearInterval(timer);
+ this.currentIndex = params.dataIndex;
+ this.hignLightPie();
+ });
+
+ // 榧犳爣绉诲叆legend杞挱鎮仠
+ this.myChart.getZr().on("mouseover", (event) => {
+ const legendDataIndex = event.topTarget.parent.__legendDataIndex; // 姣忎釜legend鐨刬ndex
+ clearInterval(timer);
+ this.currentIndex = legendDataIndex;
+ this.hignLightPie();
+ });
+
+ // 榧犳爣绉诲嚭legend杞挱缁х画
+ this.myChart.getZr().on("mouseout", () => {
+ if (timer) clearInterval(timer);
+ timer = setInterval(this.selectPie, 1500);
+ });
+ },
+ },
+};
+</script>
+
+<style>
+#echarts4 {
+ transform: scaleY(2);
+}
+</style>
diff --git a/yiqi_screen/src/components/ProductionStatistics copy.vue b/yiqi_screen/src/components/ProductionStatistics copy.vue
new file mode 100644
index 0000000..a1d1a2a
--- /dev/null
+++ b/yiqi_screen/src/components/ProductionStatistics copy.vue
@@ -0,0 +1,277 @@
+<template>
+ <!-- 鏈彮/鏈湀浜ч噺缁熻 -->
+ <div class="box-container box4" id="echarts4"></div>
+</template>
+
+<script>
+let timer = null;
+export default {
+ props: {
+ produceStatisData: {
+ type: Object,
+ default: () => {},
+ },
+ },
+ data() {
+ return {
+ option: {},
+ myChart: {},
+ currentIndex: -1,
+ data1: [],
+ data2: [{ actualData: 2782, planData: 11128 }],
+ };
+ },
+ watch: {
+ produceStatisData(val) {
+ // 娴嬭瘯鐢細
+ val.currentShiftProduceNum = 280;
+ val.currentShiftPlanNum = 300;
+ // 褰撳墠鐝粍瀹為檯鐢熶骇鏁伴噺 currentShiftProduceNum
+ // 褰撳墠鐝粍璁″垝鐢熶骇鏁伴噺 currentShiftPlanNum
+ var num1 = val.currentShiftProduceNum; //瀹為檯鐢熶骇鏁伴噺
+ var num2 = val.currentShiftPlanNum - val.currentShiftProduceNum; //璁″垝鐢熶骇鏁伴噺
+ if (val.currentShiftPlanNum == 0) {
+ //鍒嗘瘝涓�0 鏄剧ず0%
+ num1 = 0;
+ num2 = 10;
+ }
+ this.$set(this.option.series[0], "data", [
+ // { value: 1 }, //瀹為檯鐢熶骇鏁伴噺 1/ (9+1) = 10%
+ // { value: 9 },
+ {
+ value: num1,
+ }, //瀹為檯鐢熶骇鏁伴噺
+ {
+ value: num2,
+ },
+ ]);
+ var num3 = val.currentMonthProduceNum;
+ var num4 = val.currentMonthPlanNum - val.currentMonthProduceNum;
+ if (val.currentMonthPlanNum == 0) {
+ //鍒嗘瘝涓�0 鏄剧ず0%
+ num3 = 0;
+ num4 = 10;
+ }
+ this.$set(this.option.series[1], "data", [
+ { value: num3 },
+ { value: num4 },
+ ]);
+
+ this.myChart.setOption(this.option);
+ this.hignLightPie();
+ },
+ },
+ mounted() {
+ this.myChart = this.$echarts.init(document.getElementById("echarts4"));
+ this.option = {
+ color: ["#00f6fe", "transparent"],
+ // 鎻掑叆鑳屾櫙鍥�
+ // graphic: [
+ // {
+ // type: "image",
+ // id: "background1",
+ // left: "13px", // 鏍规嵁鐜舰鍥剧殑浣嶇疆璋冩暣
+ // top: "61px", // 鏍规嵁鐜舰鍥剧殑浣嶇疆璋冩暣
+ // z: -10,
+ // bounding: "raw",
+ // origin: [0, 0],
+ // style: {
+ // image: require(`@/assets/images/quan.png`), // 绗竴涓幆褰㈠浘鐨勮儗鏅浘鐗囪矾寰�
+ // width: 100,
+ // height: 100,
+ // },
+ // },
+ // {
+ // type: "image",
+ // id: "background2",
+ // left: "131px", // 鏍规嵁鐜舰鍥剧殑浣嶇疆璋冩暣
+ // top: "61px", // 鏍规嵁鐜舰鍥剧殑浣嶇疆璋冩暣
+ // z: -10,
+ // bounding: "raw",
+ // origin: [0, 0],
+ // style: {
+ // image: require(`@/assets/images/quan.png`), // 绗竴涓幆褰㈠浘鐨勮儗鏅浘鐗囪矾寰�
+ // width: 100,
+ // height: 100,
+ // },
+ // },
+ // ],
+ series: [
+ {
+ name: "Access From",
+ type: "pie",
+ // padAngle: 5, //鐜笌鐜箣闂寸殑闂撮殭
+ radius: ["29%", "36%"], //鐜彉缁�
+ center: ["25%", "49%"],
+ // avoidLabelOverlap: false,
+ label: {
+ show: false,
+ position: "center",
+ formatter: function (params) {
+ return params.percent < 1
+ ? params.percent + "%"
+ : Math.floor(params.percent) + "%"; // 鍥涜垗浜斿叆鍒版暣鏁�
+ },
+ color: "#fff",
+ fontSize: 12,
+ },
+ emphasis: {
+ //楗煎浘涓棿鐨勫瓧浣撳ぇ灏�
+ scale: false,
+ label: {
+ show: true,
+ fontSize: 22,
+ color: "#19d8d0",
+ fontWeight: "normal",
+ },
+ },
+ labelLine: {
+ show: false,
+ },
+ itemStyle: {
+ borderRadius: 3,
+ borderColor: "transparent",
+ borderWidth: 10,
+ },
+ data: [],
+ },
+ {
+ name: "Access From",
+ type: "pie",
+ // padAngle: 5, //鐜笌鐜箣闂寸殑闂撮殭
+ // radius: ["25%", "40%"],
+ radius: ["29%", "36%"], //鐜彉缁�
+ center: ["74%", "49%"],
+ // avoidLabelOverlap: false,
+ label: {
+ show: false,
+ position: "center",
+ formatter: function (params) {
+ return params.percent < 1
+ ? params.percent + "%"
+ : Math.floor(params.percent) + "%"; // 鍥涜垗浜斿叆鍒版暣鏁�
+ },
+ color: "#fff",
+ fontSize: 12,
+ },
+ itemStyle: {
+ borderRadius: 3,
+ borderColor: "transparent",
+ borderWidth: 10,
+ },
+ emphasis: {
+ scale: false,
+ label: {
+ show: true,
+ fontSize: 22,
+ color: "#19d8d0",
+ fontWeight: "normal",
+ },
+ },
+ labelLine: {
+ show: false,
+ },
+ data: [],
+ },
+ ],
+ };
+ this.myChart.setOption(this.option);
+ const that = this;
+ window.addEventListener("resize", () => {
+ that.myChart.resize();
+ });
+ // this.getData();
+ this.defineEvent();
+ // this.selectPie();
+ this.hignLightPie();
+ // timer = setInterval(this.selectPie, 1500);
+ },
+ methods: {
+ // getData() {
+ // this.data1 = [{ actualData: 144, planData: 288 }];
+ // this.$set(this.option.series[0], "data", [
+ // { value: this.data1[0].actualData },
+ // { value: this.data1[0].planData - this.data1[0].actualData },
+ // ]);
+ // this.$set(this.option.series[1], "data", [
+ // { value: this.data2[0].actualData },
+ // { value: this.data2[0].planData - this.data2[0].actualData },
+ // ]);
+ // console.log(this.option.series[0].data);
+ // this.myChart.setOption(this.option);
+ // },
+ selectPie() {
+ let dataLen = this.option.series[0].data.length;
+ this.currentIndex = (this.currentIndex + 1) % dataLen;
+ this.hignLightPie();
+ },
+ // 杞挱鐐逛寒楗煎浘
+ hignLightPie() {
+ const dataPie = this.option.series[0].data;
+ // 鐔勭伃鎵�鏈夋墖褰㈠尯鍩�
+ for (var index in dataPie) {
+ this.myChart.dispatchAction({
+ type: "downplay",
+ seriesIndex: 0,
+ dataIndex: index,
+ });
+
+ this.myChart.dispatchAction({
+ type: "downplay",
+ seriesIndex: 1,
+ dataIndex: index,
+ });
+ }
+
+ // 鐐逛寒褰撳墠鎵囧舰鍖哄煙
+ this.myChart.dispatchAction({
+ type: "highlight",
+ seriesIndex: 0,
+ dataIndex: 0,
+ });
+
+ this.myChart.dispatchAction({
+ type: "highlight",
+ seriesIndex: 1,
+ dataIndex: 0,
+ });
+ },
+
+ // 榧犳爣瑙︽懜杞挱鎮仠浜嬩欢
+ defineEvent() {
+ // 榧犳爣绉诲嚭杞挱缁х画
+ this.myChart.on("mouseout", () => {
+ if (timer) clearInterval(timer);
+ timer = setInterval(this.selectPie, 1500);
+ });
+
+ // 榧犳爣杩涘叆杞挱鎮仠
+ this.myChart.on("mouseover", (params) => {
+ clearInterval(timer);
+ this.currentIndex = params.dataIndex;
+ this.hignLightPie();
+ });
+
+ // 榧犳爣绉诲叆legend杞挱鎮仠
+ this.myChart.getZr().on("mouseover", (event) => {
+ const legendDataIndex = event.topTarget.parent.__legendDataIndex; // 姣忎釜legend鐨刬ndex
+ clearInterval(timer);
+ this.currentIndex = legendDataIndex;
+ this.hignLightPie();
+ });
+
+ // 榧犳爣绉诲嚭legend杞挱缁х画
+ this.myChart.getZr().on("mouseout", () => {
+ if (timer) clearInterval(timer);
+ timer = setInterval(this.selectPie, 1500);
+ });
+ },
+ },
+};
+</script>
+
+<style>
+#echarts4 {
+ transform: scaleY(2);
+}
+</style>
diff --git a/yiqi_screen/src/components/ProductionStatistics copy1113.vue b/yiqi_screen/src/components/ProductionStatistics copy1113.vue
new file mode 100644
index 0000000..1c37942
--- /dev/null
+++ b/yiqi_screen/src/components/ProductionStatistics copy1113.vue
@@ -0,0 +1,325 @@
+<template>
+ <!-- 鏈彮/鏈湀浜ч噺缁熻 -->
+ <div class="box-container box4" id="echarts4"></div>
+</template>
+
+<script>
+let timer = null;
+import * as echarts from "echarts";
+export default {
+ props: {
+ produceStatisData: {
+ type: Object,
+ default: () => {},
+ },
+ },
+ data() {
+ return {
+ option: {},
+ myChart: {},
+ currentIndex: -1,
+ data1: [],
+ data2: [{ actualData: 2782, planData: 11128 }],
+ };
+ },
+ // watch: {
+ // produceStatisData(val) {
+ // // 娴嬭瘯鐢細
+ // val.currentShiftProduceNum = 280;
+ // val.currentShiftPlanNum = 300;
+ // // 褰撳墠鐝粍瀹為檯鐢熶骇鏁伴噺 currentShiftProduceNum
+ // // 褰撳墠鐝粍璁″垝鐢熶骇鏁伴噺 currentShiftPlanNum
+ // var num1 = val.currentShiftProduceNum; //瀹為檯鐢熶骇鏁伴噺
+ // var num2 = val.currentShiftPlanNum - val.currentShiftProduceNum; //璁″垝鐢熶骇鏁伴噺
+ // if (val.currentShiftPlanNum == 0) {
+ // //鍒嗘瘝涓�0 鏄剧ず0%
+ // num1 = 0;
+ // num2 = 10;
+ // }
+ // this.$set(this.option.series[0], "data", [
+ // // { value: 1 }, //瀹為檯鐢熶骇鏁伴噺 1/ (9+1) = 10%
+ // // { value: 9 },
+ // {
+ // value: num1,
+ // }, //瀹為檯鐢熶骇鏁伴噺
+ // {
+ // value: num2,
+ // },
+ // ]);
+ // var num3 = val.currentMonthProduceNum;
+ // var num4 = val.currentMonthPlanNum - val.currentMonthProduceNum;
+ // if (val.currentMonthPlanNum == 0) {
+ // //鍒嗘瘝涓�0 鏄剧ず0%
+ // num3 = 0;
+ // num4 = 10;
+ // }
+ // this.$set(this.option.series[1], "data", [
+ // { value: num3 },
+ // { value: num4 },
+ // ]);
+
+ // this.myChart.setOption(this.option);
+ // this.hignLightPie();
+ // },
+ // },
+ mounted() {
+ this.myChart = this.$echarts.init(document.getElementById("echarts4"));
+ var value = 60;
+ var value2 = 15;
+ let data1 = [
+ {
+ value: value,
+ name: "",
+ itemStyle: {
+ normal: {
+ color: "#62fbf8",
+ },
+ },
+ },
+ {
+ value: 100 - value,
+ name: "",
+ label: {
+ normal: {
+ show: false,
+ },
+ },
+ itemStyle: {
+ normal: {
+ color: "rgba(0,0,0,0)",
+ },
+ },
+ },
+ ];
+
+ let data2 = [
+ {
+ value: value2,
+ name: "",
+ itemStyle: {
+ normal: {
+ color: "rgb(105,206,195)",
+ },
+ },
+ },
+ {
+ value: 100 - value2,
+ name: "",
+ label: {
+ normal: {
+ show: false,
+ },
+ },
+ itemStyle: {
+ normal: {
+ color: "rgba(0,0,0,0)",
+ },
+ },
+ },
+ ];
+
+ this.option = {
+ color: ["#00f6fe", "transparent"],
+ series: [
+ // 宸︿晶
+ {
+ name: "宸�-涓棿娓愬彉",
+ type: "pie",
+ startAngle: 90,
+ radius: "38%",
+ hoverAnimation: false,
+ center: ["25%", "49%"],
+ itemStyle: {
+ normal: {
+ labelLine: {
+ show: false,
+ },
+
+ color: {
+ type: "radial",
+ x: 0.5,
+ y: 0.5,
+ r: 0.4,
+ colorStops: [
+ {
+ offset: 0,
+ color: "rgba(55,70,130, 0)", // 0% 澶勭殑棰滆壊
+ },
+ {
+ offset: 1,
+ color: "rgba(55,70,130, 1)", // 100% 澶勭殑棰滆壊
+ },
+ ],
+ },
+ // color:'red',
+ shadowBlur: 10,
+ // shadowColor: 'rgba(55,70,130, 1)'
+ },
+ },
+ data: [
+ {
+ value: 100,
+ },
+ ],
+ },
+ {
+ name: "宸�-鏁版嵁",
+ type: "pie",
+ // radius: ['65%', '75%'],
+ radius: ["29%", "36%"], //鐜彉缁�
+ center: ["25%", "49%"],
+ silent: true,
+ // clockwise: false,
+ startAngle: 90,
+ z: 1,
+ zlevel: 1,
+ label: {
+ normal: {
+ position: "center",
+ },
+ },
+ data: data1,
+ },
+
+ {
+ name: "宸�-鍒诲害闂撮殧",
+ z: 2,
+ zlevel: 1,
+ type: "gauge",
+ radius: "55%",
+ center: ["25%", "49%"],
+ startAngle: 90,
+ endAngle: -360,
+ splitNumber: 10,
+ hoverAnimation: true,
+ axisTick: {
+ show: true,
+ splitNumber: 1,
+ length: 15,
+ lineStyle: {
+ width: 5,
+ color: "rgba(55,70,130, 0.1)",
+ // shadowColor: "rgb(4,31,62, 0.5)",
+ },
+ },
+ splitLine: {
+ show: false,
+ },
+ axisLabel: {
+ show: false,
+ },
+ pointer: {
+ show: false,
+ },
+ axisLine: {
+ lineStyle: {
+ opacity: 0,
+ },
+ },
+ detail: {
+ show: false,
+ },
+ data: [10],
+ },
+ ],
+ };
+ this.myChart.setOption(this.option);
+ const that = this;
+ window.addEventListener("resize", () => {
+ that.myChart.resize();
+ });
+ // this.getData();
+ this.defineEvent();
+ // this.selectPie();
+ this.hignLightPie();
+ // timer = setInterval(this.selectPie, 1500);
+ },
+ methods: {
+ // getData() {
+ // this.data1 = [{ actualData: 144, planData: 288 }];
+ // this.$set(this.option.series[0], "data", [
+ // { value: this.data1[0].actualData },
+ // { value: this.data1[0].planData - this.data1[0].actualData },
+ // ]);
+ // this.$set(this.option.series[1], "data", [
+ // { value: this.data2[0].actualData },
+ // { value: this.data2[0].planData - this.data2[0].actualData },
+ // ]);
+ // console.log(this.option.series[0].data);
+ // this.myChart.setOption(this.option);
+ // },
+ selectPie() {
+ let dataLen = this.option.series[0].data.length;
+ this.currentIndex = (this.currentIndex + 1) % dataLen;
+ this.hignLightPie();
+ },
+ // 杞挱鐐逛寒楗煎浘
+ hignLightPie() {
+ const dataPie = this.option.series[0].data;
+ // 鐔勭伃鎵�鏈夋墖褰㈠尯鍩�
+ for (var index in dataPie) {
+ this.myChart.dispatchAction({
+ type: "downplay",
+ seriesIndex: 0,
+ dataIndex: index,
+ });
+
+ this.myChart.dispatchAction({
+ type: "downplay",
+ seriesIndex: 1,
+ dataIndex: index,
+ });
+ }
+
+ // 鐐逛寒褰撳墠鎵囧舰鍖哄煙
+ this.myChart.dispatchAction({
+ type: "highlight",
+ seriesIndex: 0,
+ dataIndex: 0,
+ });
+
+ this.myChart.dispatchAction({
+ type: "highlight",
+ seriesIndex: 1,
+ dataIndex: 0,
+ });
+ },
+
+ // 榧犳爣瑙︽懜杞挱鎮仠浜嬩欢
+ defineEvent() {
+ // 榧犳爣绉诲嚭杞挱缁х画
+ this.myChart.on("mouseout", () => {
+ if (timer) clearInterval(timer);
+ timer = setInterval(this.selectPie, 1500);
+ });
+
+ // 榧犳爣杩涘叆杞挱鎮仠
+ this.myChart.on("mouseover", (params) => {
+ clearInterval(timer);
+ this.currentIndex = params.dataIndex;
+ this.hignLightPie();
+ });
+
+ // 榧犳爣绉诲叆legend杞挱鎮仠
+ this.myChart.getZr().on("mouseover", (event) => {
+ const legendDataIndex = event.topTarget.parent.__legendDataIndex; // 姣忎釜legend鐨刬ndex
+ clearInterval(timer);
+ this.currentIndex = legendDataIndex;
+ this.hignLightPie();
+ });
+
+ // 榧犳爣绉诲嚭legend杞挱缁х画
+ this.myChart.getZr().on("mouseout", () => {
+ if (timer) clearInterval(timer);
+ timer = setInterval(this.selectPie, 1500);
+ });
+ },
+ },
+};
+</script>
+
+<style>
+#echarts4 {
+ /* transform: scaleY(2); */
+}
+</style>
diff --git a/yiqi_screen/src/components/ProductionStatistics.vue b/yiqi_screen/src/components/ProductionStatistics.vue
index dbf822c..a1c07ef 100644
--- a/yiqi_screen/src/components/ProductionStatistics.vue
+++ b/yiqi_screen/src/components/ProductionStatistics.vue
@@ -1,7 +1,6 @@
<template>
<!-- 鏈彮/鏈湀浜ч噺缁熻 -->
<div class="box-container box4" id="echarts4"></div>
-
</template>
<script>
@@ -25,8 +24,9 @@
watch: {
produceStatisData(val) {
// 娴嬭瘯鐢細
- val.currentShiftProduceNum = 300;
- val.currentShiftPlanNum = 300;
+ // val.currentShiftProduceNum = 280;
+ // val.currentShiftPlanNum = 300;
+
// 褰撳墠鐝粍瀹為檯鐢熶骇鏁伴噺 currentShiftProduceNum
// 褰撳墠鐝粍璁″垝鐢熶骇鏁伴噺 currentShiftPlanNum
var num1 = val.currentShiftProduceNum; //瀹為檯鐢熶骇鏁伴噺
@@ -36,15 +36,15 @@
num1 = 0;
num2 = 10;
}
-
-
-
this.$set(this.option.series[0], "data", [
// { value: 1 }, //瀹為檯鐢熶骇鏁伴噺 1/ (9+1) = 10%
// { value: 9 },
- { value: num1,
- }, //瀹為檯鐢熶骇鏁伴噺
- { value: num2 },
+ {
+ value: num1,
+ }, //瀹為檯鐢熶骇鏁伴噺
+ {
+ value: num2,
+ },
]);
var num3 = val.currentMonthProduceNum;
var num4 = val.currentMonthPlanNum - val.currentMonthProduceNum;
@@ -66,53 +66,52 @@
this.myChart = this.$echarts.init(document.getElementById("echarts4"));
this.option = {
color: ["#00f6fe", "transparent"],
- // 鎻掑叆鑳屾櫙鍥�
- graphic: [
- {
- type: "image",
- id: "background1",
- left: "11px", // 鏍规嵁鐜舰鍥剧殑浣嶇疆璋冩暣
- top: "59.5px", // 鏍规嵁鐜舰鍥剧殑浣嶇疆璋冩暣
- z: -10,
- bounding: "raw",
- origin: [0, 0],
- style: {
- image: require(`@/assets/images/quan.png`), // 绗竴涓幆褰㈠浘鐨勮儗鏅浘鐗囪矾寰�
- width: 100,
- height: 100,
- opacity: 1,
- },
- },
- {
- type: "image",
- id: "background2",
- left: "130px", // 鏍规嵁鐜舰鍥剧殑浣嶇疆璋冩暣
- top: "59.5px", // 鏍规嵁鐜舰鍥剧殑浣嶇疆璋冩暣
- z: -10,
- bounding: "raw",
- origin: [0, 0],
- style: {
- image: require(`@/assets/images/quan.png`), // 绗竴涓幆褰㈠浘鐨勮儗鏅浘鐗囪矾寰�
- width: 100,
- height: 100,
- opacity: 1,
- },
- },
- ],
+ // 鎻掑叆鑳屾櫙鍥�
+ // graphic: [
+ // {
+ // type: "image",
+ // id: "background1",
+ // left: "13px", // 鏍规嵁鐜舰鍥剧殑浣嶇疆璋冩暣
+ // top: "61px", // 鏍规嵁鐜舰鍥剧殑浣嶇疆璋冩暣
+ // z: -10,
+ // bounding: "raw",
+ // origin: [0, 0],
+ // style: {
+ // image: require(`@/assets/images/quan.png`), // 绗竴涓幆褰㈠浘鐨勮儗鏅浘鐗囪矾寰�
+ // width: 100,
+ // height: 100,
+ // },
+ // },
+ // {
+ // type: "image",
+ // id: "background2",
+ // left: "131px", // 鏍规嵁鐜舰鍥剧殑浣嶇疆璋冩暣
+ // top: "61px", // 鏍规嵁鐜舰鍥剧殑浣嶇疆璋冩暣
+ // z: -10,
+ // bounding: "raw",
+ // origin: [0, 0],
+ // style: {
+ // image: require(`@/assets/images/quan.png`), // 绗竴涓幆褰㈠浘鐨勮儗鏅浘鐗囪矾寰�
+ // width: 100,
+ // height: 100,
+ // },
+ // },
+ // ],
series: [
{
name: "Access From",
type: "pie",
// padAngle: 5, //鐜笌鐜箣闂寸殑闂撮殭
- radius: ["30%", "37%"], //鐜彉缁�
- center: ["26%", "47%"],
- silent: true,clockwise: true,
+ radius: ["29%", "36%"], //鐜彉缁�
+ center: ["25%", "49%"],
// avoidLabelOverlap: false,
label: {
show: false,
position: "center",
formatter: function (params) {
- return Math.floor(params.percent) + '%'; // 鍥涜垗浜斿叆鍒版暣鏁�
+ return params.percent < 1
+ ? params.percent + "%"
+ : Math.floor(params.percent) + "%"; // 鍥涜垗浜斿叆鍒版暣鏁�
},
color: "#fff",
fontSize: 12,
@@ -126,7 +125,6 @@
color: "#19d8d0",
fontWeight: "normal",
},
-
},
labelLine: {
show: false,
@@ -143,14 +141,16 @@
type: "pie",
// padAngle: 5, //鐜笌鐜箣闂寸殑闂撮殭
// radius: ["25%", "40%"],
- radius: ["30%", "37%"], //鐜彉缁�
- center: ["74%", "47%"],
+ radius: ["29%", "36%"], //鐜彉缁�
+ center: ["74%", "49%"],
// avoidLabelOverlap: false,
label: {
show: false,
position: "center",
formatter: function (params) {
- return Math.floor(params.percent) + '%'; // 鍥涜垗浜斿叆鍒版暣鏁�
+ return params.percent < 1
+ ? params.percent + "%"
+ : Math.floor(params.percent) + "%"; // 鍥涜垗浜斿叆鍒版暣鏁�
},
color: "#fff",
fontSize: 12,
@@ -274,35 +274,5 @@
<style>
#echarts4 {
transform: scaleY(2);
-}
-
-.box4::before{
- position: absolute;
- background-size: 100% 100%;
- background-repeat: no-repeat;
- content: "";
- width: 95px;
- height: 47px;
- z-index: -1;
- top: 86px;
- left: 13px;
- transform: scaleY(2);
- border: 1px solid #074d95;
- border-radius: 100%;
-}
-
-.box4::after{
- position: absolute;
- background-size: 100% 100%;
- background-repeat: no-repeat;
- content: "";
- width: 95px;
- height: 47px;
- z-index: -1;
- top: 86px;
- left: 132px;
- transform: scaleY(2);
- border: 1px solid #074d95;
- border-radius: 100%;
}
</style>
diff --git a/yiqi_screen/src/components/ProductionStatistics1.vue b/yiqi_screen/src/components/ProductionStatistics1.vue
new file mode 100644
index 0000000..f949900
--- /dev/null
+++ b/yiqi_screen/src/components/ProductionStatistics1.vue
@@ -0,0 +1,303 @@
+<template>
+ <!-- 鏈彮/鏈湀浜ч噺缁熻 -->
+ <div class="box-container box4" id="echarts4"></div>
+</template>
+
+<script>
+let timer = null;
+export default {
+ props: {
+ produceStatisData: {
+ type: Object,
+ default: () => {},
+ },
+ },
+ data() {
+ return {
+ option: {},
+ myChart: {},
+ currentIndex: -1,
+ data1: [],
+ data2: [{ actualData: 2782, planData: 11128 }],
+ };
+ },
+ watch: {
+ produceStatisData(val) {
+ // 娴嬭瘯鐢細
+ val.currentShiftProduceNum = 280;
+ val.currentShiftPlanNum = 300;
+ // 褰撳墠鐝粍瀹為檯鐢熶骇鏁伴噺 currentShiftProduceNum
+ // 褰撳墠鐝粍璁″垝鐢熶骇鏁伴噺 currentShiftPlanNum
+ var num1 = val.currentShiftProduceNum; //瀹為檯鐢熶骇鏁伴噺
+ var num2 = val.currentShiftPlanNum - val.currentShiftProduceNum; //璁″垝鐢熶骇鏁伴噺
+ if (val.currentShiftPlanNum == 0) {
+ //鍒嗘瘝涓�0 鏄剧ず0%
+ num1 = 0;
+ num2 = 10;
+ }
+ // this.$set(this.option.series[0], "data", [
+ // // { value: 1 }, //瀹為檯鐢熶骇鏁伴噺 1/ (9+1) = 10%
+ // // { value: 9 },
+ // {
+ // value: num1,
+ // }, //瀹為檯鐢熶骇鏁伴噺
+ // {
+ // value: num2,
+ // },
+ // ]);
+ var num3 = val.currentMonthProduceNum;
+ var num4 = val.currentMonthPlanNum - val.currentMonthProduceNum;
+ if (val.currentMonthPlanNum == 0) {
+ //鍒嗘瘝涓�0 鏄剧ず0%
+ num3 = 0;
+ num4 = 10;
+ }
+ // this.$set(this.option.series[1], "data", [
+ // { value: num3 },
+ // { value: num4 },
+ // ]);
+
+ let value1 = 90.56;
+ let data1 = [
+ {
+ value: value1,
+ name: "",
+ itemStyle: {
+ normal: {
+ color: {
+ // 瀹屾垚鐨勫渾鐜殑棰滆壊
+ colorStops: [
+ {
+ offset: 0,
+ color: "#0975af",
+ },
+ {
+ offset: 1,
+ color: "#00bdfe",
+ },
+ ],
+ },
+ },
+ },
+ },
+ {
+ value: 100 - value1,
+ name: "",
+ label: {
+ normal: {
+ show: false,
+ },
+ },
+ itemStyle: {
+ normal: {
+ color: "#163367",
+ },
+ },
+ },
+ ];
+ this.$set(this.option.series[0], "data", data1);
+
+ this.myChart.setOption(this.option);
+ this.hignLightPie();
+ },
+ },
+ mounted() {
+ this.myChart = this.$echarts.init(document.getElementById("echarts4"));
+ this.option = {
+ color: ["#00f6fe", "transparent"],
+ // 鎻掑叆鑳屾櫙鍥�
+ // graphic: [
+ // {
+ // type: "image",
+ // id: "background1",
+ // left: "13px", // 鏍规嵁鐜舰鍥剧殑浣嶇疆璋冩暣
+ // top: "61px", // 鏍规嵁鐜舰鍥剧殑浣嶇疆璋冩暣
+ // z: -10,
+ // bounding: "raw",
+ // origin: [0, 0],
+ // style: {
+ // image: require(`@/assets/images/quan.png`), // 绗竴涓幆褰㈠浘鐨勮儗鏅浘鐗囪矾寰�
+ // width: 100,
+ // height: 100,
+ // },
+ // },
+ // {
+ // type: "image",
+ // id: "background2",
+ // left: "131px", // 鏍规嵁鐜舰鍥剧殑浣嶇疆璋冩暣
+ // top: "61px", // 鏍规嵁鐜舰鍥剧殑浣嶇疆璋冩暣
+ // z: -10,
+ // bounding: "raw",
+ // origin: [0, 0],
+ // style: {
+ // image: require(`@/assets/images/quan.png`), // 绗竴涓幆褰㈠浘鐨勮儗鏅浘鐗囪矾寰�
+ // width: 100,
+ // height: 100,
+ // },
+ // },
+ // ],
+ series: [
+ {
+ name: "Access From",
+ type: "pie",
+ radius: ["58%", "48%"],
+ silent: true,
+ clockwise: true,
+ startAngle: 90,
+ endAngle: -360,
+ z: 0,
+ zlevel: 0,
+ label: {
+ normal: {
+ position: "center",
+ },
+ },
+
+ animation: false,
+ data: [],
+ },
+
+ {
+ name: "",
+ type: "gauge",
+ radius: "58%",
+ center: ["50%", "50%"],
+ startAngle: 90,
+ endAngle: -360,
+ splitNumber: 12,
+ hoverAnimation: true,
+ axisTick: {
+ show: false,
+ },
+ splitLine: {
+ length: 60,
+ distance: -10,
+ lineStyle: {
+ width: 25,
+ color: "#0a0d35",
+ },
+ },
+ axisLabel: {
+ show: false,
+ },
+ pointer: {
+ show: false,
+ },
+ axisLine: {
+ lineStyle: {
+ opacity: 0,
+ },
+ },
+ detail: {
+ show: false,
+ },
+ animation: false,
+ data: [
+ {
+ value: 0,
+ name: "",
+ },
+ ],
+ },
+ ],
+ };
+ this.myChart.setOption(this.option);
+ const that = this;
+ window.addEventListener("resize", () => {
+ that.myChart.resize();
+ });
+ // this.getData();
+ this.defineEvent();
+ // this.selectPie();
+ this.hignLightPie();
+ // timer = setInterval(this.selectPie, 1500);
+ },
+ methods: {
+ // getData() {
+ // this.data1 = [{ actualData: 144, planData: 288 }];
+ // this.$set(this.option.series[0], "data", [
+ // { value: this.data1[0].actualData },
+ // { value: this.data1[0].planData - this.data1[0].actualData },
+ // ]);
+ // this.$set(this.option.series[1], "data", [
+ // { value: this.data2[0].actualData },
+ // { value: this.data2[0].planData - this.data2[0].actualData },
+ // ]);
+ // console.log(this.option.series[0].data);
+ // this.myChart.setOption(this.option);
+ // },
+ selectPie() {
+ let dataLen = this.option.series[0].data.length;
+ this.currentIndex = (this.currentIndex + 1) % dataLen;
+ this.hignLightPie();
+ },
+ // 杞挱鐐逛寒楗煎浘
+ hignLightPie() {
+ const dataPie = this.option.series[0].data;
+ // 鐔勭伃鎵�鏈夋墖褰㈠尯鍩�
+ for (var index in dataPie) {
+ this.myChart.dispatchAction({
+ type: "downplay",
+ seriesIndex: 0,
+ dataIndex: index,
+ });
+
+ this.myChart.dispatchAction({
+ type: "downplay",
+ seriesIndex: 1,
+ dataIndex: index,
+ });
+ }
+
+ // 鐐逛寒褰撳墠鎵囧舰鍖哄煙
+ this.myChart.dispatchAction({
+ type: "highlight",
+ seriesIndex: 0,
+ dataIndex: 0,
+ });
+
+ this.myChart.dispatchAction({
+ type: "highlight",
+ seriesIndex: 1,
+ dataIndex: 0,
+ });
+ },
+
+ // 榧犳爣瑙︽懜杞挱鎮仠浜嬩欢
+ defineEvent() {
+ // 榧犳爣绉诲嚭杞挱缁х画
+ this.myChart.on("mouseout", () => {
+ if (timer) clearInterval(timer);
+ timer = setInterval(this.selectPie, 1500);
+ });
+
+ // 榧犳爣杩涘叆杞挱鎮仠
+ this.myChart.on("mouseover", (params) => {
+ clearInterval(timer);
+ this.currentIndex = params.dataIndex;
+ this.hignLightPie();
+ });
+
+ // 榧犳爣绉诲叆legend杞挱鎮仠
+ this.myChart.getZr().on("mouseover", (event) => {
+ const legendDataIndex = event.topTarget.parent.__legendDataIndex; // 姣忎釜legend鐨刬ndex
+ clearInterval(timer);
+ this.currentIndex = legendDataIndex;
+ this.hignLightPie();
+ });
+
+ // 榧犳爣绉诲嚭legend杞挱缁х画
+ this.myChart.getZr().on("mouseout", () => {
+ if (timer) clearInterval(timer);
+ timer = setInterval(this.selectPie, 1500);
+ });
+ },
+ },
+};
+</script>
+
+<style>
+#echarts4 {
+ transform: scaleY(2);
+}
+</style>
diff --git "a/yiqi_screen/src/components/ProductionStatistics\345\244\207\344\273\2751113.vue" "b/yiqi_screen/src/components/ProductionStatistics\345\244\207\344\273\2751113.vue"
new file mode 100644
index 0000000..b8c860f
--- /dev/null
+++ "b/yiqi_screen/src/components/ProductionStatistics\345\244\207\344\273\2751113.vue"
@@ -0,0 +1,458 @@
+<template>
+ <!-- 鏈彮/鏈湀浜ч噺缁熻 -->
+ <div class="box-container box4" id="echarts4"></div>
+</template>
+
+<script>
+let timer = null;
+import * as echarts from "echarts";
+export default {
+ props: {
+ produceStatisData: {
+ type: Object,
+ default: () => {},
+ },
+ },
+ data() {
+ return {
+ option: {},
+ myChart: {},
+ currentIndex: -1,
+ data1: [],
+ data2: [{ actualData: 2782, planData: 11128 }],
+ };
+ },
+ // watch: {
+ // produceStatisData(val) {
+ // // 娴嬭瘯鐢細
+ // val.currentShiftProduceNum = 280;
+ // val.currentShiftPlanNum = 300;
+ // // 褰撳墠鐝粍瀹為檯鐢熶骇鏁伴噺 currentShiftProduceNum
+ // // 褰撳墠鐝粍璁″垝鐢熶骇鏁伴噺 currentShiftPlanNum
+ // var num1 = val.currentShiftProduceNum; //瀹為檯鐢熶骇鏁伴噺
+ // var num2 = val.currentShiftPlanNum - val.currentShiftProduceNum; //璁″垝鐢熶骇鏁伴噺
+ // if (val.currentShiftPlanNum == 0) {
+ // //鍒嗘瘝涓�0 鏄剧ず0%
+ // num1 = 0;
+ // num2 = 10;
+ // }
+ // this.$set(this.option.series[0], "data", [
+ // // { value: 1 }, //瀹為檯鐢熶骇鏁伴噺 1/ (9+1) = 10%
+ // // { value: 9 },
+ // {
+ // value: num1,
+ // }, //瀹為檯鐢熶骇鏁伴噺
+ // {
+ // value: num2,
+ // },
+ // ]);
+ // var num3 = val.currentMonthProduceNum;
+ // var num4 = val.currentMonthPlanNum - val.currentMonthProduceNum;
+ // if (val.currentMonthPlanNum == 0) {
+ // //鍒嗘瘝涓�0 鏄剧ず0%
+ // num3 = 0;
+ // num4 = 10;
+ // }
+ // this.$set(this.option.series[1], "data", [
+ // { value: num3 },
+ // { value: num4 },
+ // ]);
+
+ // this.myChart.setOption(this.option);
+ // this.hignLightPie();
+ // },
+ // },
+ mounted() {
+ this.myChart = this.$echarts.init(document.getElementById("echarts4"));
+ var value = 60;
+ var value2 = 15;
+ let data1 = [
+ {
+ value: value,
+ name: "",
+ itemStyle: {
+ normal: {
+ color: "#62fbf8",
+ },
+ },
+ },
+ {
+ value: 100 - value,
+ name: "",
+ label: {
+ normal: {
+ show: false,
+ },
+ },
+ itemStyle: {
+ normal: {
+ color: "rgba(0,0,0,0)",
+ },
+ },
+ },
+ ];
+
+ let data2 = [
+ {
+ value: value2,
+ name: "",
+ itemStyle: {
+ normal: {
+ color: "rgb(105,206,195)",
+ },
+ },
+ },
+ {
+ value: 100 - value2,
+ name: "",
+ label: {
+ normal: {
+ show: false,
+ },
+ },
+ itemStyle: {
+ normal: {
+ color: "rgba(0,0,0,0)",
+ },
+ },
+ },
+ ];
+
+ this.option = {
+ color: ["#00f6fe", "rgba(5, 19, 96, 0.5)"],
+ // 鎻掑叆鑳屾櫙鍥�
+ // graphic: [
+ // {
+ // type: "image",
+ // id: "background1",
+ // left: "13px", // 鏍规嵁鐜舰鍥剧殑浣嶇疆璋冩暣
+ // top: "61px", // 鏍规嵁鐜舰鍥剧殑浣嶇疆璋冩暣
+ // z: -10,
+ // bounding: "raw",
+ // origin: [0, 0],
+ // style: {
+ // image: require(`@/assets/images/quan.png`), // 绗竴涓幆褰㈠浘鐨勮儗鏅浘鐗囪矾寰�
+ // width: 100,
+ // height: 100,
+ // },
+ // },
+ // {
+ // type: "image",
+ // id: "background2",
+ // left: "131px", // 鏍规嵁鐜舰鍥剧殑浣嶇疆璋冩暣
+ // top: "61px", // 鏍规嵁鐜舰鍥剧殑浣嶇疆璋冩暣
+ // z: -10,
+ // bounding: "raw",
+ // origin: [0, 0],
+ // style: {
+ // image: require(`@/assets/images/quan.png`), // 绗竴涓幆褰㈠浘鐨勮儗鏅浘鐗囪矾寰�
+ // width: 100,
+ // height: 100,
+ // },
+ // },
+ // ],
+ series: [
+ // 宸︿晶
+ {
+ name: "宸�-鏁版嵁",
+ type: "pie",
+ // radius: ['65%', '75%'],
+ radius: ["29%", "36%"], //鐜彉缁�
+ center: ["25%", "49%"],
+ silent: true,
+ // clockwise: false,
+ startAngle: 90,
+ z: 1,
+ zlevel: 0,
+ label: {
+ normal: {
+ position: "center",
+ },
+ },
+ data: data1,
+ },
+ {
+ name: "宸�-涓棿娓愬彉",
+ type: "pie",
+ startAngle: 90,
+ z: 20,
+ zlevel: 20,
+ radius: "28%",
+ hoverAnimation: false,
+ center: ["25%", "49%"],
+
+ // zlevel: 2,
+ itemStyle: {
+ normal: {
+ labelLine: {
+ show: false,
+ },
+ color: new echarts.graphic.RadialGradient(0.5, 0.5, 1, [
+ {
+ offset: 1,
+ color: "rgba(55,70,130, 1)",
+ },
+ {
+ offset: 0,
+ color: "rgba(55,70,130, 0)",
+ },
+ ]),
+ shadowBlur: 10,
+ // shadowColor: 'rgba(55,70,130, 1)'
+ },
+ },
+ data: [
+ {
+ value: 100,
+ },
+ ],
+ },
+ {
+ name: "宸�-鍒诲害闂撮殧",
+ z: 2,
+ // zlevel: 1,
+ type: "gauge",
+ radius: "57%",
+ center: ["25%", "49%"],
+ startAngle: 20,
+ endAngle: -360,
+ splitNumber: 10,
+ hoverAnimation: true,
+ axisTick: {
+ show: true,
+ splitNumber: 1,
+ length: 14, //鍒诲害闀垮害
+ // Distance: 40, //鍒诲害闂撮殧璺濈
+ lineStyle: {
+ width: 5,
+ color: new echarts.graphic.LinearGradient(
+ 0,
+ 0,
+ 0,
+ 1,
+ [
+ {
+ offset: 0,
+ color: "rgba(8, 52, 106, 0.039)", // 0% 澶勭殑棰滆壊
+ },
+ {
+ offset: 1,
+ color: "rgba(8, 52, 106, 0.239)", // 100% 澶勭殑棰滆壊
+ },
+ ],
+ false
+ ),
+ },
+ },
+ splitLine: {
+ show: false,
+ },
+ axisLabel: {
+ show: false,
+ },
+ pointer: {
+ show: false,
+ },
+ axisLine: {
+ lineStyle: {
+ opacity: 0,
+ },
+ },
+ detail: {
+ show: false,
+ },
+ data: [100],
+ },
+
+ // 鍙充晶
+ {
+ name: "鍙�-鏁版嵁",
+ type: "pie",
+ // radius: ['65%', '75%'],
+ radius: ["29%", "36%"], //鐜彉缁�
+ center: ["74%", "49%"],
+ silent: true,
+ // clockwise: false,
+ startAngle: 90,
+ z: 1,
+ zlevel: 0,
+ label: {
+ normal: {
+ position: "center",
+ },
+ },
+ data: data2,
+ },
+ {
+ name: "鍙�-涓棿娓愬彉",
+ type: "pie",
+ startAngle: 90,
+ radius: "28%",
+ hoverAnimation: false,
+ center: ["74%", "49%"],
+ itemStyle: {
+ normal: {
+ labelLine: {
+ show: false,
+ },
+ color: new echarts.graphic.RadialGradient(0.5, 0.5, 1, [
+ {
+ offset: 1,
+ color: "rgba(55,70,130, 1)",
+ },
+ {
+ offset: 0,
+ color: "rgba(55,70,130, 0)",
+ },
+ ]),
+ shadowBlur: 10,
+ // shadowColor: 'rgba(55,70,130, 1)'
+ },
+ },
+ data: [
+ {
+ value: 100,
+ },
+ ],
+ },
+ {
+ name: "鍙�-鍒诲害闂撮殧",
+ z: 2,
+ type: "gauge",
+ radius: "45%",
+ center: ["74%", "49%"],
+ startAngle: 90,
+ endAngle: -360,
+ splitNumber: 10,
+ hoverAnimation: true,
+ axisTick: {
+ show: true,
+ splitNumber: 1,
+ length: 20,
+ lineStyle: {
+ width: 10,
+ color: "#1183a7",
+ shadowColor: "rgb(4,31,62, 0.5)",
+ },
+ },
+ splitLine: {
+ show: false,
+ },
+ axisLabel: {
+ show: false,
+ },
+ pointer: {
+ show: false,
+ },
+ axisLine: {
+ lineStyle: {
+ opacity: 0,
+ },
+ },
+ detail: {
+ show: false,
+ },
+ data: [100],
+ },
+ ],
+ };
+ this.myChart.setOption(this.option);
+ const that = this;
+ window.addEventListener("resize", () => {
+ that.myChart.resize();
+ });
+ // this.getData();
+ this.defineEvent();
+ // this.selectPie();
+ this.hignLightPie();
+ // timer = setInterval(this.selectPie, 1500);
+ },
+ methods: {
+ // getData() {
+ // this.data1 = [{ actualData: 144, planData: 288 }];
+ // this.$set(this.option.series[0], "data", [
+ // { value: this.data1[0].actualData },
+ // { value: this.data1[0].planData - this.data1[0].actualData },
+ // ]);
+ // this.$set(this.option.series[1], "data", [
+ // { value: this.data2[0].actualData },
+ // { value: this.data2[0].planData - this.data2[0].actualData },
+ // ]);
+ // console.log(this.option.series[0].data);
+ // this.myChart.setOption(this.option);
+ // },
+ selectPie() {
+ let dataLen = this.option.series[0].data.length;
+ this.currentIndex = (this.currentIndex + 1) % dataLen;
+ this.hignLightPie();
+ },
+ // 杞挱鐐逛寒楗煎浘
+ hignLightPie() {
+ const dataPie = this.option.series[0].data;
+ // 鐔勭伃鎵�鏈夋墖褰㈠尯鍩�
+ for (var index in dataPie) {
+ this.myChart.dispatchAction({
+ type: "downplay",
+ seriesIndex: 0,
+ dataIndex: index,
+ });
+
+ this.myChart.dispatchAction({
+ type: "downplay",
+ seriesIndex: 1,
+ dataIndex: index,
+ });
+ }
+
+ // 鐐逛寒褰撳墠鎵囧舰鍖哄煙
+ this.myChart.dispatchAction({
+ type: "highlight",
+ seriesIndex: 0,
+ dataIndex: 0,
+ });
+
+ this.myChart.dispatchAction({
+ type: "highlight",
+ seriesIndex: 1,
+ dataIndex: 0,
+ });
+ },
+
+ // 榧犳爣瑙︽懜杞挱鎮仠浜嬩欢
+ defineEvent() {
+ // 榧犳爣绉诲嚭杞挱缁х画
+ this.myChart.on("mouseout", () => {
+ if (timer) clearInterval(timer);
+ timer = setInterval(this.selectPie, 1500);
+ });
+
+ // 榧犳爣杩涘叆杞挱鎮仠
+ this.myChart.on("mouseover", (params) => {
+ clearInterval(timer);
+ this.currentIndex = params.dataIndex;
+ this.hignLightPie();
+ });
+
+ // 榧犳爣绉诲叆legend杞挱鎮仠
+ this.myChart.getZr().on("mouseover", (event) => {
+ const legendDataIndex = event.topTarget.parent.__legendDataIndex; // 姣忎釜legend鐨刬ndex
+ clearInterval(timer);
+ this.currentIndex = legendDataIndex;
+ this.hignLightPie();
+ });
+
+ // 榧犳爣绉诲嚭legend杞挱缁х画
+ this.myChart.getZr().on("mouseout", () => {
+ if (timer) clearInterval(timer);
+ timer = setInterval(this.selectPie, 1500);
+ });
+ },
+ },
+};
+</script>
+
+<style>
+#echarts4 {
+ transform: scaleY(2);
+}
+</style>
diff --git a/yiqi_screen/src/components/img/t.js b/yiqi_screen/src/components/img/t.js
index 36e8e8a..63fb1fd 100644
--- a/yiqi_screen/src/components/img/t.js
+++ b/yiqi_screen/src/components/img/t.js
@@ -1 +1 @@
-export let zhu = ""
\ No newline at end of file
+export let zhu = '';
\ No newline at end of file
diff --git "a/yiqi_screen1216\344\272\214\347\273\264.rar" "b/yiqi_screen1216\344\272\214\347\273\264.rar"
new file mode 100644
index 0000000..547d75a
--- /dev/null
+++ "b/yiqi_screen1216\344\272\214\347\273\264.rar"
Binary files differ
--
Gitblit v1.9.3