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