fix:大屏首页逻辑增加
This commit is contained in:
		
							parent
							
								
									d2a445b36c
								
							
						
					
					
						commit
						c9156a2813
					
				
							
								
								
									
										28
									
								
								src/api/xj/index/index.js
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										28
									
								
								src/api/xj/index/index.js
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,28 @@ | ||||
| /* | ||||
|  * @Author: SunTao 328867980@qq.com | ||||
|  * @Date: 2024-11-15 11:05:34 | ||||
|  * @LastEditors: SunTao 328867980@qq.com | ||||
|  * @LastEditTime: 2024-11-15 11:18:36 | ||||
|  * @FilePath: \znxjxt-ui\src\api\xj\index\index.js | ||||
|  * @Description: 内部首页接口 | ||||
|  */ | ||||
| 
 | ||||
| import request from "@/utils/request"; | ||||
| 
 | ||||
| // 获取首页最顶端数据
 | ||||
| export function getTotalCount(query) { | ||||
|   return request({ | ||||
|     url: "/xj/home/getTotalCount", | ||||
|     method: "get", | ||||
|     params: query, | ||||
|   }); | ||||
| } | ||||
| 
 | ||||
| // 获取日常巡查数据
 | ||||
| export function getTaskToday(query) { | ||||
|   return request({ | ||||
|     url: "/xj/home/getTaskToday", | ||||
|     method: "get", | ||||
|     params: query, | ||||
|   }); | ||||
| } | ||||
| @ -98,3 +98,24 @@ export function getCarList(query) { | ||||
|     params: query, | ||||
|   }); | ||||
| } | ||||
| 
 | ||||
| 
 | ||||
| // 获取设备直播的url地址
 | ||||
| export function getVideoUrl(params) { | ||||
|   return request({ | ||||
|     url: "/bigscreen/v2/getAiotVideoUrl", | ||||
|     method: "get", | ||||
|     params, | ||||
|   }); | ||||
| } | ||||
| 
 | ||||
| // 关闭设备的上传视频流
 | ||||
| export function closeVideoUrl(params) { | ||||
|   return request({ | ||||
|     url: "/bigscreen/v2/colseAiotVideo", | ||||
|     method: "get", | ||||
|     params, | ||||
|   }); | ||||
| } | ||||
| 
 | ||||
| 
 | ||||
|  | ||||
| @ -2,9 +2,9 @@ | ||||
|  * @Author: SunTao 328867980@qq.com | ||||
|  * @Date: 2024-10-24 15:03:28 | ||||
|  * @LastEditors: SunTao 328867980@qq.com | ||||
|  * @LastEditTime: 2024-11-14 09:16:02 | ||||
|  * @LastEditTime: 2024-11-15 14:57:02 | ||||
|  * @FilePath: \znxjxt-ui\src\api\xj\screen\index.js | ||||
|  * @Description: 这是默认设置,请设置`customMade`, 打开koroFileHeader查看配置 进行设置: https://github.com/OBKoro1/koro1FileHeader/wiki/%E9%85%8D%E7%BD%AE
 | ||||
|  * @Description: 大屏首页接口  | ||||
|  */ | ||||
| import request from "@/utils/request"; | ||||
| 
 | ||||
|  | ||||
| @ -0,0 +1,127 @@ | ||||
| <!-- | ||||
|  * @Author: SunTao 328867980@qq.com | ||||
|  * @Date: 2024-11-15 13:14:03 | ||||
|  * @LastEditors: SunTao 328867980@qq.com | ||||
|  * @LastEditTime: 2024-11-15 14:06:48 | ||||
|  * @FilePath: \znxjxt-ui\src\views\big-screen\overview-components\components\inspection-follow.vue | ||||
|  * @Description: 总览大屏-巡检车辆-跟车弹窗 | ||||
| --> | ||||
| 
 | ||||
| <template> | ||||
|   <div class="inspection-content"> | ||||
|     <fssm-map ref="carMap" :baseMap="'img_c'"></fssm-map> | ||||
|   </div> | ||||
| </template> | ||||
| 
 | ||||
| <script> | ||||
| // websocket | ||||
| import { | ||||
|   connectWebsocket, | ||||
|   closeWebsocket, | ||||
|   sendMsg, | ||||
| } from "@/plugins/websocket.js"; | ||||
| import { getToken } from "@/utils/auth.js"; | ||||
| import logo from "@/assets/xc.png"; | ||||
| import FssmMap from "@/components/map/fssm-map.vue"; | ||||
| import { Point } from "ol/geom"; | ||||
| import { Feature } from "ol"; | ||||
| import { Style, Icon } from "ol/style"; | ||||
| import VectorSource from "ol/source/Vector"; | ||||
| import VectorLayer from "ol/layer/Vector"; | ||||
| 
 | ||||
| export default { | ||||
|   name: "InspectionFollow", | ||||
|   components: { | ||||
|     FssmMap, | ||||
|   }, | ||||
|   data() { | ||||
|     return {}; | ||||
|   }, | ||||
|   created() { | ||||
|     this.initWebSocket(); | ||||
|   }, | ||||
|   methods: { | ||||
|     /* 初始化websocket */ | ||||
|     initWebSocket() { | ||||
|       const url = `ws://192.168.1.188:8080/websocket?token=${getToken()}`; | ||||
|       const data = { type: "carLocation", status: true }; | ||||
|       connectWebsocket( | ||||
|         url, | ||||
|         data, | ||||
|         (res) => { | ||||
|           // console.log("onWsMessage接收到服务器的数据: ", res); | ||||
|           console.log(JSON.parse(res)); | ||||
|         }, | ||||
|         (err) => { | ||||
|             console.log("断开重连"); | ||||
|             this.drawPoint(); | ||||
|         } | ||||
|       ); | ||||
|     }, | ||||
| 
 | ||||
|     /* 发送消息 */ | ||||
|     sendMsg() { | ||||
|       sendMsg(5555); //value是发送的值 | ||||
|       // this.value = ""; | ||||
|     }, | ||||
| 
 | ||||
|     /* 绘制地图车点位 */ | ||||
|     drawPoint() { | ||||
|       const features = []; | ||||
|       // 修改坐标样式 | ||||
|       const point = new Point([123.30297096718999,41.87942945541742]); | ||||
|       const feature = new Feature({ | ||||
|         geometry: point, | ||||
|         data: { | ||||
|           iconType: "1", | ||||
|         //   imageUrl: element.imageUrl, | ||||
|         //   rect: element.rect, | ||||
|         }, | ||||
|         // 自己设置一个标识 | ||||
|         type: "icon", | ||||
|       }); | ||||
|       // 可以给点位设置样式 | ||||
|       feature.setStyle([ | ||||
|         new Style({ | ||||
|           image: new Icon({ | ||||
|             crossOrigin: "anonymous", | ||||
|             src: logo, | ||||
|             // 图标缩放比例 | ||||
|             scale: 0.05, | ||||
|           }), | ||||
|         }), | ||||
|       ]); | ||||
|       features.push(feature); | ||||
|       //设置地图的数据源 | ||||
|       const pointSource = new VectorSource({ | ||||
|         features, | ||||
|       }); | ||||
|       let markLayerPoints = new VectorLayer({ | ||||
|         source: pointSource, | ||||
|         properties: { | ||||
|           type: "point", | ||||
|         }, | ||||
|       }); | ||||
|       this.$nextTick(() => { | ||||
|         const map = this.$refs.carMap.instance.get("map"); | ||||
|         map.addLayer(markLayerPoints); | ||||
|       }); | ||||
|     }, | ||||
|     beforeDestroy() { | ||||
|       closeWebsocket(); | ||||
|     }, | ||||
|   }, | ||||
| }; | ||||
| </script> | ||||
| 
 | ||||
| <style lang="scss" scoped> | ||||
| .inspection-content { | ||||
|   width: 100%; | ||||
|   height: 45rem; | ||||
| 
 | ||||
|   ::v-deep .baseLayerClass { | ||||
|     filter: grayscale(200%) invert(200%) sepia(50%) hue-rotate(175deg) | ||||
|       brightness(80%) saturate(550%); | ||||
|   } | ||||
| } | ||||
| </style> | ||||
| @ -0,0 +1,52 @@ | ||||
| <!-- | ||||
|  * @Author: SunTao 328867980@qq.com | ||||
|  * @Date: 2024-11-15 14:23:21 | ||||
|  * @LastEditors: SunTao 328867980@qq.com | ||||
|  * @LastEditTime: 2024-11-15 15:06:55 | ||||
|  * @FilePath: \znxjxt-ui\src\views\big-screen\overview-components\components\inspection-view.vue | ||||
|  * @Description: 总览大屏-巡检车辆-视频查看弹窗 | ||||
| --> | ||||
| 
 | ||||
| <template> | ||||
|   <div class="view-content"></div> | ||||
| </template> | ||||
| 
 | ||||
| <script> | ||||
| import { getVideoUrl } from "@/api/xj/screen/disease-screen"; | ||||
| export default { | ||||
|   name: "InspectionView", | ||||
|   props: { | ||||
|     dialogItem: { | ||||
|       type: Object, | ||||
|       default: () => {}, | ||||
|     }, | ||||
|   }, | ||||
|   data() { | ||||
|     return { | ||||
|       // 视频播放地址 | ||||
|       vedioUrl: "", | ||||
|     }; | ||||
|   }, | ||||
|   created() { | ||||
|     this.getVideo(); | ||||
|   }, | ||||
|   methods: { | ||||
|     /* 获取视频url地址 */ | ||||
|     getVideo() { | ||||
|       console.log(this.dialogItem); | ||||
|       getVideoUrl({ id: this.dialogItem.clientId }).then(({ code, data }) => { | ||||
|         if (code === 200) { | ||||
|              | ||||
|         } | ||||
|       }); | ||||
|     }, | ||||
|   }, | ||||
| }; | ||||
| </script> | ||||
| 
 | ||||
| <style lang="scss" scoped> | ||||
| .view-content { | ||||
|   width: 100%; | ||||
|   height: 40rem; | ||||
| } | ||||
| </style> | ||||
| @ -2,7 +2,7 @@ | ||||
|  * @Author: SunTao 328867980@qq.com | ||||
|  * @Date: 2024-11-08 09:40:18 | ||||
|  * @LastEditors: SunTao 328867980@qq.com | ||||
|  * @LastEditTime: 2024-11-14 15:54:12 | ||||
|  * @LastEditTime: 2024-11-15 15:29:10 | ||||
|  * @FilePath: \znxjxt-ui\src\views\big-screen\disease-components\inspection-vehicles.vue | ||||
|  * @Description: 总览大屏-巡检车辆 | ||||
| --> | ||||
| @ -85,7 +85,6 @@ | ||||
|             </el-popover> | ||||
| 
 | ||||
|             <el-button | ||||
|               disabled | ||||
|               size="mini" | ||||
|               type="text" | ||||
|               @click="followCar(scope.row)" | ||||
| @ -93,7 +92,6 @@ | ||||
|               >跟车 | ||||
|             </el-button> | ||||
|             <el-button | ||||
|               disabled | ||||
|               size="mini" | ||||
|               type="text" | ||||
|               @click="videoDelete(scope.row)" | ||||
| @ -118,13 +116,48 @@ | ||||
|         </el-pagination> | ||||
|       </div> --> | ||||
|     </div> | ||||
|     <!-- 跟车弹窗 --> | ||||
|     <el-dialog | ||||
|       :title="followTitle" | ||||
|       :visible.sync="showCarVisible" | ||||
|       width="85rem" | ||||
|       append-to-body | ||||
|       :close-on-click-modal="false" | ||||
|       destroy-on-close | ||||
|       @close="followCancel" | ||||
|     > | ||||
|       <inspection-follow v-if="followTitle === '跟车详情'"></inspection-follow> | ||||
|     </el-dialog> | ||||
| 
 | ||||
|     <!-- 视频弹窗 --> | ||||
|     <el-dialog | ||||
|       :title="viewTitle" | ||||
|       :visible.sync="showViewVisible" | ||||
|       width="60rem" | ||||
|       append-to-body | ||||
|       :close-on-click-modal="false" | ||||
|       destroy-on-close | ||||
|       @close="viewCancel" | ||||
|     > | ||||
|       <inspection-view | ||||
|         v-if="viewTitle === '视频查看'" | ||||
|         :dialogItem="dialogItem" | ||||
|       ></inspection-view> | ||||
|     </el-dialog> | ||||
|   </div> | ||||
| </template> | ||||
| 
 | ||||
| <script> | ||||
| import { getCarList } from "@/api/xj/screen/disease-screen"; | ||||
| import { getCarList, closeVideoUrl } from "@/api/xj/screen/disease-screen"; | ||||
| import InspectionFollow from "./components/inspection-follow.vue"; | ||||
| import InspectionView from "./components/inspection-view.vue"; | ||||
| import { closeWebsocket } from "@/plugins/websocket.js"; | ||||
| export default { | ||||
|   name: "InspectionVehicles", | ||||
|   components: { | ||||
|     InspectionFollow, | ||||
|     InspectionView, | ||||
|   }, | ||||
|   data() { | ||||
|     return { | ||||
|       // 车辆总数 | ||||
| @ -142,6 +175,16 @@ export default { | ||||
|       // }, | ||||
|       // 分页总数 | ||||
|       tableTotal: 0, | ||||
|       // 传弹窗数据 | ||||
|       dialogItem: {}, | ||||
|       // 跟车弹窗显隐控制 | ||||
|       showCarVisible: false, | ||||
|       // 跟车弹窗标题 | ||||
|       followTitle: "", | ||||
|       // 视频弹窗显隐控制 | ||||
|       showViewVisible: false, | ||||
|       // 视频弹窗标题 | ||||
|       viewTitle: "", | ||||
|     }; | ||||
|   }, | ||||
|   created() { | ||||
| @ -164,16 +207,44 @@ export default { | ||||
|     detailDefect(val) {}, | ||||
| 
 | ||||
|     /* 表格跟车事件 */ | ||||
|     followCar(val) {}, | ||||
|     followCar(val) { | ||||
|       this.followTitle = "跟车详情"; | ||||
|       this.showCarVisible = true; | ||||
|     }, | ||||
| 
 | ||||
|     /* 表格视频事件 */ | ||||
|     videoDelete(val) {}, | ||||
|     videoDelete(val) { | ||||
|       this.dialogItem = val; | ||||
|       this.viewTitle = "视频查看"; | ||||
|       this.showViewVisible = true; | ||||
|     }, | ||||
| 
 | ||||
|     /* 页码修改事件 */ | ||||
|     // handleCurrentChange(arg) { | ||||
|     //   this.pagination.page = arg; | ||||
|     //   this.getTableData(); | ||||
|     // }, | ||||
| 
 | ||||
|     /* 关闭跟车弹窗事件 */ | ||||
|     followCancel() { | ||||
|       this.followTitle = ""; | ||||
|       this.showCarVisible = false; | ||||
|       this.dialogItem = {}; | ||||
|       closeWebsocket(); | ||||
|     }, | ||||
| 
 | ||||
|     /* 关闭视频弹窗事件 */ | ||||
|     viewCancel() { | ||||
|       this.viewTitle = ""; | ||||
|       this.showViewVisible = false; | ||||
|       closeVideoUrl({ id: this.dialogItem.clientId }) | ||||
|         .then(({ code, data }) => { | ||||
|           if (code === 200) { | ||||
|             console.log(data); | ||||
|             this.dialogItem = {}; | ||||
|           } | ||||
|         }) | ||||
|     }, | ||||
|   }, | ||||
| }; | ||||
| </script> | ||||
| @ -313,6 +384,22 @@ export default { | ||||
|     background: transparent; | ||||
|   } | ||||
| } | ||||
| 
 | ||||
| /* 修改弹窗样式 */ | ||||
| ::v-deep .el-dialog__header { | ||||
|   padding: 10px; | ||||
|   background-color: #113463; | ||||
| 
 | ||||
|   span, | ||||
|   i { | ||||
|     color: #ffffff; | ||||
|   } | ||||
| } | ||||
| 
 | ||||
| ::v-deep .el-dialog__body { | ||||
|   padding: 0; | ||||
|   background-color: #113463; | ||||
| } | ||||
| </style> | ||||
| <style lang="scss"> | ||||
| /* 弹出层样式 */ | ||||
|  | ||||
| @ -2,7 +2,7 @@ | ||||
|  * @Author: SunTao 328867980@qq.com | ||||
|  * @Date: 2024-10-29 15:12:20 | ||||
|  * @LastEditors: SunTao 328867980@qq.com | ||||
|  * @LastEditTime: 2024-11-05 11:47:03 | ||||
|  * @LastEditTime: 2024-11-15 11:37:11 | ||||
|  * @FilePath: \znxjxt-ui\src\views\index-components\daily-index.vue | ||||
|  * @Description: 首页-日常巡查 | ||||
| --> | ||||
| @ -14,13 +14,19 @@ | ||||
|       <div class="left"> | ||||
|         <div class="left-div"> | ||||
|           <div class="name">巡查里程</div> | ||||
|           <div class="value"><span>15.16</span>km</div> | ||||
|           <div class="value"> | ||||
|             <span>{{ formatNumber(mileage) }}</span | ||||
|             >km | ||||
|           </div> | ||||
|         </div> | ||||
|         <div class="left-div"> | ||||
|           <div class="name">覆盖道路数</div> | ||||
|           <div class="value"><span>352</span>条</div> | ||||
|           <div class="value"> | ||||
|             <span>{{ roadNum }}</span | ||||
|             >条 | ||||
|           </div> | ||||
|         <div class="left-chart" ref="rateChart"></div> | ||||
|         </div> | ||||
|         <!-- <div class="left-chart" ref="rateChart"></div> --> | ||||
|       </div> | ||||
|       <div class="right"> | ||||
|         <div ref="trendChart"></div> | ||||
| @ -31,106 +37,62 @@ | ||||
| </template> | ||||
| 
 | ||||
| <script> | ||||
| import { getTaskToday } from "@/api/xj/index/index"; | ||||
| import * as echarts from "echarts"; | ||||
| export default { | ||||
|   name: "DailyIndex", | ||||
|   data() { | ||||
|     return {}; | ||||
|     return { | ||||
|       // 巡查里程 | ||||
|       mileage: 0, | ||||
|       // 覆盖道路数 | ||||
|       roadNum: 0, | ||||
|       // 病害趋势echart数据 | ||||
|       diseaseChart: [], | ||||
|     }; | ||||
|   }, | ||||
|   created() { | ||||
|     this.getData(); | ||||
|   }, | ||||
|   methods: { | ||||
|     /* 处理数据 */ | ||||
|     formatNumber(num) { | ||||
|       if (num >= 100000000) { | ||||
|         // 超过1亿显示 x.xx亿 | ||||
|         return (num / 100000000).toFixed(2) + "亿"; | ||||
|       } else if (num >= 10000) { | ||||
|         // 超过1万显示 x.xx万 | ||||
|         return (num / 10000).toFixed(2) + "万"; | ||||
|       } else { | ||||
|         // 小于1万直接返回原数字 | ||||
|         return num; | ||||
|       } | ||||
|     }, | ||||
| 
 | ||||
|     /* 获取数据 */ | ||||
|     getData() { | ||||
|       getTaskToday().then(({ code, data }) => { | ||||
|         if (code === 200) { | ||||
|           this.mileage = data.xclc; | ||||
|           this.roadNum = data.fgdlts; | ||||
|           this.diseaseChart = data.xclcbhqs; | ||||
|           this.$nextTick(() => { | ||||
|         this.drawLeftChart(); | ||||
|             // this.drawLeftChart(); | ||||
|             this.drawTrendChart(); | ||||
|             this.drawDistributionChart(); | ||||
|           }); | ||||
|     }, | ||||
|     /* 绘制覆盖率饼图 */ | ||||
|     drawLeftChart() { | ||||
|       if (this.$refs.rateChart) { | ||||
|         const chart = echarts.init(this.$refs.rateChart); | ||||
|         const current = 45; | ||||
|         chart.setOption({ | ||||
|           // color: ['rgba(61, 137, 247, 1)', '#f07b3f'], | ||||
|           title: [ | ||||
|             // 中心比例 | ||||
|             { | ||||
|               text: "80%", | ||||
|               x: "center", | ||||
|               y: "52%", | ||||
|               textStyle: { | ||||
|                 fontSize: 20, | ||||
|                 color: "#444", | ||||
|                 fontWeight: "bold", | ||||
|               }, | ||||
|             }, | ||||
|             { | ||||
|               text: "覆盖率", | ||||
|               x: "center", | ||||
|               y: "10%", | ||||
|               textStyle: { | ||||
|                 fontSize: 14, | ||||
|               }, | ||||
|             }, | ||||
|           ], | ||||
|           polar: { | ||||
|             center: ["50%", "60%"], | ||||
|             radius: ["40%", "58%"], | ||||
|           }, | ||||
|           angleAxis: { | ||||
|             max: 100, | ||||
|             show: false, | ||||
|           }, | ||||
|           radiusAxis: { | ||||
|             type: "category", | ||||
|             show: true, | ||||
|             axisLabel: { | ||||
|               show: false, | ||||
|             }, | ||||
|             axisLine: { | ||||
|               show: false, | ||||
|             }, | ||||
|             axisTick: { | ||||
|               show: false, | ||||
|             }, | ||||
|           }, | ||||
|           series: [ | ||||
|             { | ||||
|               data: [80], | ||||
|               name: "", | ||||
|               type: "bar", | ||||
|               roundCap: true, | ||||
|               showBackground: true, | ||||
|               backgroundStyle: { | ||||
|                 color: "#BDD5F4", | ||||
|               }, | ||||
|               coordinateSystem: "polar", | ||||
|               itemStyle: { | ||||
|                 color: new echarts.graphic.LinearGradient(0, 1, 0, 0, [ | ||||
|                   { | ||||
|                     offset: 0, | ||||
|                     color: "#005DCF", | ||||
|                   }, | ||||
|                   { | ||||
|                     offset: 1, | ||||
|                     color: "#00CCFF", | ||||
|                   }, | ||||
|                 ]), | ||||
|               }, | ||||
|             }, | ||||
|           ], | ||||
|         }); | ||||
|         window.addEventListener("resize", () => { | ||||
|           chart.resize(); | ||||
|         }); | ||||
|         } | ||||
|       }); | ||||
|     }, | ||||
| 
 | ||||
|     /* 绘制病害趋势柱状图 */ | ||||
|     drawTrendChart() { | ||||
|       const xData = this.diseaseChart.map((item) => { | ||||
|         return item.label; | ||||
|       }); | ||||
|       const yData = this.diseaseChart.map((item) => { | ||||
|         return item.value; | ||||
|       }); | ||||
|       if (this.$refs.trendChart) { | ||||
|         const chart = echarts.init(this.$refs.trendChart); | ||||
|         chart.setOption({ | ||||
| @ -162,7 +124,7 @@ export default { | ||||
|           xAxis: [ | ||||
|             { | ||||
|               type: "category", | ||||
|               data: ["2024/2/9", "2024/2/10", "2024/2/11", "2024/2/12"], | ||||
|               data: xData, | ||||
|               axisTick: { | ||||
|                 show: false, //隐藏X轴刻度 | ||||
|               }, | ||||
| @ -217,23 +179,69 @@ export default { | ||||
|               type: "bar", | ||||
|               barWidth: 10, | ||||
|               name: "累计病害", | ||||
|               data: [400, 600, 1400, 1700], | ||||
|               data: yData, | ||||
|             }, | ||||
|             { | ||||
|               type: "line", | ||||
|               symbolSize: 5, | ||||
|               name: "巡查里程", | ||||
|               smooth: 1, | ||||
|               data: [10, 40, 50, 90], | ||||
|               data: [10, 40, 50, 90, 10, 20, 23, 54, 65, 86, 54, 48, 95], | ||||
|               yAxisIndex: 1, | ||||
|             }, | ||||
|           ], | ||||
|           dataZoom: [ | ||||
|             { | ||||
|               // 设置滚动条的隐藏与显示 | ||||
|               show: false, | ||||
|               // 设置滚动条类型 | ||||
|               type: "slider", | ||||
|               // 设置背景颜色 | ||||
|               backgroundColor: "rgba(225,225,225,0.2)", | ||||
|               // 设置选中范围的填充颜色 | ||||
|               fillerColor: "#ccc", | ||||
|               // 设置边框颜色 | ||||
|               borderColor: "rgba(225,225,225,0.2)", | ||||
|               // 是否显示detail,即拖拽时候显示详细数值信息 | ||||
|               showDetail: false, | ||||
|               // 数据窗口范围的起始数值 | ||||
|               startValue: 0, | ||||
|               // 数据窗口范围的结束数值(一页显示多少条数据) | ||||
|               endValue: 6, | ||||
|               // empty:当前数据窗口外的数据,被设置为空。 | ||||
|               // 即不会影响其他轴的数据范围 | ||||
|               filterMode: "empty", | ||||
|               // 设置滚动条宽度,相对于盒子宽度 | ||||
|               width: "80%", | ||||
|               // 设置滚动条高度 | ||||
|               height: 5, | ||||
|               // 设置滚动条显示位置 | ||||
|               left: "center", | ||||
|               // 是否锁定选择区域(或叫做数据窗口)的大小 | ||||
|               zoomLoxk: true, | ||||
|               // 控制手柄的尺寸 | ||||
|               handleSize: 10, | ||||
|               // dataZoom-slider组件离容器下侧的距离 | ||||
|               bottom: 0, | ||||
|             }, | ||||
|             { | ||||
|               // 没有下面这块的话,只能拖动滚动条, | ||||
|               // 鼠标滚轮在区域内不能控制外部滚动条 | ||||
|               type: "inside", | ||||
|               // 滚轮是否触发缩放 | ||||
|               zoomOnMouseWheel: false, | ||||
|               // 鼠标滚轮触发滚动 | ||||
|               moveOnMouseMove: true, | ||||
|               moveOnMouseWheel: true, | ||||
|             }, | ||||
|           ], | ||||
|         }); | ||||
|         window.addEventListener("resize", () => { | ||||
|           chart.resize(); | ||||
|         }); | ||||
|       } | ||||
|     }, | ||||
| 
 | ||||
|     /* 绘制病害分布柱状图 */ | ||||
|     drawDistributionChart() { | ||||
|       const xData = [ | ||||
| @ -359,6 +367,87 @@ export default { | ||||
|         }); | ||||
|       } | ||||
|     }, | ||||
| 
 | ||||
|     /* 绘制覆盖率饼图 */ | ||||
|     drawLeftChart() { | ||||
|       if (this.$refs.rateChart) { | ||||
|         const chart = echarts.init(this.$refs.rateChart); | ||||
|         const current = 45; | ||||
|         chart.setOption({ | ||||
|           // color: ['rgba(61, 137, 247, 1)', '#f07b3f'], | ||||
|           title: [ | ||||
|             // 中心比例 | ||||
|             { | ||||
|               text: "80%", | ||||
|               x: "center", | ||||
|               y: "52%", | ||||
|               textStyle: { | ||||
|                 fontSize: 20, | ||||
|                 color: "#444", | ||||
|                 fontWeight: "bold", | ||||
|               }, | ||||
|             }, | ||||
|             { | ||||
|               text: "覆盖率", | ||||
|               x: "center", | ||||
|               y: "10%", | ||||
|               textStyle: { | ||||
|                 fontSize: 14, | ||||
|               }, | ||||
|             }, | ||||
|           ], | ||||
|           polar: { | ||||
|             center: ["50%", "60%"], | ||||
|             radius: ["40%", "58%"], | ||||
|           }, | ||||
|           angleAxis: { | ||||
|             max: 100, | ||||
|             show: false, | ||||
|           }, | ||||
|           radiusAxis: { | ||||
|             type: "category", | ||||
|             show: true, | ||||
|             axisLabel: { | ||||
|               show: false, | ||||
|             }, | ||||
|             axisLine: { | ||||
|               show: false, | ||||
|             }, | ||||
|             axisTick: { | ||||
|               show: false, | ||||
|             }, | ||||
|           }, | ||||
|           series: [ | ||||
|             { | ||||
|               data: [80], | ||||
|               name: "", | ||||
|               type: "bar", | ||||
|               roundCap: true, | ||||
|               showBackground: true, | ||||
|               backgroundStyle: { | ||||
|                 color: "#BDD5F4", | ||||
|               }, | ||||
|               coordinateSystem: "polar", | ||||
|               itemStyle: { | ||||
|                 color: new echarts.graphic.LinearGradient(0, 1, 0, 0, [ | ||||
|                   { | ||||
|                     offset: 0, | ||||
|                     color: "#005DCF", | ||||
|                   }, | ||||
|                   { | ||||
|                     offset: 1, | ||||
|                     color: "#00CCFF", | ||||
|                   }, | ||||
|                 ]), | ||||
|               }, | ||||
|             }, | ||||
|           ], | ||||
|         }); | ||||
|         window.addEventListener("resize", () => { | ||||
|           chart.resize(); | ||||
|         }); | ||||
|       } | ||||
|     }, | ||||
|   }, | ||||
| }; | ||||
| </script> | ||||
| @ -394,7 +483,8 @@ export default { | ||||
|       background-size: 100%; | ||||
| 
 | ||||
|       .left-div { | ||||
|         height: 27.5%; | ||||
|         // height: 27.5%; | ||||
|         height: 50%; | ||||
|         width: calc(100% - 2rem); | ||||
|         margin: 0 1rem; | ||||
|         display: flex; | ||||
|  | ||||
| @ -13,11 +13,11 @@ | ||||
|     <div class="traffic-table"> | ||||
|       <el-table :data="trafficTableData" style="width: 100%" height="180"> | ||||
|         <el-table-column type="index" label="序号"></el-table-column> | ||||
|         <el-table-column prop="date" label="路线名称" > | ||||
|         </el-table-column> | ||||
|         <el-table-column prop="name" label="PCI" > </el-table-column> | ||||
|         <el-table-column prop="pci" label="PCI等级" > | ||||
|         </el-table-column> | ||||
|         <el-table-column prop="date" label="路线名称"> </el-table-column> | ||||
|         <el-table-column prop="name" label="路面病害数"> </el-table-column> | ||||
|         <el-table-column prop="pci" label="交安病害数"> </el-table-column> | ||||
|         <el-table-column prop="name" label="桥隧病害数"> </el-table-column> | ||||
|         <el-table-column prop="name" label="绿化病害数" > </el-table-column> | ||||
|       </el-table> | ||||
|     </div> | ||||
|     <div class="traffic-chart" ref="trafficChart"></div> | ||||
| @ -100,7 +100,18 @@ export default { | ||||
|           }, | ||||
|           xAxis: [ | ||||
|             { | ||||
|               data: ["1月", "2月", "3月", "4月", "5月", "6月", "7月", "8月", "9月", "10月"], | ||||
|               data: [ | ||||
|                 "1月", | ||||
|                 "2月", | ||||
|                 "3月", | ||||
|                 "4月", | ||||
|                 "5月", | ||||
|                 "6月", | ||||
|                 "7月", | ||||
|                 "8月", | ||||
|                 "9月", | ||||
|                 "10月", | ||||
|               ], | ||||
|               type: "category", | ||||
|               axisTick: { | ||||
|                 show: false, //隐藏X轴刻度 | ||||
|  | ||||
| @ -2,7 +2,7 @@ | ||||
|  * @Author: SunTao 328867980@qq.com | ||||
|  * @Date: 2024-10-08 09:26:24 | ||||
|  * @LastEditors: SunTao 328867980@qq.com | ||||
|  * @LastEditTime: 2024-11-06 10:50:32 | ||||
|  * @LastEditTime: 2024-11-15 11:16:08 | ||||
|  * @FilePath: \znxjxt-ui\src\views\index.vue | ||||
|  * @Description: 系统首页 | ||||
| --> | ||||
| @ -48,6 +48,7 @@ import DailyIndex from "./index-components/daily-index.vue"; | ||||
| import DiseaseIndex from "./index-components/disease-index.vue"; | ||||
| import RoadIndex from "./index-components/road-index.vue"; | ||||
| import TrafficIndex from "./index-components/traffic-index.vue"; | ||||
| import { getTotalCount } from "@/api/xj/index/index"; | ||||
| export default { | ||||
|   name: "Index", | ||||
|   components: { | ||||
| @ -69,12 +70,16 @@ export default { | ||||
|   methods: { | ||||
|     /* 获取顶栏数据 */ | ||||
|     getTopData() { | ||||
|       getTotalCount().then(({ code, data }) => { | ||||
|         if (code === 200) { | ||||
|           this.topList = [ | ||||
|         { name: "巡查总里程", value: 54, unit: "个" }, | ||||
|         { name: "现存病害总数", value: 54, unit: "个" }, | ||||
|         { name: "公路资产总数", value: 54, unit: "个" }, | ||||
|         { name: "交安事件总数", value: 54, unit: "个" }, | ||||
|             { name: "路面病害总数", value: data.road, unit: "个" }, | ||||
|             { name: "交安事件病害总数 ", value: data.event, unit: "个" }, | ||||
|             { name: "桥隧病害总数", value: data.bridge, unit: "个" }, | ||||
|             { name: "绿化病害总数", value: data.green, unit: "个" }, | ||||
|           ]; | ||||
|         } | ||||
|       }); | ||||
|     }, | ||||
|   }, | ||||
| }; | ||||
|  | ||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user