| | |
| | | "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", |
| | |
| | | "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", |
| | |
| | | } |
| | | }, |
| | | "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": { |
| | |
| | | "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" |
| | | } |
| | |
| | | "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", |
| | |
| | | "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": { |
| | |
| | | } |
| | | }, |
| | | "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" |
| | | }, |
| | |
| | | }, |
| | | "dependencies": { |
| | | "@jiaminghi/data-view": "^2.10.0", |
| | | "animejs": "^3.2.2", |
| | | "axios": "^1.6.0", |
| | | "core-js": "^3.8.3", |
| | | "echarts": "^5.4.3", |
| | |
| | | |
| | | <style> |
| | | html, body { |
| | | font-size: 79.5833px !important; |
| | | width: 1910px; |
| | | height: 1070px; |
| | | /* width:100%; */ |
| | |
| | | // 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" //æ¬å°æµè¯ç¯å¢ |
| | | |
| | |
| | | export let zhu = "" |
| | | export let zhu = ''; |
| | |
| | | <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 |
| | | alt="t10" |
| | | :src="require(`@/assets/images/10.png`)" |
| | | class="OP89" |
| | | v-if=" |
| | | item.equipmentCurrentState == 1 && |
| | | item.workingProcedure == 'OP20' |
| | | " |
| | | src="~@/assets/images/8.gif" |
| | | class="box200" |
| | | /> |
| | | <img |
| | | alt="t10" |
| | | :src="require(`@/assets/images/10.png`)" |
| | | class="OP90" |
| | | /> --> |
| | | v-if=" |
| | | item.equipmentCurrentState == 1 && |
| | | item.workingProcedure == 'OP50' |
| | | " |
| | | src="~@/assets/images/8.gif" |
| | | class="box300" |
| | | /> |
| | | </div> |
| | | |
| | | <img |
| | | alt="t1" |
| | | v-for="item in equipmentStatusData" |
| | | :key="item.id" |
| | | :src=" |
| | |
| | | :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" |
| | | /> |
| | |
| | | <!-- <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> |
| | |
| | | </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"> |
| | |
| | | </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" |
| | | /> |
| | |
| | | (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); |
| | | } |
| | |
| | | this.imageColor[item.workingProcedure] = result[0].color; |
| | | } |
| | | }); |
| | | // console.log(this.imageColor, "getImageColor"); |
| | | console.log(5555555555); |
| | | console.log(this.imageColor, "getImageColor"); |
| | | }, |
| | | // è·åè´¨éæ°æ® |
| | | async getQualityData() { |
| | |
| | | }, |
| | | }, |
| | | 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(){ |
| | |
| | | } |
| | | |
| | | .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); |
| | | } |
| | | } |
| | | |
| | |
| | | width: 95%; |
| | | margin: 0 auto; |
| | | position: relative; |
| | | height: 6.8rem; |
| | | height: 526px; |
| | | } |
| | | |
| | | .prodline { |
| | |
| | | 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 { |
| | |
| | | } |
| | | |
| | | .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 { |
| | |
| | | width: 101%; |
| | | } |
| | | |
| | | .OP80, |
| | | .unit { |
| | | top: -113px; |
| | | left: 86px; |
| | | transform: scale(1.2); |
| | | } |
| | | |
| | | .OP80 { |
| | | top: -1.95rem; |
| | | left: 1.98rem; |
| | | } |
| | |
| | | } |
| | | |
| | | .main-bottom { |
| | | height: 320px; |
| | | height: 336px; |
| | | display: flex; |
| | | justify-content: center; |
| | | .border_left1 { |
| | |
| | | color: #00f8c6; |
| | | text-align: center; |
| | | border-bottom: 2px solid #0739a3; |
| | | |
| | | } |
| | | } |
| | | |
| | |
| | | .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> |
¶Ô±ÈÐÂÎļþ |
| | |
| | | <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> |
¶Ô±ÈÐÂÎļþ |
| | |
| | | <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> |
¶Ô±ÈÐÂÎļþ |
| | |
| | | <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> |
¶Ô±ÈÐÂÎļþ |
| | |
| | | <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> |
¶Ô±ÈÐÂÎļþ |
| | |
| | | <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> |
| | |
| | | <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: { |
| | |
| | | option: {}, |
| | | myChart: {}, |
| | | timechartes: null, |
| | | |
| | | myChart2: null, |
| | | textureImg: null, |
| | | // img, |
| | |
| | | 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); |
| | |
| | | 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)", |
| | |
| | | axisLine: { |
| | | lineStyle: { |
| | | color: "#326e92", |
| | | |
| | | }, |
| | | }, |
| | | }, |
| | |
| | | show: true, |
| | | margin: 5, |
| | | color: "#326e92", |
| | | // formatter: '{value}%' |
| | | formatter: "{value}%", |
| | | }, |
| | | alignTicks: false, |
| | | nameTextStyle: { |
| | |
| | | name: "çäº§å®ææ°", |
| | | type: "pictorialBar", |
| | | // type: "bar", |
| | | symbol: 'image://'+zhu, |
| | | symbol: "image://" + zhu, |
| | | data: [], |
| | | |
| | | // yAxisIndex: 0, |
| | | // color: { |
| | | // type: "linear", |
| | |
| | | name: "çäº§å®æç", |
| | | type: "line", |
| | | data: [], |
| | | z: 5, |
| | | showSymbol: true, |
| | | yAxisIndex: 1, |
| | | smooth: true, // 使æçº¿å¾å¹³æ» |
| | | color: "rgba(255,205,86,0.85)", |
| | | color: "#ff9600", |
| | | lineStyle: { |
| | | width: 1, |
| | | }, |
| | |
| | | // window.addEventListener("resize", ()=> { |
| | | // this.myChart.resize(); |
| | | // }); |
| | | |
| | | // this.init() |
| | | }, |
| | | methods: { |
| | |
| | | var chartDom = document.getElementById("main"); |
| | | var myChart = echarts.init(chartDom); |
| | | var option; |
| | | var rocket ='' |
| | | var rocket = ""; |
| | | |
| | | option = { |
| | | legend: { |
| | |
| | | { |
| | | type: "pictorialBar", |
| | | name: "tu1", |
| | | symbol: 'image://'+zhu, |
| | | symbol: "image://" + zhu, |
| | | data: [ |
| | | { |
| | | value: 60, |
| | |
| | | }; |
| | | myChart.setOption(option); |
| | | }, |
| | | |
| | | }, |
| | | }; |
| | | </script> |
¶Ô±ÈÐÂÎļþ |
| | |
| | | <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çindex |
| | | 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> |
¶Ô±ÈÐÂÎļþ |
| | |
| | | <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çindex |
| | | 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> |
¶Ô±ÈÐÂÎļþ |
| | |
| | | <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çindex |
| | | 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> |
| | |
| | | <template> |
| | | <!-- æ¬ç/æ¬æäº§éç»è®¡ --> |
| | | <div class="box-container box4" id="echarts4"></div> |
| | | |
| | | </template> |
| | | |
| | | <script> |
| | |
| | | watch: { |
| | | produceStatisData(val) { |
| | | // æµè¯ç¨ï¼ |
| | | val.currentShiftProduceNum = 300; |
| | | val.currentShiftPlanNum = 300; |
| | | // val.currentShiftProduceNum = 280; |
| | | // val.currentShiftPlanNum = 300; |
| | | |
| | | // å½åçç»å®é
ç产æ°é currentShiftProduceNum |
| | | // å½åçç»è®¡åç产æ°é currentShiftPlanNum |
| | | var num1 = val.currentShiftProduceNum; //å®é
ç产æ°é |
| | |
| | | num1 = 0; |
| | | num2 = 10; |
| | | } |
| | | |
| | | |
| | | |
| | | this.$set(this.option.series[0], "data", [ |
| | | // { value: 1 }, //å®é
ç产æ°é 1/ (9+1) = 10% |
| | | // { value: 9 }, |
| | | { value: num1, |
| | | { |
| | | value: num1, |
| | | }, //å®é
ç产æ°é |
| | | { value: num2 }, |
| | | { |
| | | value: num2, |
| | | }, |
| | | ]); |
| | | var num3 = val.currentMonthProduceNum; |
| | | var num4 = val.currentMonthPlanNum - val.currentMonthProduceNum; |
| | |
| | | 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, |
| | |
| | | color: "#19d8d0", |
| | | fontWeight: "normal", |
| | | }, |
| | | |
| | | }, |
| | | labelLine: { |
| | | show: false, |
| | |
| | | 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, |
| | |
| | | <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> |
¶Ô±ÈÐÂÎļþ |
| | |
| | | <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çindex |
| | | 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> |
¶Ô±ÈÐÂÎļþ |
| | |
| | | <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çindex |
| | | 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> |
| | |
| | | export let zhu = "" |
| | | export let zhu = ''; |