| 
									
										
										
										
											2024-10-18 17:31:35 +08:00
										 |  |  |  | <!-- | 
					
						
							|  |  |  |  |  * @Author: SunTao 328867980@qq.com | 
					
						
							|  |  |  |  |  * @Date: 2024-10-17 11:34:00 | 
					
						
							|  |  |  |  |  * @LastEditors: SunTao 328867980@qq.com | 
					
						
							| 
									
										
										
										
											2024-12-10 10:43:44 +08:00
										 |  |  |  |  * @LastEditTime: 2024-12-10 10:41:39 | 
					
						
							| 
									
										
										
										
											2024-10-18 17:31:35 +08:00
										 |  |  |  |  * @FilePath: \znxjxt-ui\src\views\big-screen\index.vue | 
					
						
							|  |  |  |  |  * @Description: 大屏首页 | 
					
						
							|  |  |  |  | --> | 
					
						
							|  |  |  |  | <template> | 
					
						
							|  |  |  |  |   <div class="screen-content"> | 
					
						
							|  |  |  |  |     <div class="screen-header"> | 
					
						
							| 
									
										
										
										
											2024-10-22 09:55:33 +08:00
										 |  |  |  |       <div class="header-weather"> | 
					
						
							| 
									
										
										
										
											2024-12-03 13:42:21 +08:00
										 |  |  |  |         <!-- <iframe | 
					
						
							| 
									
										
										
										
											2024-10-22 09:55:33 +08:00
										 |  |  |  |           width="150" | 
					
						
							|  |  |  |  |           scrolling="no" | 
					
						
							|  |  |  |  |           height="45" | 
					
						
							|  |  |  |  |           frameborder="0" | 
					
						
							|  |  |  |  |           allowtransparency="true" | 
					
						
							|  |  |  |  |           src="https://i.tianqi.com?c=code&id=12&icon=1&color=%2389C5E8&py=shenyang&num=1&site=12" | 
					
						
							| 
									
										
										
										
											2024-12-03 13:42:21 +08:00
										 |  |  |  |         ></iframe> --> | 
					
						
							| 
									
										
										
										
											2024-10-22 09:55:33 +08:00
										 |  |  |  |       </div> | 
					
						
							| 
									
										
										
										
											2024-10-18 17:31:35 +08:00
										 |  |  |  |       <div class="header-time"> | 
					
						
							| 
									
										
										
										
											2024-11-20 14:46:20 +08:00
										 |  |  |  |         <!-- 消息中心 --> | 
					
						
							|  |  |  |  |         <div class="header-news"> | 
					
						
							| 
									
										
										
										
											2024-12-09 15:35:13 +08:00
										 |  |  |  |           <el-popover | 
					
						
							|  |  |  |  |             placement="bottom-end" | 
					
						
							|  |  |  |  |             width="400" | 
					
						
							|  |  |  |  |             popper-class="screen-message-popover" | 
					
						
							|  |  |  |  |             trigger="hover" | 
					
						
							|  |  |  |  |           > | 
					
						
							| 
									
										
										
										
											2024-11-20 14:46:20 +08:00
										 |  |  |  |             <div class="screen-message-content"> | 
					
						
							|  |  |  |  |               <div class="message-content"> | 
					
						
							| 
									
										
										
										
											2024-12-09 15:35:13 +08:00
										 |  |  |  |                 <fssm-scroll style="max-height: 12rem"> | 
					
						
							|  |  |  |  |                   <div | 
					
						
							|  |  |  |  |                     class="message-item" | 
					
						
							|  |  |  |  |                     v-for="(item, index) in messageList" | 
					
						
							|  |  |  |  |                     :key="`message-item-${index}`" | 
					
						
							|  |  |  |  |                   > | 
					
						
							|  |  |  |  |                     <div | 
					
						
							|  |  |  |  |                       class="item-top" | 
					
						
							|  |  |  |  |                       @click="handleMessageItemClick(item.notificationType)" | 
					
						
							|  |  |  |  |                     > | 
					
						
							| 
									
										
										
										
											2024-11-20 14:46:20 +08:00
										 |  |  |  |                       <div class="index"> | 
					
						
							| 
									
										
										
										
											2024-12-05 17:25:06 +08:00
										 |  |  |  |                         <!-- <i v-if="item.title === '成功'" style="color: #67c23a" class="el-icon-success"></i> --> | 
					
						
							| 
									
										
										
										
											2024-12-09 15:35:13 +08:00
										 |  |  |  |                         <i | 
					
						
							|  |  |  |  |                           v-if="item.notificationType === 'REMIND'" | 
					
						
							|  |  |  |  |                           style="color: #e6a23c" | 
					
						
							|  |  |  |  |                           class="el-icon-info" | 
					
						
							|  |  |  |  |                         ></i> | 
					
						
							|  |  |  |  |                         <i | 
					
						
							|  |  |  |  |                           v-if="item.notificationType === 'WARNING'" | 
					
						
							|  |  |  |  |                           style="color: #909399" | 
					
						
							|  |  |  |  |                           class="el-icon-warning" | 
					
						
							|  |  |  |  |                         ></i> | 
					
						
							| 
									
										
										
										
											2024-12-05 17:25:06 +08:00
										 |  |  |  |                         <!-- <i v-if="item.title === '错误'" style="color: #f56c6c" class="el-icon-error"></i> --> | 
					
						
							| 
									
										
										
										
											2024-11-20 14:46:20 +08:00
										 |  |  |  |                       </div> | 
					
						
							|  |  |  |  |                       <div class="time"> | 
					
						
							| 
									
										
										
										
											2024-12-05 17:25:06 +08:00
										 |  |  |  |                         <span>{{ item.createdTime }}</span> | 
					
						
							| 
									
										
										
										
											2024-11-20 14:46:20 +08:00
										 |  |  |  |                       </div> | 
					
						
							|  |  |  |  |                       <div class="carNo"> | 
					
						
							| 
									
										
										
										
											2024-12-05 17:25:06 +08:00
										 |  |  |  |                         <span>{{ item.title }}</span> | 
					
						
							| 
									
										
										
										
											2024-11-20 14:46:20 +08:00
										 |  |  |  |                       </div> | 
					
						
							|  |  |  |  |                     </div> | 
					
						
							|  |  |  |  |                     <div class="item-content"> | 
					
						
							|  |  |  |  |                       {{ item.content }} | 
					
						
							|  |  |  |  |                     </div> | 
					
						
							|  |  |  |  |                   </div> | 
					
						
							|  |  |  |  |                 </fssm-scroll> | 
					
						
							|  |  |  |  |               </div> | 
					
						
							|  |  |  |  |               <div class="message-footer"> | 
					
						
							| 
									
										
										
										
											2024-12-09 15:35:13 +08:00
										 |  |  |  |                 <el-button | 
					
						
							|  |  |  |  |                   @click="handleMessageClick" | 
					
						
							|  |  |  |  |                   icon="el-icon-d-arrow-right" | 
					
						
							|  |  |  |  |                   type="text" | 
					
						
							|  |  |  |  |                   >查看更多</el-button | 
					
						
							|  |  |  |  |                 > | 
					
						
							| 
									
										
										
										
											2024-11-20 14:46:20 +08:00
										 |  |  |  |               </div> | 
					
						
							|  |  |  |  |             </div> | 
					
						
							|  |  |  |  |             <i slot="reference" class="el-icon-message-solid"> | 
					
						
							| 
									
										
										
										
											2024-12-05 17:25:06 +08:00
										 |  |  |  |               <div class="num">{{ noticeNum }}</div> | 
					
						
							| 
									
										
										
										
											2024-11-20 14:46:20 +08:00
										 |  |  |  |             </i> | 
					
						
							|  |  |  |  |           </el-popover> | 
					
						
							|  |  |  |  |         </div> | 
					
						
							| 
									
										
										
										
											2024-10-18 17:31:35 +08:00
										 |  |  |  |         <div class="header-data">{{ dataTime }}</div> | 
					
						
							|  |  |  |  |         <div class="header-week"> | 
					
						
							|  |  |  |  |           <span>{{ weekTime }}</span> | 
					
						
							|  |  |  |  |           <span>{{ yearTime }}</span> | 
					
						
							|  |  |  |  |         </div> | 
					
						
							|  |  |  |  |         <div class="header-home"> | 
					
						
							| 
									
										
										
										
											2024-10-22 09:55:33 +08:00
										 |  |  |  |           <div class="home" @click="goIndex"></div> | 
					
						
							| 
									
										
										
										
											2024-10-18 17:31:35 +08:00
										 |  |  |  |         </div> | 
					
						
							|  |  |  |  |       </div> | 
					
						
							|  |  |  |  |     </div> | 
					
						
							|  |  |  |  |     <div class="screen-middle"> | 
					
						
							|  |  |  |  |       <div class="screen-left"> | 
					
						
							| 
									
										
										
										
											2024-12-09 15:35:13 +08:00
										 |  |  |  |         <module-block | 
					
						
							|  |  |  |  |           v-for="(item, index) in leftModuleList" | 
					
						
							|  |  |  |  |           :key="`left-module-list-${index}`" | 
					
						
							|  |  |  |  |           :width="item.width" | 
					
						
							|  |  |  |  |           :height="item.height" | 
					
						
							|  |  |  |  |           :title="item.title" | 
					
						
							|  |  |  |  |           :class="item.class" | 
					
						
							|  |  |  |  |         > | 
					
						
							| 
									
										
										
										
											2024-12-05 17:25:06 +08:00
										 |  |  |  |           <template> | 
					
						
							| 
									
										
										
										
											2024-12-09 15:35:13 +08:00
										 |  |  |  |             <component | 
					
						
							|  |  |  |  |               :select="item.select" | 
					
						
							|  |  |  |  |               :is="item.component" | 
					
						
							|  |  |  |  |               :bottomTipClick="bottomTipClick" | 
					
						
							|  |  |  |  |             ></component> | 
					
						
							| 
									
										
										
										
											2024-12-05 17:25:06 +08:00
										 |  |  |  |           </template> | 
					
						
							| 
									
										
										
										
											2024-10-22 09:55:33 +08:00
										 |  |  |  |           <template slot="operation" v-if="item.selectIsShow"> | 
					
						
							|  |  |  |  |             <el-radio-group class="screen-checkBox" v-model="item.select"> | 
					
						
							| 
									
										
										
										
											2024-12-09 15:35:13 +08:00
										 |  |  |  |               <el-radio-button | 
					
						
							|  |  |  |  |                 v-for="(item, index) in selectTypeArr" | 
					
						
							|  |  |  |  |                 :label="item.value" | 
					
						
							|  |  |  |  |                 :key="`left-screen-${index}`" | 
					
						
							|  |  |  |  |                 >{{ item.label }}</el-radio-button | 
					
						
							|  |  |  |  |               > | 
					
						
							| 
									
										
										
										
											2024-10-22 09:55:33 +08:00
										 |  |  |  |             </el-radio-group> | 
					
						
							|  |  |  |  |           </template> | 
					
						
							| 
									
										
										
										
											2024-10-18 17:31:35 +08:00
										 |  |  |  |         </module-block> | 
					
						
							|  |  |  |  |       </div> | 
					
						
							|  |  |  |  |       <div class="screen-right"> | 
					
						
							| 
									
										
										
										
											2024-12-09 15:35:13 +08:00
										 |  |  |  |         <module-block | 
					
						
							|  |  |  |  |           v-for="(item, index) in rightModuleList" | 
					
						
							|  |  |  |  |           :key="`right-module-list-${index}`" | 
					
						
							|  |  |  |  |           :width="item.width" | 
					
						
							|  |  |  |  |           :height="item.height" | 
					
						
							|  |  |  |  |           :title="item.title" | 
					
						
							|  |  |  |  |           :class="item.class" | 
					
						
							|  |  |  |  |         > | 
					
						
							| 
									
										
										
										
											2024-12-05 17:25:06 +08:00
										 |  |  |  |           <template> | 
					
						
							| 
									
										
										
										
											2024-12-09 15:35:13 +08:00
										 |  |  |  |             <component | 
					
						
							|  |  |  |  |               :select="item.select" | 
					
						
							|  |  |  |  |               :is="item.component" | 
					
						
							|  |  |  |  |               :bottomTipClick="bottomTipClick" | 
					
						
							|  |  |  |  |               @imagePoint="getimagePoint" | 
					
						
							|  |  |  |  |             ></component> | 
					
						
							| 
									
										
										
										
											2024-12-05 17:25:06 +08:00
										 |  |  |  |           </template> | 
					
						
							| 
									
										
										
										
											2024-10-22 09:55:33 +08:00
										 |  |  |  |           <template slot="operation" v-if="item.selectIsShow"> | 
					
						
							|  |  |  |  |             <el-radio-group class="screen-checkBox" v-model="item.select"> | 
					
						
							| 
									
										
										
										
											2024-12-09 15:35:13 +08:00
										 |  |  |  |               <el-radio-button | 
					
						
							|  |  |  |  |                 v-for="(item, index) in selectTypeArr" | 
					
						
							|  |  |  |  |                 :label="item.value" | 
					
						
							|  |  |  |  |                 :key="`right-screen-${index}`" | 
					
						
							|  |  |  |  |                 >{{ item.label }}</el-radio-button | 
					
						
							|  |  |  |  |               > | 
					
						
							| 
									
										
										
										
											2024-10-22 09:55:33 +08:00
										 |  |  |  |             </el-radio-group> | 
					
						
							|  |  |  |  |           </template> | 
					
						
							| 
									
										
										
										
											2024-10-18 17:31:35 +08:00
										 |  |  |  |         </module-block> | 
					
						
							|  |  |  |  |       </div> | 
					
						
							| 
									
										
										
										
											2024-10-23 17:17:37 +08:00
										 |  |  |  |       <div class="road-content"> | 
					
						
							| 
									
										
										
										
											2024-11-11 14:40:40 +08:00
										 |  |  |  |         <!-- 地图右上角多选框切换坐标类型 --> | 
					
						
							| 
									
										
										
										
											2024-11-14 17:43:24 +08:00
										 |  |  |  |         <div class="road-checkBox" v-if="showIconList"> | 
					
						
							| 
									
										
										
										
											2024-10-23 17:17:37 +08:00
										 |  |  |  |           <fssm-scroll class="road-scroll"> | 
					
						
							|  |  |  |  |             <el-checkbox-group v-model="iconType" @change="handleChecked"> | 
					
						
							| 
									
										
										
										
											2024-12-09 15:35:13 +08:00
										 |  |  |  |               <el-checkbox | 
					
						
							|  |  |  |  |                 v-for="(item, index) in iconTypeList" | 
					
						
							|  |  |  |  |                 :label="item.value" | 
					
						
							|  |  |  |  |                 :key="`check-${index}`" | 
					
						
							|  |  |  |  |                 >{{ item.label }}</el-checkbox | 
					
						
							|  |  |  |  |               > | 
					
						
							| 
									
										
										
										
											2024-10-23 17:17:37 +08:00
										 |  |  |  |             </el-checkbox-group> | 
					
						
							|  |  |  |  |           </fssm-scroll> | 
					
						
							| 
									
										
										
										
											2024-11-14 17:43:24 +08:00
										 |  |  |  |         </div> | 
					
						
							| 
									
										
										
										
											2024-11-11 14:40:40 +08:00
										 |  |  |  |         <!-- 地图图例 --> | 
					
						
							|  |  |  |  |         <div class="map-legend"></div> | 
					
						
							| 
									
										
										
										
											2024-10-23 17:17:37 +08:00
										 |  |  |  |         <!-- 图片背景 --> | 
					
						
							| 
									
										
										
										
											2024-11-11 14:40:40 +08:00
										 |  |  |  |         <div class="disease-content" v-if="elementDiv === 'OverviewScreen'"> | 
					
						
							| 
									
										
										
										
											2024-10-28 10:00:28 +08:00
										 |  |  |  |           <div class="disease-title"></div> | 
					
						
							| 
									
										
										
										
											2024-11-11 14:40:40 +08:00
										 |  |  |  |           <!-- 图背景下选择框 --> | 
					
						
							|  |  |  |  |           <div class="map-image-select"> | 
					
						
							|  |  |  |  |             病害类型筛选: | 
					
						
							| 
									
										
										
										
											2024-12-09 15:35:13 +08:00
										 |  |  |  |             <el-cascader | 
					
						
							|  |  |  |  |               v-model="mapCareSelect" | 
					
						
							|  |  |  |  |               popper-class="screen-index-cascader" | 
					
						
							|  |  |  |  |               :options="dieaseOptions" | 
					
						
							|  |  |  |  |               :props="{ | 
					
						
							|  |  |  |  |                 checkStrictly: true, | 
					
						
							|  |  |  |  |                 emitPath: true, | 
					
						
							|  |  |  |  |                 children: 'subTypes', | 
					
						
							|  |  |  |  |               }" | 
					
						
							|  |  |  |  |               @change="getMapCare" | 
					
						
							|  |  |  |  |               clearable | 
					
						
							|  |  |  |  |             ></el-cascader> | 
					
						
							| 
									
										
										
										
											2024-11-11 14:40:40 +08:00
										 |  |  |  |           </div> | 
					
						
							| 
									
										
										
										
											2024-10-25 17:29:08 +08:00
										 |  |  |  |           <div class="map-care"> | 
					
						
							| 
									
										
										
										
											2024-12-09 15:35:13 +08:00
										 |  |  |  |             <div | 
					
						
							|  |  |  |  |               class="map-care-div" | 
					
						
							|  |  |  |  |               :class="`map-care-div-${item.status}`" | 
					
						
							|  |  |  |  |               v-for="(item, index) in mapCareList" | 
					
						
							|  |  |  |  |               :key="`map-care-${index}`" | 
					
						
							|  |  |  |  |               :style="{ left: item.left, top: item.top }" | 
					
						
							|  |  |  |  |             > | 
					
						
							| 
									
										
										
										
											2024-11-11 14:40:40 +08:00
										 |  |  |  |               <span>{{ item.name }}</span> | 
					
						
							| 
									
										
										
										
											2024-10-28 10:00:28 +08:00
										 |  |  |  |             </div> | 
					
						
							| 
									
										
										
										
											2024-10-25 17:29:08 +08:00
										 |  |  |  |           </div> | 
					
						
							| 
									
										
										
										
											2024-10-23 17:17:37 +08:00
										 |  |  |  |         </div> | 
					
						
							|  |  |  |  |         <!-- 地图 --> | 
					
						
							| 
									
										
										
										
											2024-12-09 15:35:13 +08:00
										 |  |  |  |         <fssm-map | 
					
						
							|  |  |  |  |           v-if="elementDiv !== 'OverviewScreen'" | 
					
						
							|  |  |  |  |           ref="roadMap" | 
					
						
							|  |  |  |  |           :showChange="true" | 
					
						
							|  |  |  |  |           :controlStyle="{ top: '10%', left: '26%' }" | 
					
						
							|  |  |  |  |           @feature-select="featureSelect" | 
					
						
							|  |  |  |  |           @map-zoom="getZoom" | 
					
						
							|  |  |  |  |         ></fssm-map> | 
					
						
							| 
									
										
										
										
											2024-11-14 17:43:24 +08:00
										 |  |  |  |         <!-- @map-moveend="mapMoveend" --> | 
					
						
							| 
									
										
										
										
											2024-10-23 17:17:37 +08:00
										 |  |  |  |       </div> | 
					
						
							| 
									
										
										
										
											2024-10-18 17:31:35 +08:00
										 |  |  |  |     </div> | 
					
						
							|  |  |  |  |     <div class="screen-footer"> | 
					
						
							| 
									
										
										
										
											2024-11-11 14:40:40 +08:00
										 |  |  |  |       <!-- 病害巡检4种类型按钮 --> | 
					
						
							| 
									
										
										
										
											2024-10-18 17:31:35 +08:00
										 |  |  |  |       <div class="footer-change-map"> | 
					
						
							| 
									
										
										
										
											2024-11-11 14:40:40 +08:00
										 |  |  |  |         <template v-if="elementDiv === 'DiseaseScreen'"> | 
					
						
							| 
									
										
										
										
											2024-12-09 15:35:13 +08:00
										 |  |  |  |           <div | 
					
						
							|  |  |  |  |             class="change-map-div" | 
					
						
							|  |  |  |  |             :class="bottomTipClick === item.click ? 'change-map-click' : ''" | 
					
						
							|  |  |  |  |             v-for="(item, index) in changeMapBtn" | 
					
						
							|  |  |  |  |             :key="`btn-${index}`" | 
					
						
							|  |  |  |  |             @click="changeIconType(item.click)" | 
					
						
							|  |  |  |  |           > | 
					
						
							| 
									
										
										
										
											2024-10-22 09:55:33 +08:00
										 |  |  |  |             {{ item.name }} | 
					
						
							|  |  |  |  |           </div> | 
					
						
							|  |  |  |  |         </template> | 
					
						
							| 
									
										
										
										
											2024-10-18 17:31:35 +08:00
										 |  |  |  |       </div> | 
					
						
							| 
									
										
										
										
											2024-11-11 14:40:40 +08:00
										 |  |  |  |       <!-- 切换3种导航栏按钮 --> | 
					
						
							| 
									
										
										
										
											2024-10-18 17:31:35 +08:00
										 |  |  |  |       <div class="footer-change-vue"> | 
					
						
							| 
									
										
										
										
											2024-12-09 15:35:13 +08:00
										 |  |  |  |         <div | 
					
						
							|  |  |  |  |           :class=" | 
					
						
							|  |  |  |  |             elementDiv === item.component | 
					
						
							|  |  |  |  |               ? `change-vue-click-${item.component}` | 
					
						
							|  |  |  |  |               : `change-vue-${item.component}` | 
					
						
							|  |  |  |  |           " | 
					
						
							|  |  |  |  |           v-for="(item, index) in elementList" | 
					
						
							|  |  |  |  |           :key="`footer-${index}`" | 
					
						
							|  |  |  |  |           @click="changeElement(item)" | 
					
						
							|  |  |  |  |         ></div> | 
					
						
							| 
									
										
										
										
											2024-10-18 17:31:35 +08:00
										 |  |  |  |       </div> | 
					
						
							|  |  |  |  |     </div> | 
					
						
							| 
									
										
										
										
											2024-11-14 17:43:24 +08:00
										 |  |  |  |     <!-- 详情图片弹窗 --> | 
					
						
							| 
									
										
										
										
											2024-12-09 15:35:13 +08:00
										 |  |  |  |     <el-dialog | 
					
						
							|  |  |  |  |       :title="imgTitle" | 
					
						
							|  |  |  |  |       :visible.sync="imgVisible" | 
					
						
							|  |  |  |  |       width="95rem" | 
					
						
							|  |  |  |  |       append-to-body | 
					
						
							|  |  |  |  |       fullscreen | 
					
						
							|  |  |  |  |       :close-on-click-modal="false" | 
					
						
							|  |  |  |  |       destroy-on-close | 
					
						
							|  |  |  |  |       @close="imgCancel" | 
					
						
							|  |  |  |  |     > | 
					
						
							|  |  |  |  |       <img-dialog | 
					
						
							|  |  |  |  |         v-if="imgTitle === '查看'" | 
					
						
							|  |  |  |  |         :imageItem="imageItem" | 
					
						
							|  |  |  |  |         :bottomTipClick="bottomTipClick" | 
					
						
							|  |  |  |  |       ></img-dialog> | 
					
						
							| 
									
										
										
										
											2024-10-23 17:17:37 +08:00
										 |  |  |  |     </el-dialog> | 
					
						
							| 
									
										
										
										
											2024-11-07 12:04:16 +08:00
										 |  |  |  | 
 | 
					
						
							|  |  |  |  |     <!-- 查看点位图片弹窗 --> | 
					
						
							| 
									
										
										
										
											2024-12-09 15:35:13 +08:00
										 |  |  |  |     <el-dialog | 
					
						
							|  |  |  |  |       title="查看点位" | 
					
						
							|  |  |  |  |       :visible.sync="showImageDialog" | 
					
						
							|  |  |  |  |       width="90rem" | 
					
						
							|  |  |  |  |       append-to-body | 
					
						
							|  |  |  |  |       :close-on-click-modal="false" | 
					
						
							|  |  |  |  |       destroy-on-close | 
					
						
							|  |  |  |  |       @close="screenImgCancel" | 
					
						
							|  |  |  |  |     > | 
					
						
							| 
									
										
										
										
											2024-11-11 14:40:40 +08:00
										 |  |  |  |       <div class="view-image-container" ref="imageContainer"> | 
					
						
							| 
									
										
										
										
											2024-12-09 15:35:13 +08:00
										 |  |  |  |         <img | 
					
						
							|  |  |  |  |           :src="screenImage.imageUrl" | 
					
						
							|  |  |  |  |           alt="Main Image" | 
					
						
							|  |  |  |  |           ref="mainImage" | 
					
						
							|  |  |  |  |           @load="updateScreenRects" | 
					
						
							|  |  |  |  |         /> | 
					
						
							|  |  |  |  |         <div | 
					
						
							|  |  |  |  |           v-for="(rect, index) in screenRects" | 
					
						
							|  |  |  |  |           :key="index" | 
					
						
							|  |  |  |  |           class="rect-overlay" | 
					
						
							|  |  |  |  |           :style="getScreenRectStyle(rect)" | 
					
						
							|  |  |  |  |         ></div> | 
					
						
							| 
									
										
										
										
											2024-11-19 14:18:57 +08:00
										 |  |  |  |         <div class="rect-image"> | 
					
						
							|  |  |  |  |           采集时间: | 
					
						
							|  |  |  |  |           {{ screenImage.createTime }} 起始桩号: | 
					
						
							|  |  |  |  |           {{ screenImage.stakeStart || "暂无数据" }} 终止桩号: | 
					
						
							|  |  |  |  |           {{ screenImage.stakeEnd || "暂无数据" }} | 
					
						
							|  |  |  |  |           {{ `${this.elementDiv === "RoadScreen" ? "路产" : "病害"}类型:` }} | 
					
						
							|  |  |  |  |           {{ screenImage.iconTypeName || "暂无数据" }} | 
					
						
							|  |  |  |  |           <span v-if="this.elementDiv === 'DiseaseScreen'"> | 
					
						
							|  |  |  |  |             病害面积:{{ screenImage.targetArea }}平方米 病害长度:{{ | 
					
						
							| 
									
										
										
										
											2024-12-09 15:35:13 +08:00
										 |  |  |  |               screenImage.targetLen * 1 <= 0 | 
					
						
							|  |  |  |  |                 ? "暂无数据" | 
					
						
							|  |  |  |  |                 : `${screenImage.targetLen}米` | 
					
						
							|  |  |  |  |             }} | 
					
						
							|  |  |  |  |           </span> | 
					
						
							| 
									
										
										
										
											2024-11-19 14:18:57 +08:00
										 |  |  |  |         </div> | 
					
						
							| 
									
										
										
										
											2024-11-07 12:04:16 +08:00
										 |  |  |  |       </div> | 
					
						
							|  |  |  |  |     </el-dialog> | 
					
						
							| 
									
										
										
										
											2024-10-18 17:31:35 +08:00
										 |  |  |  |   </div> | 
					
						
							|  |  |  |  | </template> | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  | <script> | 
					
						
							| 
									
										
										
										
											2024-10-23 17:17:37 +08:00
										 |  |  |  | // 地图
 | 
					
						
							|  |  |  |  | import FssmMap from "@/components/map/fssm-map.vue"; | 
					
						
							|  |  |  |  | import { Feature } from "ol"; | 
					
						
							|  |  |  |  | import { Point } from "ol/geom"; | 
					
						
							|  |  |  |  | import { Style, Icon, Fill, Stroke, Circle, Text } from "ol/style"; | 
					
						
							|  |  |  |  | import VectorSource from "ol/source/Vector"; | 
					
						
							|  |  |  |  | import VectorLayer from "ol/layer/Vector"; | 
					
						
							|  |  |  |  | import * as geomExports from "ol/geom"; | 
					
						
							|  |  |  |  | import Cluster from "ol/source/Cluster"; | 
					
						
							| 
									
										
										
										
											2024-11-29 17:59:17 +08:00
										 |  |  |  | import logo from "@/assets/xc.png"; | 
					
						
							| 
									
										
										
										
											2024-10-23 17:17:37 +08:00
										 |  |  |  | // 组件
 | 
					
						
							| 
									
										
										
										
											2024-10-18 17:31:35 +08:00
										 |  |  |  | import ModuleBlock from "./module-block.vue"; | 
					
						
							| 
									
										
										
										
											2024-11-11 14:40:40 +08:00
										 |  |  |  | import TodayInspection from "./overview-components/today-inspection.vue"; | 
					
						
							|  |  |  |  | import DiseaseTrends from "./overview-components/disease-trends.vue"; | 
					
						
							|  |  |  |  | import DiseaseCurrent from "./overview-components/disease-current.vue"; | 
					
						
							|  |  |  |  | import PatrolOrder from "./overview-components/patrol-order.vue"; | 
					
						
							|  |  |  |  | import InspectionVehicles from "./overview-components/inspection-vehicles.vue"; | 
					
						
							| 
									
										
										
										
											2024-10-18 17:31:35 +08:00
										 |  |  |  | import RoadStatistic from "./road-components/road-statistic.vue"; | 
					
						
							|  |  |  |  | import ManageMaintain from "./road-components/manage-maintain.vue"; | 
					
						
							|  |  |  |  | import AnomalyFacilities from "./road-components/anomaly-facilities"; | 
					
						
							|  |  |  |  | import AncillaryFacilities from "./road-components/ancillary-facilities.vue"; | 
					
						
							| 
									
										
										
										
											2024-11-11 14:40:40 +08:00
										 |  |  |  | import TrafficSafety from "./disease-components/traffic-safety.vue"; | 
					
						
							|  |  |  |  | import TrafficTrend from "./disease-components/traffic-trend.vue"; | 
					
						
							|  |  |  |  | import TrafficStatistic from "./disease-components/traffic-statistic.vue"; | 
					
						
							|  |  |  |  | import TrafficLog from "./disease-components/traffic-log.vue"; | 
					
						
							| 
									
										
										
										
											2024-10-23 17:17:37 +08:00
										 |  |  |  | import ImgDialog from "./components/img-dialog.vue"; | 
					
						
							|  |  |  |  | import FssmScroll from "@/components/scroll/fssm-scroll.vue"; | 
					
						
							| 
									
										
										
										
											2024-10-25 17:29:08 +08:00
										 |  |  |  | // 接口
 | 
					
						
							| 
									
										
										
										
											2024-10-29 09:45:49 +08:00
										 |  |  |  | import { | 
					
						
							|  |  |  |  |   selectTypeList, | 
					
						
							|  |  |  |  |   mapPointList, | 
					
						
							|  |  |  |  |   mapPciList, | 
					
						
							| 
									
										
										
										
											2024-10-31 14:39:01 +08:00
										 |  |  |  |   comppanyImg, | 
					
						
							| 
									
										
										
										
											2024-11-01 13:15:24 +08:00
										 |  |  |  |   getItemTypes, | 
					
						
							| 
									
										
										
										
											2024-11-07 12:04:16 +08:00
										 |  |  |  |   getRoadListTypes, | 
					
						
							| 
									
										
										
										
											2024-11-18 13:49:59 +08:00
										 |  |  |  |   getDefectTypes, | 
					
						
							| 
									
										
										
										
											2024-12-05 17:25:06 +08:00
										 |  |  |  |   getNoticeList, | 
					
						
							| 
									
										
										
										
											2024-10-29 09:45:49 +08:00
										 |  |  |  | } from "@/api/xj/screen/index"; | 
					
						
							| 
									
										
										
										
											2024-10-18 17:31:35 +08:00
										 |  |  |  | export default { | 
					
						
							|  |  |  |  |   name: "BigScreen", | 
					
						
							|  |  |  |  |   components: { | 
					
						
							| 
									
										
										
										
											2024-10-23 17:17:37 +08:00
										 |  |  |  |     FssmMap, | 
					
						
							| 
									
										
										
										
											2024-10-18 17:31:35 +08:00
										 |  |  |  |     ModuleBlock, | 
					
						
							|  |  |  |  |     TodayInspection, | 
					
						
							|  |  |  |  |     DiseaseTrends, | 
					
						
							|  |  |  |  |     DiseaseCurrent, | 
					
						
							| 
									
										
										
										
											2024-11-11 14:40:40 +08:00
										 |  |  |  |     PatrolOrder, | 
					
						
							|  |  |  |  |     InspectionVehicles, | 
					
						
							| 
									
										
										
										
											2024-10-18 17:31:35 +08:00
										 |  |  |  |     RoadStatistic, | 
					
						
							|  |  |  |  |     ManageMaintain, | 
					
						
							|  |  |  |  |     AnomalyFacilities, | 
					
						
							|  |  |  |  |     AncillaryFacilities, | 
					
						
							| 
									
										
										
										
											2024-10-22 09:55:33 +08:00
										 |  |  |  |     TrafficSafety, | 
					
						
							|  |  |  |  |     TrafficTrend, | 
					
						
							|  |  |  |  |     TrafficStatistic, | 
					
						
							| 
									
										
										
										
											2024-10-23 17:17:37 +08:00
										 |  |  |  |     ImgDialog, | 
					
						
							|  |  |  |  |     FssmScroll, | 
					
						
							| 
									
										
										
										
											2024-11-11 14:40:40 +08:00
										 |  |  |  |     TrafficLog, | 
					
						
							| 
									
										
										
										
											2024-10-18 17:31:35 +08:00
										 |  |  |  |   }, | 
					
						
							|  |  |  |  |   data() { | 
					
						
							|  |  |  |  |     return { | 
					
						
							|  |  |  |  |       // 计时器标识
 | 
					
						
							|  |  |  |  |       timeFlag: null, | 
					
						
							|  |  |  |  |       // 时间
 | 
					
						
							|  |  |  |  |       dataTime: "", | 
					
						
							|  |  |  |  |       // 星期
 | 
					
						
							|  |  |  |  |       weekTime: "", | 
					
						
							|  |  |  |  |       // 年
 | 
					
						
							|  |  |  |  |       yearTime: "", | 
					
						
							| 
									
										
										
										
											2024-11-20 14:46:20 +08:00
										 |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-12-05 17:25:06 +08:00
										 |  |  |  |       // 预警中心数据条数
 | 
					
						
							|  |  |  |  |       noticeNum: 0, | 
					
						
							| 
									
										
										
										
											2024-11-20 14:46:20 +08:00
										 |  |  |  |       // 预警中心消息数据
 | 
					
						
							|  |  |  |  |       messageList: [], | 
					
						
							| 
									
										
										
										
											2024-12-05 17:25:06 +08:00
										 |  |  |  |       // 预警中心定时器
 | 
					
						
							|  |  |  |  |       messageTimer: null, | 
					
						
							| 
									
										
										
										
											2024-11-20 14:46:20 +08:00
										 |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-10-25 17:29:08 +08:00
										 |  |  |  |       // 数据栏右上角选择框
 | 
					
						
							|  |  |  |  |       selectTypeArr: [], | 
					
						
							| 
									
										
										
										
											2024-10-18 17:31:35 +08:00
										 |  |  |  |       // 左侧切换模块
 | 
					
						
							|  |  |  |  |       leftModuleList: [ | 
					
						
							|  |  |  |  |         { | 
					
						
							|  |  |  |  |           width: "100%", | 
					
						
							| 
									
										
										
										
											2024-10-31 14:39:01 +08:00
										 |  |  |  |           height: "27%", | 
					
						
							| 
									
										
										
										
											2024-10-22 09:55:33 +08:00
										 |  |  |  |           title: "今日巡查", | 
					
						
							|  |  |  |  |           component: TodayInspection, | 
					
						
							| 
									
										
										
										
											2024-10-18 17:31:35 +08:00
										 |  |  |  |           selectIsShow: false, | 
					
						
							|  |  |  |  |           class: "one", | 
					
						
							|  |  |  |  |         }, | 
					
						
							|  |  |  |  |         { | 
					
						
							|  |  |  |  |           width: "100%", | 
					
						
							| 
									
										
										
										
											2024-10-31 14:39:01 +08:00
										 |  |  |  |           height: "27%", | 
					
						
							| 
									
										
										
										
											2024-11-26 16:26:39 +08:00
										 |  |  |  |           title: "主要病害趋势", | 
					
						
							| 
									
										
										
										
											2024-10-22 09:55:33 +08:00
										 |  |  |  |           component: DiseaseTrends, | 
					
						
							| 
									
										
										
										
											2024-10-18 17:31:35 +08:00
										 |  |  |  |           selectIsShow: false, | 
					
						
							|  |  |  |  |           class: "twe", | 
					
						
							|  |  |  |  |         }, | 
					
						
							| 
									
										
										
										
											2024-10-22 09:55:33 +08:00
										 |  |  |  |         { | 
					
						
							|  |  |  |  |           width: "100%", | 
					
						
							| 
									
										
										
										
											2024-10-31 14:39:01 +08:00
										 |  |  |  |           height: "29%", | 
					
						
							| 
									
										
										
										
											2024-11-13 15:37:25 +08:00
										 |  |  |  |           title: "病害统计", | 
					
						
							| 
									
										
										
										
											2024-10-22 09:55:33 +08:00
										 |  |  |  |           component: DiseaseCurrent, | 
					
						
							|  |  |  |  |           selectIsShow: true, | 
					
						
							| 
									
										
										
										
											2024-10-25 17:29:08 +08:00
										 |  |  |  |           select: "", | 
					
						
							| 
									
										
										
										
											2024-10-22 09:55:33 +08:00
										 |  |  |  |           class: "twe", | 
					
						
							|  |  |  |  |         }, | 
					
						
							| 
									
										
										
										
											2024-10-18 17:31:35 +08:00
										 |  |  |  |       ], | 
					
						
							|  |  |  |  |       // 右侧切换模块
 | 
					
						
							|  |  |  |  |       rightModuleList: [ | 
					
						
							|  |  |  |  |         { | 
					
						
							|  |  |  |  |           width: "100%", | 
					
						
							| 
									
										
										
										
											2024-11-13 15:37:25 +08:00
										 |  |  |  |           height: "18%", | 
					
						
							| 
									
										
										
										
											2024-11-11 14:40:40 +08:00
										 |  |  |  |           title: "巡查里程", | 
					
						
							|  |  |  |  |           component: PatrolOrder, | 
					
						
							| 
									
										
										
										
											2024-10-18 17:31:35 +08:00
										 |  |  |  |           selectIsShow: false, | 
					
						
							|  |  |  |  |           class: "one", | 
					
						
							|  |  |  |  |         }, | 
					
						
							|  |  |  |  |         { | 
					
						
							|  |  |  |  |           width: "100%", | 
					
						
							| 
									
										
										
										
											2024-11-13 15:37:25 +08:00
										 |  |  |  |           height: "65%", | 
					
						
							| 
									
										
										
										
											2024-11-11 14:40:40 +08:00
										 |  |  |  |           title: "巡检车辆", | 
					
						
							|  |  |  |  |           component: InspectionVehicles, | 
					
						
							| 
									
										
										
										
											2024-10-18 17:31:35 +08:00
										 |  |  |  |           selectIsShow: false, | 
					
						
							|  |  |  |  |           class: "twe", | 
					
						
							|  |  |  |  |         }, | 
					
						
							|  |  |  |  |       ], | 
					
						
							| 
									
										
										
										
											2024-10-28 10:00:28 +08:00
										 |  |  |  |       // 图片背景下打点坐标数据
 | 
					
						
							|  |  |  |  |       mapCareList: [], | 
					
						
							| 
									
										
										
										
											2024-11-14 17:43:24 +08:00
										 |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-11-07 12:04:16 +08:00
										 |  |  |  |       // 具体icon类别
 | 
					
						
							| 
									
										
										
										
											2024-10-23 17:17:37 +08:00
										 |  |  |  |       iconTypeList: [], | 
					
						
							|  |  |  |  |       // icon类别绑定
 | 
					
						
							|  |  |  |  |       iconType: [], | 
					
						
							| 
									
										
										
										
											2024-11-14 17:43:24 +08:00
										 |  |  |  |       // 地图右上角多选显隐控制
 | 
					
						
							|  |  |  |  |       showIconList: false, | 
					
						
							|  |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-11-11 14:40:40 +08:00
										 |  |  |  |       // 图片背景下病害类型下拉选择绑定
 | 
					
						
							|  |  |  |  |       mapCareSelect: "", | 
					
						
							|  |  |  |  |       // 图片背景下病害类型下拉选择数据
 | 
					
						
							| 
									
										
										
										
											2024-11-20 14:46:20 +08:00
										 |  |  |  |       dieaseOptions: [], | 
					
						
							| 
									
										
										
										
											2024-11-07 12:04:16 +08:00
										 |  |  |  |       // 路段下拉绑定
 | 
					
						
							|  |  |  |  |       roadList: [], | 
					
						
							| 
									
										
										
										
											2024-11-14 17:43:24 +08:00
										 |  |  |  |       // 地图打点-路段绑定
 | 
					
						
							| 
									
										
										
										
											2024-11-07 12:04:16 +08:00
										 |  |  |  |       roadSelect: "", | 
					
						
							| 
									
										
										
										
											2024-11-14 17:43:24 +08:00
										 |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-10-23 17:17:37 +08:00
										 |  |  |  |       // 图标类别切换标识
 | 
					
						
							| 
									
										
										
										
											2024-11-11 14:40:40 +08:00
										 |  |  |  |       bottomTipClick: "1", | 
					
						
							| 
									
										
										
										
											2024-11-14 17:43:24 +08:00
										 |  |  |  |       // 切换地图图标类别按钮
 | 
					
						
							|  |  |  |  |       changeMapBtn: [ | 
					
						
							|  |  |  |  |         { name: "路面", click: "1" }, | 
					
						
							|  |  |  |  |         { name: "交安", click: "2" }, | 
					
						
							|  |  |  |  |         { name: "桥隧", click: "3" }, | 
					
						
							|  |  |  |  |         { name: "绿化", click: "4" }, | 
					
						
							|  |  |  |  |       ], | 
					
						
							|  |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-10-18 17:31:35 +08:00
										 |  |  |  |       // 中间展示的动态组件绑定
 | 
					
						
							| 
									
										
										
										
											2024-11-11 14:40:40 +08:00
										 |  |  |  |       elementDiv: "OverviewScreen", | 
					
						
							| 
									
										
										
										
											2024-10-23 17:17:37 +08:00
										 |  |  |  |       // 下方三个按钮数据
 | 
					
						
							| 
									
										
										
										
											2024-10-18 17:31:35 +08:00
										 |  |  |  |       elementList: [ | 
					
						
							| 
									
										
										
										
											2024-11-11 14:40:40 +08:00
										 |  |  |  |         { name: "总览", component: "OverviewScreen" }, | 
					
						
							|  |  |  |  |         { name: "病害巡检", component: "DiseaseScreen" }, | 
					
						
							| 
									
										
										
										
											2024-11-13 15:37:25 +08:00
										 |  |  |  |         { name: "道路资产", component: "RoadScreen" }, | 
					
						
							| 
									
										
										
										
											2024-10-18 17:31:35 +08:00
										 |  |  |  |       ], | 
					
						
							| 
									
										
										
										
											2024-11-14 17:43:24 +08:00
										 |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-11-01 13:15:24 +08:00
										 |  |  |  |       // 中心点集合(全部)
 | 
					
						
							| 
									
										
										
										
											2024-10-23 17:17:37 +08:00
										 |  |  |  |       centerPiont: [], | 
					
						
							| 
									
										
										
										
											2024-11-01 13:15:24 +08:00
										 |  |  |  |       // 中心点集合(当前)
 | 
					
						
							|  |  |  |  |       drawPointList: [], | 
					
						
							|  |  |  |  |       // 点位图标map
 | 
					
						
							|  |  |  |  |       mapLogeList: {}, | 
					
						
							| 
									
										
										
										
											2024-10-23 17:17:37 +08:00
										 |  |  |  |       // 线段点集合
 | 
					
						
							|  |  |  |  |       lineString: [], | 
					
						
							|  |  |  |  |       // 地图放大缩小层级
 | 
					
						
							|  |  |  |  |       mapZoom: "", | 
					
						
							|  |  |  |  |       // 聚合图层
 | 
					
						
							|  |  |  |  |       clusters: null, | 
					
						
							|  |  |  |  |       // 线段图层
 | 
					
						
							|  |  |  |  |       markLayerLines: null, | 
					
						
							| 
									
										
										
										
											2024-11-14 17:43:24 +08:00
										 |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-10-23 17:17:37 +08:00
										 |  |  |  |       // 图片弹窗标题
 | 
					
						
							|  |  |  |  |       imgTitle: "查看", | 
					
						
							|  |  |  |  |       // 图片弹窗显隐控制
 | 
					
						
							| 
									
										
										
										
											2024-11-13 15:37:25 +08:00
										 |  |  |  |       imgVisible: false, | 
					
						
							| 
									
										
										
										
											2024-11-14 17:43:24 +08:00
										 |  |  |  |       // 传图片弹窗数据
 | 
					
						
							|  |  |  |  |       imageItem: {}, | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |       // 查看大图点位图片数据
 | 
					
						
							| 
									
										
										
										
											2024-11-07 12:04:16 +08:00
										 |  |  |  |       screenImage: {}, | 
					
						
							| 
									
										
										
										
											2024-11-14 17:43:24 +08:00
										 |  |  |  |       // 查看大图点位图片弹窗显隐控制
 | 
					
						
							| 
									
										
										
										
											2024-11-07 12:04:16 +08:00
										 |  |  |  |       showImageDialog: false, | 
					
						
							| 
									
										
										
										
											2024-11-14 17:43:24 +08:00
										 |  |  |  |       // 查看大图点位图片弹窗红框数据
 | 
					
						
							| 
									
										
										
										
											2024-11-07 12:04:16 +08:00
										 |  |  |  |       screenRects: [], | 
					
						
							| 
									
										
										
										
											2024-11-29 17:59:17 +08:00
										 |  |  |  | 
 | 
					
						
							|  |  |  |  |       // 小车地图点位数据源
 | 
					
						
							|  |  |  |  |       carMapPointSource: null, | 
					
						
							| 
									
										
										
										
											2024-12-04 09:50:55 +08:00
										 |  |  |  |       // 小车地图点位数组
 | 
					
						
							|  |  |  |  |       carPointList: [], | 
					
						
							|  |  |  |  |       // 小车地图点位features数组
 | 
					
						
							|  |  |  |  |       mapPointFeatures: [], | 
					
						
							| 
									
										
										
										
											2024-10-18 17:31:35 +08:00
										 |  |  |  |     }; | 
					
						
							|  |  |  |  |   }, | 
					
						
							|  |  |  |  |   created() { | 
					
						
							|  |  |  |  |     this.setTime(); | 
					
						
							| 
									
										
										
										
											2024-10-25 17:29:08 +08:00
										 |  |  |  |     this.getSelect(); | 
					
						
							| 
									
										
										
										
											2024-10-28 10:00:28 +08:00
										 |  |  |  |     this.getMapCare(); | 
					
						
							| 
									
										
										
										
											2024-11-07 12:04:16 +08:00
										 |  |  |  |     this.getRoadList(); | 
					
						
							| 
									
										
										
										
											2024-11-11 14:40:40 +08:00
										 |  |  |  |     this.getDieaseTypeList(); | 
					
						
							| 
									
										
										
										
											2024-11-20 14:46:20 +08:00
										 |  |  |  |     this.getMessageList(); | 
					
						
							| 
									
										
										
										
											2024-11-29 15:34:10 +08:00
										 |  |  |  |     this.handleMessage(); | 
					
						
							| 
									
										
										
										
											2024-10-18 17:31:35 +08:00
										 |  |  |  |   }, | 
					
						
							| 
									
										
										
										
											2024-12-09 15:35:13 +08:00
										 |  |  |  |   mounted() {}, | 
					
						
							| 
									
										
										
										
											2024-10-18 17:31:35 +08:00
										 |  |  |  |   methods: { | 
					
						
							| 
									
										
										
										
											2024-11-28 11:12:21 +08:00
										 |  |  |  |     /** | 
					
						
							|  |  |  |  |      * @description: 获取当前时间 | 
					
						
							|  |  |  |  |      * @return {*} | 
					
						
							|  |  |  |  |      */ | 
					
						
							| 
									
										
										
										
											2024-10-18 17:31:35 +08:00
										 |  |  |  |     setTime() { | 
					
						
							|  |  |  |  |       this.timeFlag = setInterval(() => { | 
					
						
							|  |  |  |  |         const weekMap = [ | 
					
						
							|  |  |  |  |           "星期天", | 
					
						
							|  |  |  |  |           "星期一", | 
					
						
							|  |  |  |  |           "星期二", | 
					
						
							|  |  |  |  |           "星期三", | 
					
						
							|  |  |  |  |           "星期四", | 
					
						
							|  |  |  |  |           "星期五", | 
					
						
							|  |  |  |  |           "星期六", | 
					
						
							|  |  |  |  |         ]; | 
					
						
							|  |  |  |  |         const date = new Date(); | 
					
						
							|  |  |  |  |         const year = date.getFullYear(); | 
					
						
							|  |  |  |  |         const month = | 
					
						
							|  |  |  |  |           date.getMonth() + 1 < 10 | 
					
						
							|  |  |  |  |             ? `0${date.getMonth() + 1}` | 
					
						
							|  |  |  |  |             : date.getMonth() + 1; | 
					
						
							|  |  |  |  |         const day = date.getDate() < 10 ? `0${date.getDate()}` : date.getDate(); | 
					
						
							|  |  |  |  |         const hours = | 
					
						
							|  |  |  |  |           date.getHours() < 10 ? `0${date.getHours()}` : date.getHours(); | 
					
						
							|  |  |  |  |         const minutes = | 
					
						
							|  |  |  |  |           date.getMinutes() < 10 ? `0${date.getMinutes()}` : date.getMinutes(); | 
					
						
							|  |  |  |  |         const seconds = | 
					
						
							|  |  |  |  |           date.getSeconds() < 10 ? `0${date.getSeconds()}` : date.getSeconds(); | 
					
						
							|  |  |  |  |         const week = date.getDay(); | 
					
						
							|  |  |  |  |         // this.currentTime = `${year}-${month}-${day}\t\t${hours}:${minutes}:${seconds}\t\t${weekMap[week]}`;
 | 
					
						
							|  |  |  |  |         this.yearTime = `${year}.${month}.${day}`; | 
					
						
							|  |  |  |  |         this.weekTime = `${weekMap[week]}`; | 
					
						
							|  |  |  |  |         this.dataTime = `${hours}:${minutes}:${seconds}`; | 
					
						
							|  |  |  |  |       }, 1000); | 
					
						
							|  |  |  |  |     }, | 
					
						
							| 
									
										
										
										
											2024-11-07 09:30:17 +08:00
										 |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-11-28 11:12:21 +08:00
										 |  |  |  |     /** | 
					
						
							|  |  |  |  |      * @description: 获取消息中心数据 | 
					
						
							| 
									
										
										
										
											2024-11-29 15:34:10 +08:00
										 |  |  |  |      * @return {void} | 
					
						
							| 
									
										
										
										
											2024-11-28 11:12:21 +08:00
										 |  |  |  |      */ | 
					
						
							| 
									
										
										
										
											2024-11-20 14:46:20 +08:00
										 |  |  |  |     getMessageList() { | 
					
						
							| 
									
										
										
										
											2024-12-05 17:25:06 +08:00
										 |  |  |  |       this.messageTimer = setInterval(() => { | 
					
						
							|  |  |  |  |         getNoticeList({ read: 1 }).then(({ code, rows, total }) => { | 
					
						
							|  |  |  |  |           if (code === 200) { | 
					
						
							|  |  |  |  |             this.messageList = rows; | 
					
						
							| 
									
										
										
										
											2024-12-09 15:35:13 +08:00
										 |  |  |  |             this.noticeNum = total; | 
					
						
							| 
									
										
										
										
											2024-12-05 17:25:06 +08:00
										 |  |  |  |           } | 
					
						
							|  |  |  |  |         }); | 
					
						
							|  |  |  |  |       }, 5000); | 
					
						
							|  |  |  |  |       getNoticeList({ read: 1 }).then(({ code, rows, total }) => { | 
					
						
							|  |  |  |  |         if (code === 200) { | 
					
						
							|  |  |  |  |           this.messageList = rows; | 
					
						
							| 
									
										
										
										
											2024-12-09 15:35:13 +08:00
										 |  |  |  |           this.noticeNum = total; | 
					
						
							| 
									
										
										
										
											2024-12-05 17:25:06 +08:00
										 |  |  |  |         } | 
					
						
							|  |  |  |  |       }); | 
					
						
							|  |  |  |  |       // this.messageList = [
 | 
					
						
							|  |  |  |  |       //   {
 | 
					
						
							|  |  |  |  |       //     title: "成功",
 | 
					
						
							|  |  |  |  |       //     status: "SUCCESS",
 | 
					
						
							|  |  |  |  |       //     time: "2024/45/62",
 | 
					
						
							|  |  |  |  |       //     car: "辽jskdn",
 | 
					
						
							|  |  |  |  |       //     content: "骄傲的是否哈德half绝对符合卡的法拉第",
 | 
					
						
							|  |  |  |  |       //   },
 | 
					
						
							|  |  |  |  |       //   {
 | 
					
						
							|  |  |  |  |       //     title: "告警",
 | 
					
						
							|  |  |  |  |       //     status: "WARNING",
 | 
					
						
							|  |  |  |  |       //     time: "2024/45/62",
 | 
					
						
							|  |  |  |  |       //     car: "辽jskdn",
 | 
					
						
							|  |  |  |  |       //     content: "骄傲的是否哈德half绝对符合卡的法拉第",
 | 
					
						
							|  |  |  |  |       //   },
 | 
					
						
							|  |  |  |  |       //   {
 | 
					
						
							|  |  |  |  |       //     title: "提醒",
 | 
					
						
							|  |  |  |  |       //     status: "REMIND",
 | 
					
						
							|  |  |  |  |       //     time: "2024/45/62",
 | 
					
						
							|  |  |  |  |       //     car: "辽jskdn",
 | 
					
						
							|  |  |  |  |       //     content: "骄傲的是否哈德half绝对符合卡的法拉第",
 | 
					
						
							|  |  |  |  |       //   },
 | 
					
						
							|  |  |  |  |       // ];
 | 
					
						
							| 
									
										
										
										
											2024-11-20 14:46:20 +08:00
										 |  |  |  |     }, | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |     /** | 
					
						
							|  |  |  |  |      * @description: 消息中心点击具体数据事件 | 
					
						
							|  |  |  |  |      * @return {*} | 
					
						
							|  |  |  |  |      */ | 
					
						
							|  |  |  |  |     handleMessageItemClick(value) { | 
					
						
							|  |  |  |  |       this.$router.push({ | 
					
						
							|  |  |  |  |         name: "Warning-center", | 
					
						
							| 
									
										
										
										
											2024-12-03 13:42:21 +08:00
										 |  |  |  |         params: { title: value }, | 
					
						
							| 
									
										
										
										
											2024-11-20 14:46:20 +08:00
										 |  |  |  |       }); | 
					
						
							|  |  |  |  |     }, | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |     /** | 
					
						
							|  |  |  |  |      * @description: 消息中心查看更多事件 | 
					
						
							|  |  |  |  |      * @return {*} | 
					
						
							|  |  |  |  |      */ | 
					
						
							|  |  |  |  |     handleMessageClick() { | 
					
						
							|  |  |  |  |       this.$router.push("/inspection_warn/warning-center"); | 
					
						
							|  |  |  |  |     }, | 
					
						
							|  |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-11-28 11:12:21 +08:00
										 |  |  |  |     /** | 
					
						
							|  |  |  |  |      * @description: 获取数据栏右上角选项数据 | 
					
						
							| 
									
										
										
										
											2024-11-29 15:34:10 +08:00
										 |  |  |  |      * @return {void} | 
					
						
							| 
									
										
										
										
											2024-11-28 11:12:21 +08:00
										 |  |  |  |      */ | 
					
						
							| 
									
										
										
										
											2024-10-25 17:29:08 +08:00
										 |  |  |  |     getSelect() { | 
					
						
							|  |  |  |  |       selectTypeList().then(({ code, data }) => { | 
					
						
							|  |  |  |  |         if (code === 200) { | 
					
						
							|  |  |  |  |           this.selectTypeArr = data; | 
					
						
							|  |  |  |  |         } | 
					
						
							|  |  |  |  |       }); | 
					
						
							|  |  |  |  |     }, | 
					
						
							| 
									
										
										
										
											2024-11-29 15:34:10 +08:00
										 |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-11-28 11:12:21 +08:00
										 |  |  |  |     /** | 
					
						
							|  |  |  |  |      * @description: 获取路段下拉数据 | 
					
						
							| 
									
										
										
										
											2024-11-29 15:34:10 +08:00
										 |  |  |  |      * @return {void} | 
					
						
							| 
									
										
										
										
											2024-11-28 11:12:21 +08:00
										 |  |  |  |      */ | 
					
						
							| 
									
										
										
										
											2024-11-07 12:04:16 +08:00
										 |  |  |  |     getRoadList() { | 
					
						
							|  |  |  |  |       getRoadListTypes().then(({ code, data }) => { | 
					
						
							|  |  |  |  |         if (code === 200) { | 
					
						
							|  |  |  |  |           this.roadList = data; | 
					
						
							|  |  |  |  |         } | 
					
						
							|  |  |  |  |       }); | 
					
						
							|  |  |  |  |     }, | 
					
						
							|  |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-11-28 11:12:21 +08:00
										 |  |  |  |     /** | 
					
						
							|  |  |  |  |      * @description: 获取图片背景左上角病害类型下拉 | 
					
						
							| 
									
										
										
										
											2024-11-29 15:34:10 +08:00
										 |  |  |  |      * @return {void} | 
					
						
							| 
									
										
										
										
											2024-11-28 11:12:21 +08:00
										 |  |  |  |      */ | 
					
						
							| 
									
										
										
										
											2024-11-11 14:40:40 +08:00
										 |  |  |  |     getDieaseTypeList() { | 
					
						
							| 
									
										
										
										
											2024-11-18 13:49:59 +08:00
										 |  |  |  |       getDefectTypes().then(({ code, data }) => { | 
					
						
							| 
									
										
										
										
											2024-11-13 15:37:25 +08:00
										 |  |  |  |         if (code === 200) { | 
					
						
							| 
									
										
										
										
											2024-11-18 13:49:59 +08:00
										 |  |  |  |           this.dieaseOptions = data; | 
					
						
							| 
									
										
										
										
											2024-11-13 15:37:25 +08:00
										 |  |  |  |         } | 
					
						
							|  |  |  |  |       }); | 
					
						
							| 
									
										
										
										
											2024-11-11 14:40:40 +08:00
										 |  |  |  |     }, | 
					
						
							|  |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-11-28 11:12:21 +08:00
										 |  |  |  |     /** | 
					
						
							|  |  |  |  |      * @description: 获取图片背景下坐标数据 | 
					
						
							| 
									
										
										
										
											2024-11-29 15:34:10 +08:00
										 |  |  |  |      * @return {void} | 
					
						
							| 
									
										
										
										
											2024-11-28 11:12:21 +08:00
										 |  |  |  |      */ | 
					
						
							| 
									
										
										
										
											2024-11-15 11:03:30 +08:00
										 |  |  |  |     getMapCare(value) { | 
					
						
							| 
									
										
										
										
											2024-11-18 13:49:59 +08:00
										 |  |  |  |       const data = { | 
					
						
							|  |  |  |  |         classType: value ? value[0] : "", | 
					
						
							|  |  |  |  |         type: value ? (value.length > 1 ? value[1] : "") : "", | 
					
						
							|  |  |  |  |       }; | 
					
						
							| 
									
										
										
										
											2024-11-19 14:18:57 +08:00
										 |  |  |  |       comppanyImg(data).then(({ code, data }) => { | 
					
						
							|  |  |  |  |         if (code === 200) { | 
					
						
							|  |  |  |  |           this.mapCareList = data; | 
					
						
							| 
									
										
										
										
											2024-10-31 14:39:01 +08:00
										 |  |  |  |         } | 
					
						
							| 
									
										
										
										
											2024-11-19 14:18:57 +08:00
										 |  |  |  |       }); | 
					
						
							| 
									
										
										
										
											2024-10-28 10:00:28 +08:00
										 |  |  |  |     }, | 
					
						
							| 
									
										
										
										
											2024-11-07 09:30:17 +08:00
										 |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-11-28 11:12:21 +08:00
										 |  |  |  |     /** | 
					
						
							|  |  |  |  |      * @description: 点击病害日志详情打开弹窗进行地图打点 | 
					
						
							| 
									
										
										
										
											2024-11-29 15:34:10 +08:00
										 |  |  |  |      * @return {void} | 
					
						
							| 
									
										
										
										
											2024-11-28 11:12:21 +08:00
										 |  |  |  |      */ | 
					
						
							| 
									
										
										
										
											2024-11-14 17:43:24 +08:00
										 |  |  |  |     getimagePoint(item) { | 
					
						
							|  |  |  |  |       this.imgTitle = "查看"; | 
					
						
							|  |  |  |  |       this.imageItem = item; | 
					
						
							| 
									
										
										
										
											2024-10-23 17:17:37 +08:00
										 |  |  |  |       this.imgVisible = true; | 
					
						
							| 
									
										
										
										
											2024-11-19 14:18:57 +08:00
										 |  |  |  |       // 地图右上角多选按钮显示
 | 
					
						
							|  |  |  |  |       this.getIconType(); | 
					
						
							|  |  |  |  |       this.showIconList = true; | 
					
						
							| 
									
										
										
										
											2024-11-14 17:43:24 +08:00
										 |  |  |  |       // 地图打点\改变地图层级
 | 
					
						
							|  |  |  |  |       this.$nextTick(() => { | 
					
						
							|  |  |  |  |         const map = this.$refs.roadMap.instance.get("map"); | 
					
						
							|  |  |  |  |         map.getView().setCenter(item.tablePoint); | 
					
						
							|  |  |  |  |         map.getView().setZoom(16); | 
					
						
							|  |  |  |  |       }); | 
					
						
							|  |  |  |  |       this.roadSelect = item.segmentId; | 
					
						
							|  |  |  |  |       this.getCenterPiont(); | 
					
						
							| 
									
										
										
										
											2024-10-23 17:17:37 +08:00
										 |  |  |  |     }, | 
					
						
							| 
									
										
										
										
											2024-11-07 09:30:17 +08:00
										 |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-11-28 11:12:21 +08:00
										 |  |  |  |     /** | 
					
						
							|  |  |  |  |      * @description: 关闭图片查看弹窗 | 
					
						
							| 
									
										
										
										
											2024-11-29 15:34:10 +08:00
										 |  |  |  |      * @return {void} | 
					
						
							| 
									
										
										
										
											2024-11-28 11:12:21 +08:00
										 |  |  |  |      */ | 
					
						
							| 
									
										
										
										
											2024-10-23 17:17:37 +08:00
										 |  |  |  |     imgCancel() { | 
					
						
							| 
									
										
										
										
											2024-11-14 17:43:24 +08:00
										 |  |  |  |       this.imgTitle = ""; | 
					
						
							|  |  |  |  |       this.imageItem = {}; | 
					
						
							| 
									
										
										
										
											2024-10-23 17:17:37 +08:00
										 |  |  |  |       this.imgVisible = false; | 
					
						
							|  |  |  |  |     }, | 
					
						
							| 
									
										
										
										
											2024-11-07 09:30:17 +08:00
										 |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-11-28 11:12:21 +08:00
										 |  |  |  |     /** | 
					
						
							|  |  |  |  |      * @description: 关闭查看点位大图弹窗 | 
					
						
							| 
									
										
										
										
											2024-11-29 15:34:10 +08:00
										 |  |  |  |      * @return {void} | 
					
						
							| 
									
										
										
										
											2024-11-28 11:12:21 +08:00
										 |  |  |  |      */ | 
					
						
							| 
									
										
										
										
											2024-11-07 12:04:16 +08:00
										 |  |  |  |     screenImgCancel() { | 
					
						
							| 
									
										
										
										
											2024-11-21 11:52:44 +08:00
										 |  |  |  |       this.$refs.roadMap.removeSelectClick(); | 
					
						
							| 
									
										
										
										
											2024-11-07 12:04:16 +08:00
										 |  |  |  |       this.showImageDialog = false; | 
					
						
							|  |  |  |  |     }, | 
					
						
							|  |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-11-28 11:12:21 +08:00
										 |  |  |  |     /** | 
					
						
							|  |  |  |  |      * @description: 切换icon类型多选框事件 | 
					
						
							| 
									
										
										
										
											2024-11-29 15:34:10 +08:00
										 |  |  |  |      * @return {void} | 
					
						
							| 
									
										
										
										
											2024-11-28 11:12:21 +08:00
										 |  |  |  |      */ | 
					
						
							| 
									
										
										
										
											2024-10-23 17:17:37 +08:00
										 |  |  |  |     handleChecked(value) { | 
					
						
							| 
									
										
										
										
											2024-11-01 13:15:24 +08:00
										 |  |  |  |       this.centerPiont = this.drawPointList.filter( | 
					
						
							|  |  |  |  |         (item) => value.indexOf(item.iconType) > -1 | 
					
						
							|  |  |  |  |       ); | 
					
						
							|  |  |  |  |       this.$nextTick(() => { | 
					
						
							|  |  |  |  |         const map = this.$refs.roadMap.instance.get("map"); | 
					
						
							|  |  |  |  |         map.removeLayer(this.clusters); | 
					
						
							|  |  |  |  |         this.clusters = null; | 
					
						
							|  |  |  |  |         this.drawPoint(); | 
					
						
							|  |  |  |  |       }); | 
					
						
							| 
									
										
										
										
											2024-10-23 17:17:37 +08:00
										 |  |  |  |     }, | 
					
						
							| 
									
										
										
										
											2024-11-07 09:30:17 +08:00
										 |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-11-28 11:12:21 +08:00
										 |  |  |  |     /** | 
					
						
							|  |  |  |  |      * @description: 获取地图点位信息 | 
					
						
							| 
									
										
										
										
											2024-11-29 15:34:10 +08:00
										 |  |  |  |      * @return {void} | 
					
						
							| 
									
										
										
										
											2024-11-28 11:12:21 +08:00
										 |  |  |  |      */ | 
					
						
							| 
									
										
										
										
											2024-10-23 17:17:37 +08:00
										 |  |  |  |     getCenterPiont() { | 
					
						
							| 
									
										
										
										
											2024-10-29 09:45:49 +08:00
										 |  |  |  |       // 如果当前已经有打点坐标
 | 
					
						
							| 
									
										
										
										
											2024-11-07 12:04:16 +08:00
										 |  |  |  |       if (this.clusters) { | 
					
						
							|  |  |  |  |         this.$nextTick(() => { | 
					
						
							|  |  |  |  |           const map = this.$refs.roadMap.instance.get("map"); | 
					
						
							|  |  |  |  |           map.removeLayer(this.clusters); | 
					
						
							|  |  |  |  |           this.clusters = null; | 
					
						
							|  |  |  |  |         }); | 
					
						
							|  |  |  |  |       } | 
					
						
							| 
									
										
										
										
											2024-11-11 14:40:40 +08:00
										 |  |  |  |       mapPointList({ | 
					
						
							| 
									
										
										
										
											2024-11-14 17:43:24 +08:00
										 |  |  |  |         type: this.elementDiv, | 
					
						
							|  |  |  |  |         classType: this.bottomTipClick, | 
					
						
							| 
									
										
										
										
											2024-11-11 14:40:40 +08:00
										 |  |  |  |         segmentId: this.roadSelect, | 
					
						
							|  |  |  |  |       }).then(({ code, data }) => { | 
					
						
							|  |  |  |  |         if (code === 200) { | 
					
						
							|  |  |  |  |           this.drawPointList = data.map((item) => { | 
					
						
							|  |  |  |  |             if (item.geometry) { | 
					
						
							|  |  |  |  |               return { | 
					
						
							|  |  |  |  |                 ...item, | 
					
						
							|  |  |  |  |                 geometry: [item.geometry[0], item.geometry[1]], | 
					
						
							|  |  |  |  |               }; | 
					
						
							|  |  |  |  |             } | 
					
						
							|  |  |  |  |             return []; | 
					
						
							|  |  |  |  |           }); | 
					
						
							|  |  |  |  |           this.centerPiont = data.map((item) => { | 
					
						
							|  |  |  |  |             if (item.geometry) { | 
					
						
							|  |  |  |  |               return { | 
					
						
							|  |  |  |  |                 ...item, | 
					
						
							|  |  |  |  |                 geometry: [item.geometry[0], item.geometry[1]], | 
					
						
							|  |  |  |  |               }; | 
					
						
							|  |  |  |  |             } | 
					
						
							|  |  |  |  |             return []; | 
					
						
							|  |  |  |  |           }); | 
					
						
							| 
									
										
										
										
											2024-11-20 18:11:03 +08:00
										 |  |  |  |           // 如果不是病害巡检,则绘制点位
 | 
					
						
							| 
									
										
										
										
											2024-11-21 11:52:44 +08:00
										 |  |  |  |           // 如果图片弹窗打开,则绘制点位
 | 
					
						
							|  |  |  |  |           if (this.elementDiv !== "DiseaseScreen" || this.imgVisible) { | 
					
						
							| 
									
										
										
										
											2024-11-20 18:11:03 +08:00
										 |  |  |  |             this.drawPoint(); | 
					
						
							|  |  |  |  |           } | 
					
						
							| 
									
										
										
										
											2024-11-07 12:04:16 +08:00
										 |  |  |  |         } | 
					
						
							| 
									
										
										
										
											2024-11-11 14:40:40 +08:00
										 |  |  |  |       }); | 
					
						
							| 
									
										
										
										
											2024-10-23 17:17:37 +08:00
										 |  |  |  |     }, | 
					
						
							| 
									
										
										
										
											2024-11-07 09:30:17 +08:00
										 |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-11-28 11:12:21 +08:00
										 |  |  |  |     /** | 
					
						
							|  |  |  |  |      * @description: 绘制地图点位 | 
					
						
							| 
									
										
										
										
											2024-11-29 15:34:10 +08:00
										 |  |  |  |      * @return {void} | 
					
						
							| 
									
										
										
										
											2024-11-28 11:12:21 +08:00
										 |  |  |  |      */ | 
					
						
							| 
									
										
										
										
											2024-10-23 17:17:37 +08:00
										 |  |  |  |     drawPoint() { | 
					
						
							|  |  |  |  |       const features = []; | 
					
						
							|  |  |  |  |       this.centerPiont.forEach((element) => { | 
					
						
							|  |  |  |  |         // 修改坐标样式
 | 
					
						
							| 
									
										
										
										
											2024-11-01 13:15:24 +08:00
										 |  |  |  |         const point = new Point(element.geometry); | 
					
						
							| 
									
										
										
										
											2024-10-23 17:17:37 +08:00
										 |  |  |  |         const feature = new Feature({ | 
					
						
							|  |  |  |  |           geometry: point, | 
					
						
							| 
									
										
										
										
											2024-11-19 14:18:57 +08:00
										 |  |  |  |           data: element, | 
					
						
							| 
									
										
										
										
											2024-10-23 17:17:37 +08:00
										 |  |  |  |           // 自己设置一个标识
 | 
					
						
							|  |  |  |  |           type: "icon", | 
					
						
							|  |  |  |  |         }); | 
					
						
							|  |  |  |  |         features.push(feature); | 
					
						
							|  |  |  |  |       }); | 
					
						
							|  |  |  |  |       const clusterSource = new Cluster({ | 
					
						
							| 
									
										
										
										
											2024-11-14 17:43:24 +08:00
										 |  |  |  |         distance: this.mapZoom > 15 ? 0 : 100, | 
					
						
							|  |  |  |  |         minDistance: this.mapZoom > 15 ? 0 : 100, | 
					
						
							| 
									
										
										
										
											2024-10-23 17:17:37 +08:00
										 |  |  |  |         source: new VectorSource({ | 
					
						
							|  |  |  |  |           features, | 
					
						
							|  |  |  |  |         }), | 
					
						
							|  |  |  |  |         type: "Cluster", | 
					
						
							|  |  |  |  |       }); | 
					
						
							|  |  |  |  |       this.clusters = new VectorLayer({ | 
					
						
							|  |  |  |  |         source: clusterSource, | 
					
						
							|  |  |  |  |         name: "clusterLayer", | 
					
						
							|  |  |  |  |         zIndex: 10, | 
					
						
							| 
									
										
										
										
											2024-11-01 13:15:24 +08:00
										 |  |  |  |         style: (feature) => { | 
					
						
							| 
									
										
										
										
											2024-10-23 17:17:37 +08:00
										 |  |  |  |           const count = feature.get("features").length; | 
					
						
							| 
									
										
										
										
											2024-11-01 13:15:24 +08:00
										 |  |  |  |           if (count > 1) { | 
					
						
							|  |  |  |  |             return new Style({ | 
					
						
							|  |  |  |  |               image: new Icon({ | 
					
						
							|  |  |  |  |                 crossOrigin: "anonymous", | 
					
						
							|  |  |  |  |                 src: require(`@/assets/screen/index/龟裂.png`), | 
					
						
							|  |  |  |  |                 // 图标缩放比例
 | 
					
						
							|  |  |  |  |                 scale: 0.6, | 
					
						
							|  |  |  |  |                 displacement: [0, 30], | 
					
						
							|  |  |  |  |                 // 0.3为30度
 | 
					
						
							|  |  |  |  |                 // rotation: 0.3,
 | 
					
						
							| 
									
										
										
										
											2024-10-23 17:17:37 +08:00
										 |  |  |  |               }), | 
					
						
							| 
									
										
										
										
											2024-11-01 13:15:24 +08:00
										 |  |  |  |               text: new Text({ | 
					
						
							|  |  |  |  |                 textAlign: "center", //位置
 | 
					
						
							|  |  |  |  |                 textBaseline: "middle", | 
					
						
							|  |  |  |  |                 font: "normal 14px 微软雅黑", | 
					
						
							|  |  |  |  |                 offsetY: -50, | 
					
						
							|  |  |  |  |                 fill: new Fill({ | 
					
						
							|  |  |  |  |                   color: "#ffffff", | 
					
						
							|  |  |  |  |                 }), | 
					
						
							|  |  |  |  |                 text: count.toString(), | 
					
						
							|  |  |  |  |               }), | 
					
						
							|  |  |  |  |             }); | 
					
						
							|  |  |  |  |           } else { | 
					
						
							|  |  |  |  |             return new Style({ | 
					
						
							|  |  |  |  |               image: new Icon({ | 
					
						
							|  |  |  |  |                 crossOrigin: "anonymous", | 
					
						
							| 
									
										
										
										
											2024-12-09 15:35:13 +08:00
										 |  |  |  |                 src: require(`@/assets/screen/index/${ | 
					
						
							|  |  |  |  |                   this.mapLogeList[ | 
					
						
							|  |  |  |  |                     feature.getProperties().features[0].get("data").iconType | 
					
						
							|  |  |  |  |                   ] | 
					
						
							|  |  |  |  |                 }.png`),
 | 
					
						
							| 
									
										
										
										
											2024-11-01 13:15:24 +08:00
										 |  |  |  |                 // 图标缩放比例
 | 
					
						
							|  |  |  |  |                 scale: 0.6, | 
					
						
							|  |  |  |  |                 displacement: [0, 30], | 
					
						
							|  |  |  |  |                 // 0.3为30度
 | 
					
						
							|  |  |  |  |                 // rotation: 0.3,
 | 
					
						
							|  |  |  |  |               }), | 
					
						
							|  |  |  |  |               text: new Text({ | 
					
						
							|  |  |  |  |                 textAlign: "center", //位置
 | 
					
						
							|  |  |  |  |                 textBaseline: "middle", | 
					
						
							|  |  |  |  |                 font: "normal 14px 微软雅黑", | 
					
						
							|  |  |  |  |                 offsetY: -50, | 
					
						
							|  |  |  |  |                 fill: new Fill({ | 
					
						
							|  |  |  |  |                   color: "#ffffff", | 
					
						
							|  |  |  |  |                 }), | 
					
						
							|  |  |  |  |                 text: "", | 
					
						
							|  |  |  |  |               }), | 
					
						
							|  |  |  |  |             }); | 
					
						
							|  |  |  |  |           } | 
					
						
							| 
									
										
										
										
											2024-10-23 17:17:37 +08:00
										 |  |  |  |         }, | 
					
						
							|  |  |  |  |       }); | 
					
						
							|  |  |  |  |       this.$nextTick(() => { | 
					
						
							|  |  |  |  |         const map = this.$refs.roadMap.instance.get("map"); | 
					
						
							|  |  |  |  |         map.addLayer(this.clusters); | 
					
						
							|  |  |  |  |       }); | 
					
						
							|  |  |  |  |     }, | 
					
						
							| 
									
										
										
										
											2024-11-07 09:30:17 +08:00
										 |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-11-28 11:12:21 +08:00
										 |  |  |  |     /** | 
					
						
							|  |  |  |  |      * @description: 获取地图线段点位信息 | 
					
						
							| 
									
										
										
										
											2024-11-29 15:34:10 +08:00
										 |  |  |  |      * @return {void} | 
					
						
							| 
									
										
										
										
											2024-11-28 11:12:21 +08:00
										 |  |  |  |      */ | 
					
						
							| 
									
										
										
										
											2024-10-23 17:17:37 +08:00
										 |  |  |  |     getLinePoint() { | 
					
						
							| 
									
										
										
										
											2024-11-14 17:43:24 +08:00
										 |  |  |  |       if (!this.markLayerLines) { | 
					
						
							|  |  |  |  |         mapPciList().then(({ code, data }) => { | 
					
						
							| 
									
										
										
										
											2024-12-05 17:48:42 +08:00
										 |  |  |  |           if (code === 200 && data) { | 
					
						
							| 
									
										
										
										
											2024-11-22 15:14:32 +08:00
										 |  |  |  |             this.lineString = data.filter((item) => item.coordinates !== null); | 
					
						
							| 
									
										
										
										
											2024-11-14 17:43:24 +08:00
										 |  |  |  |             this.drawLine(); | 
					
						
							|  |  |  |  |           } | 
					
						
							|  |  |  |  |         }); | 
					
						
							|  |  |  |  |       } | 
					
						
							| 
									
										
										
										
											2024-10-23 17:17:37 +08:00
										 |  |  |  |     }, | 
					
						
							| 
									
										
										
										
											2024-11-07 09:30:17 +08:00
										 |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-11-28 11:12:21 +08:00
										 |  |  |  |     /** | 
					
						
							|  |  |  |  |      * @description: 绘制地图线段 | 
					
						
							| 
									
										
										
										
											2024-11-29 15:34:10 +08:00
										 |  |  |  |      * @return {void} | 
					
						
							| 
									
										
										
										
											2024-11-28 11:12:21 +08:00
										 |  |  |  |      */ | 
					
						
							| 
									
										
										
										
											2024-10-23 17:17:37 +08:00
										 |  |  |  |     drawLine() { | 
					
						
							|  |  |  |  |       const features = []; | 
					
						
							|  |  |  |  |       this.lineString.forEach((element) => { | 
					
						
							| 
									
										
										
										
											2024-11-22 15:14:32 +08:00
										 |  |  |  |         const lines = element?.coordinates?.split(";")?.map((it) => { | 
					
						
							| 
									
										
										
										
											2024-11-07 12:04:16 +08:00
										 |  |  |  |           return it.split(",").map(Number); | 
					
						
							|  |  |  |  |         }); | 
					
						
							| 
									
										
										
										
											2024-10-23 17:17:37 +08:00
										 |  |  |  |         const line = new Feature({ | 
					
						
							| 
									
										
										
										
											2024-11-07 12:04:16 +08:00
										 |  |  |  |           geometry: new geomExports.LineString(lines), | 
					
						
							| 
									
										
										
										
											2024-10-23 17:17:37 +08:00
										 |  |  |  |           type: "line", | 
					
						
							|  |  |  |  |         }); | 
					
						
							|  |  |  |  |         line.setStyle([ | 
					
						
							|  |  |  |  |           new Style({ | 
					
						
							|  |  |  |  |             // 填充色
 | 
					
						
							|  |  |  |  |             fill: new Fill({ | 
					
						
							|  |  |  |  |               color: "red", | 
					
						
							|  |  |  |  |             }), | 
					
						
							|  |  |  |  |             // 边线颜色
 | 
					
						
							|  |  |  |  |             stroke: new Stroke({ | 
					
						
							| 
									
										
										
										
											2024-11-15 18:08:37 +08:00
										 |  |  |  |               color: this.getLineColor(element.pci), | 
					
						
							| 
									
										
										
										
											2024-10-23 17:17:37 +08:00
										 |  |  |  |               width: 5, | 
					
						
							|  |  |  |  |             }), | 
					
						
							|  |  |  |  |             // 形状
 | 
					
						
							|  |  |  |  |             image: new Circle({ | 
					
						
							|  |  |  |  |               radius: 17, | 
					
						
							|  |  |  |  |               fill: new Fill({ | 
					
						
							|  |  |  |  |                 color: "#ffffff", | 
					
						
							|  |  |  |  |               }), | 
					
						
							|  |  |  |  |             }), | 
					
						
							| 
									
										
										
										
											2024-11-28 11:12:21 +08:00
										 |  |  |  |             // text: new Text({
 | 
					
						
							|  |  |  |  |             //   text: "121454",
 | 
					
						
							|  |  |  |  |             //   color: "#ffffff",
 | 
					
						
							|  |  |  |  |             //   textAlign: "center", //位置
 | 
					
						
							|  |  |  |  |             //   textBaseline: "middle",
 | 
					
						
							|  |  |  |  |             //   offsetY: 0,
 | 
					
						
							|  |  |  |  |             //   fill: new Fill({
 | 
					
						
							|  |  |  |  |             //     color: "#ffffff",
 | 
					
						
							|  |  |  |  |             //   }),
 | 
					
						
							|  |  |  |  |             // }),
 | 
					
						
							| 
									
										
										
										
											2024-10-23 17:17:37 +08:00
										 |  |  |  |           }), | 
					
						
							|  |  |  |  |         ]); | 
					
						
							|  |  |  |  |         features.push(line); | 
					
						
							|  |  |  |  |       }); | 
					
						
							|  |  |  |  |       const lineSource = new VectorSource({ | 
					
						
							|  |  |  |  |         features, | 
					
						
							|  |  |  |  |       }); | 
					
						
							|  |  |  |  |       this.markLayerLines = new VectorLayer({ | 
					
						
							|  |  |  |  |         source: lineSource, | 
					
						
							|  |  |  |  |         properties: { | 
					
						
							|  |  |  |  |           type: "line", | 
					
						
							|  |  |  |  |         }, | 
					
						
							|  |  |  |  |       }); | 
					
						
							|  |  |  |  |       this.$nextTick(() => { | 
					
						
							|  |  |  |  |         const map = this.$refs.roadMap.instance.get("map"); | 
					
						
							|  |  |  |  |         map.addLayer(this.markLayerLines); | 
					
						
							|  |  |  |  |       }); | 
					
						
							|  |  |  |  |     }, | 
					
						
							| 
									
										
										
										
											2024-11-07 09:30:17 +08:00
										 |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-11-28 11:12:21 +08:00
										 |  |  |  |     /** | 
					
						
							|  |  |  |  |      * @description: 地图线段颜色区分 | 
					
						
							| 
									
										
										
										
											2024-11-29 15:34:10 +08:00
										 |  |  |  |      * @param {number} value | 
					
						
							|  |  |  |  |      * @return {string} | 
					
						
							| 
									
										
										
										
											2024-11-28 11:12:21 +08:00
										 |  |  |  |      */ | 
					
						
							| 
									
										
										
										
											2024-11-15 18:08:37 +08:00
										 |  |  |  |     getLineColor(value) { | 
					
						
							|  |  |  |  |       if (value > 92) { | 
					
						
							|  |  |  |  |         return "#0ABE67"; | 
					
						
							|  |  |  |  |       } else if (92 >= value > 80) { | 
					
						
							|  |  |  |  |         return "#03BDE7"; | 
					
						
							|  |  |  |  |       } else if (80 >= value > 70) { | 
					
						
							|  |  |  |  |         return "#E7CA03"; | 
					
						
							|  |  |  |  |       } else if (70 >= value > 60) { | 
					
						
							|  |  |  |  |         return "#D47F07"; | 
					
						
							|  |  |  |  |       } else { | 
					
						
							|  |  |  |  |         return "#E64548"; | 
					
						
							|  |  |  |  |       } | 
					
						
							|  |  |  |  |     }, | 
					
						
							| 
									
										
										
										
											2024-11-29 15:34:10 +08:00
										 |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-11-28 11:12:21 +08:00
										 |  |  |  |     /** | 
					
						
							|  |  |  |  |      * @description: 地图下方4图标类别切换点击事件 | 
					
						
							| 
									
										
										
										
											2024-11-29 15:34:10 +08:00
										 |  |  |  |      * @param {string} value | 
					
						
							|  |  |  |  |      * @return {void} | 
					
						
							| 
									
										
										
										
											2024-11-28 11:12:21 +08:00
										 |  |  |  |      */ | 
					
						
							| 
									
										
										
										
											2024-10-23 17:17:37 +08:00
										 |  |  |  |     changeIconType(value) { | 
					
						
							| 
									
										
										
										
											2024-11-11 14:40:40 +08:00
										 |  |  |  |       if (this.bottomTipClick !== value) { | 
					
						
							|  |  |  |  |         this.bottomTipClick = value; | 
					
						
							| 
									
										
										
										
											2024-11-19 14:18:57 +08:00
										 |  |  |  |         this.$nextTick(() => { | 
					
						
							|  |  |  |  |           const map = this.$refs.roadMap.instance.get("map"); | 
					
						
							|  |  |  |  |           map.removeLayer(this.clusters); | 
					
						
							|  |  |  |  |           this.clusters = null; | 
					
						
							|  |  |  |  |           // map.getView().setZoom(10);
 | 
					
						
							|  |  |  |  |           // map.getView().setCenter([123.30297096718999, 41.87942945541742]);
 | 
					
						
							|  |  |  |  |         }); | 
					
						
							|  |  |  |  |         // 地图右上角多选按钮隐藏
 | 
					
						
							|  |  |  |  |         this.showIconList = false; | 
					
						
							|  |  |  |  |         // this.getIconType();
 | 
					
						
							|  |  |  |  |         // this.getCenterPiont();
 | 
					
						
							| 
									
										
										
										
											2024-10-23 17:17:37 +08:00
										 |  |  |  |       } | 
					
						
							|  |  |  |  |     }, | 
					
						
							| 
									
										
										
										
											2024-11-07 09:30:17 +08:00
										 |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-11-28 11:12:21 +08:00
										 |  |  |  |     /** | 
					
						
							|  |  |  |  |      * @description: 获取icon多选数据 | 
					
						
							| 
									
										
										
										
											2024-11-29 15:34:10 +08:00
										 |  |  |  |      * @return {void} | 
					
						
							| 
									
										
										
										
											2024-11-28 11:12:21 +08:00
										 |  |  |  |      */ | 
					
						
							| 
									
										
										
										
											2024-11-14 17:43:24 +08:00
										 |  |  |  |     getIconType() { | 
					
						
							| 
									
										
										
										
											2024-11-01 13:15:24 +08:00
										 |  |  |  |       this.mapLogeList = {}; | 
					
						
							| 
									
										
										
										
											2024-11-18 13:49:59 +08:00
										 |  |  |  |       getItemTypes({ | 
					
						
							|  |  |  |  |         classType: this.bottomTipClick, | 
					
						
							|  |  |  |  |         type: this.elementDiv, | 
					
						
							|  |  |  |  |       }).then(({ code, data }) => { | 
					
						
							| 
									
										
										
										
											2024-11-01 13:15:24 +08:00
										 |  |  |  |         if (code === 200) { | 
					
						
							|  |  |  |  |           this.iconTypeList = data; | 
					
						
							|  |  |  |  |           this.iconType = data.map((item) => { | 
					
						
							|  |  |  |  |             return item.value; | 
					
						
							|  |  |  |  |           }); | 
					
						
							|  |  |  |  |           data.forEach((item) => { | 
					
						
							|  |  |  |  |             this.mapLogeList[item.value] = item.label; | 
					
						
							|  |  |  |  |           }); | 
					
						
							|  |  |  |  |         } | 
					
						
							|  |  |  |  |       }); | 
					
						
							| 
									
										
										
										
											2024-10-23 17:17:37 +08:00
										 |  |  |  |     }, | 
					
						
							| 
									
										
										
										
											2024-11-07 09:30:17 +08:00
										 |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-11-28 11:12:21 +08:00
										 |  |  |  |     /** | 
					
						
							|  |  |  |  |      * @description: 传回来的地图图层 | 
					
						
							| 
									
										
										
										
											2024-11-29 15:34:10 +08:00
										 |  |  |  |      * @param {number} zoom | 
					
						
							|  |  |  |  |      * @return {void} | 
					
						
							| 
									
										
										
										
											2024-11-28 11:12:21 +08:00
										 |  |  |  |      */ | 
					
						
							| 
									
										
										
										
											2024-10-23 17:17:37 +08:00
										 |  |  |  |     getZoom(zoom) { | 
					
						
							| 
									
										
										
										
											2024-11-14 17:43:24 +08:00
										 |  |  |  |       this.mapZoom = zoom; | 
					
						
							| 
									
										
										
										
											2024-11-07 09:30:17 +08:00
										 |  |  |  |       if (this.clusters && zoom * 1 > 15) { | 
					
						
							| 
									
										
										
										
											2024-10-29 10:58:53 +08:00
										 |  |  |  |         this.clusters.getSource().setDistance(0); | 
					
						
							| 
									
										
										
										
											2024-11-07 09:30:17 +08:00
										 |  |  |  |       } else if (this.clusters && zoom * 1 <= 15) { | 
					
						
							| 
									
										
										
										
											2024-11-14 17:43:24 +08:00
										 |  |  |  |         this.clusters.getSource().setDistance(100); | 
					
						
							| 
									
										
										
										
											2024-10-23 17:17:37 +08:00
										 |  |  |  |       } | 
					
						
							|  |  |  |  |     }, | 
					
						
							| 
									
										
										
										
											2024-11-07 09:30:17 +08:00
										 |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-11-28 11:12:21 +08:00
										 |  |  |  |     /** | 
					
						
							|  |  |  |  |      * @description: 地图选中feature事件 | 
					
						
							| 
									
										
										
										
											2024-11-29 15:34:10 +08:00
										 |  |  |  |      * @param {object} e | 
					
						
							|  |  |  |  |      * @return {void} | 
					
						
							| 
									
										
										
										
											2024-11-28 11:12:21 +08:00
										 |  |  |  |      */ | 
					
						
							| 
									
										
										
										
											2024-10-23 17:17:37 +08:00
										 |  |  |  |     featureSelect(e) { | 
					
						
							|  |  |  |  |       const map = this.$refs.roadMap.instance.get("map"); | 
					
						
							| 
									
										
										
										
											2024-11-21 11:52:44 +08:00
										 |  |  |  |       const selectedFeatures = e.selected; | 
					
						
							|  |  |  |  |       if (selectedFeatures.length > 0) { | 
					
						
							|  |  |  |  |         let feature = selectedFeatures[0]; | 
					
						
							| 
									
										
										
										
											2024-10-23 17:17:37 +08:00
										 |  |  |  |         let features = feature.get("features"); | 
					
						
							|  |  |  |  |         // 点击线段事件
 | 
					
						
							|  |  |  |  |         if (feature.getProperties().type === "line") { | 
					
						
							|  |  |  |  |           console.log(feature, "线段参数"); | 
					
						
							| 
									
										
										
										
											2024-12-04 09:50:55 +08:00
										 |  |  |  |         } else if (feature.getProperties().type === "carPoint") { | 
					
						
							|  |  |  |  |           console.log(feature, "小车点位"); | 
					
						
							| 
									
										
										
										
											2024-10-23 17:17:37 +08:00
										 |  |  |  |         } else { | 
					
						
							|  |  |  |  |           if (features.length === 1) { | 
					
						
							|  |  |  |  |             // 单个点位
 | 
					
						
							|  |  |  |  |             // 执行之前的业务逻辑
 | 
					
						
							|  |  |  |  |             // 获取点击的图层信息
 | 
					
						
							|  |  |  |  |             const selectFeature = feature.getProperties().features[0]; | 
					
						
							|  |  |  |  |             console.log(selectFeature, "点位"); | 
					
						
							|  |  |  |  |             // 获取点位数据
 | 
					
						
							| 
									
										
										
										
											2024-11-07 12:04:16 +08:00
										 |  |  |  |             this.screenImage = selectFeature.get("data"); | 
					
						
							|  |  |  |  |             this.showImageDialog = true; | 
					
						
							| 
									
										
										
										
											2024-12-04 09:50:55 +08:00
										 |  |  |  |             // console.log(selectFeature.get("data"));
 | 
					
						
							| 
									
										
										
										
											2024-10-23 17:17:37 +08:00
										 |  |  |  |           } else { | 
					
						
							|  |  |  |  |             // 聚合点
 | 
					
						
							|  |  |  |  |             // 放大地图层级
 | 
					
						
							|  |  |  |  |             map.getView().animate({ | 
					
						
							|  |  |  |  |               center: feature.getGeometry().getCoordinates(), | 
					
						
							|  |  |  |  |               zoom: map.getView().getZoom() + 1, | 
					
						
							|  |  |  |  |             }); | 
					
						
							|  |  |  |  |           } | 
					
						
							|  |  |  |  |         } | 
					
						
							| 
									
										
										
										
											2024-10-18 17:31:35 +08:00
										 |  |  |  |       } | 
					
						
							|  |  |  |  |     }, | 
					
						
							| 
									
										
										
										
											2024-11-07 09:30:17 +08:00
										 |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-11-28 11:12:21 +08:00
										 |  |  |  |     /** | 
					
						
							|  |  |  |  |      * @description: 数据栏切换事件 | 
					
						
							| 
									
										
										
										
											2024-11-29 15:34:10 +08:00
										 |  |  |  |      * @param {object} item | 
					
						
							|  |  |  |  |      * @return {void} | 
					
						
							| 
									
										
										
										
											2024-11-28 11:12:21 +08:00
										 |  |  |  |      */ | 
					
						
							| 
									
										
										
										
											2024-10-18 17:31:35 +08:00
										 |  |  |  |     changeElement(item) { | 
					
						
							|  |  |  |  |       if (this.elementDiv !== item) { | 
					
						
							|  |  |  |  |         this.elementDiv = item.component; | 
					
						
							| 
									
										
										
										
											2024-11-14 17:43:24 +08:00
										 |  |  |  |         this.roadSelect = ""; | 
					
						
							| 
									
										
										
										
											2024-11-11 14:40:40 +08:00
										 |  |  |  |         if (item.component === "OverviewScreen") { | 
					
						
							| 
									
										
										
										
											2024-11-14 17:43:24 +08:00
										 |  |  |  |           /* 清空线段图层 */ | 
					
						
							|  |  |  |  |           this.markLayerLines = null; | 
					
						
							| 
									
										
										
										
											2024-10-18 17:31:35 +08:00
										 |  |  |  |           this.leftModuleList = [ | 
					
						
							|  |  |  |  |             { | 
					
						
							|  |  |  |  |               width: "100%", | 
					
						
							| 
									
										
										
										
											2024-10-31 14:39:01 +08:00
										 |  |  |  |               height: "27%", | 
					
						
							| 
									
										
										
										
											2024-10-18 17:31:35 +08:00
										 |  |  |  |               title: "今日巡查", | 
					
						
							|  |  |  |  |               component: TodayInspection, | 
					
						
							|  |  |  |  |               selectIsShow: false, | 
					
						
							|  |  |  |  |               class: "one", | 
					
						
							|  |  |  |  |             }, | 
					
						
							|  |  |  |  |             { | 
					
						
							|  |  |  |  |               width: "100%", | 
					
						
							| 
									
										
										
										
											2024-10-31 14:39:01 +08:00
										 |  |  |  |               height: "27%", | 
					
						
							| 
									
										
										
										
											2024-10-18 17:31:35 +08:00
										 |  |  |  |               title: "病害趋势", | 
					
						
							|  |  |  |  |               component: DiseaseTrends, | 
					
						
							|  |  |  |  |               selectIsShow: false, | 
					
						
							|  |  |  |  |               class: "twe", | 
					
						
							|  |  |  |  |             }, | 
					
						
							|  |  |  |  |             { | 
					
						
							|  |  |  |  |               width: "100%", | 
					
						
							| 
									
										
										
										
											2024-10-31 14:39:01 +08:00
										 |  |  |  |               height: "29%", | 
					
						
							| 
									
										
										
										
											2024-11-13 15:37:25 +08:00
										 |  |  |  |               title: "病害统计", | 
					
						
							| 
									
										
										
										
											2024-10-18 17:31:35 +08:00
										 |  |  |  |               component: DiseaseCurrent, | 
					
						
							| 
									
										
										
										
											2024-10-22 09:55:33 +08:00
										 |  |  |  |               selectIsShow: true, | 
					
						
							| 
									
										
										
										
											2024-10-25 17:29:08 +08:00
										 |  |  |  |               select: "", | 
					
						
							| 
									
										
										
										
											2024-10-18 17:31:35 +08:00
										 |  |  |  |               class: "twe", | 
					
						
							|  |  |  |  |             }, | 
					
						
							|  |  |  |  |           ]; | 
					
						
							|  |  |  |  |           this.rightModuleList = [ | 
					
						
							|  |  |  |  |             { | 
					
						
							|  |  |  |  |               width: "100%", | 
					
						
							| 
									
										
										
										
											2024-11-13 15:37:25 +08:00
										 |  |  |  |               height: "18%", | 
					
						
							| 
									
										
										
										
											2024-11-11 14:40:40 +08:00
										 |  |  |  |               title: "巡查里程", | 
					
						
							|  |  |  |  |               component: PatrolOrder, | 
					
						
							| 
									
										
										
										
											2024-10-18 17:31:35 +08:00
										 |  |  |  |               selectIsShow: false, | 
					
						
							|  |  |  |  |               class: "one", | 
					
						
							|  |  |  |  |             }, | 
					
						
							|  |  |  |  |             { | 
					
						
							|  |  |  |  |               width: "100%", | 
					
						
							| 
									
										
										
										
											2024-11-13 15:37:25 +08:00
										 |  |  |  |               height: "65%", | 
					
						
							| 
									
										
										
										
											2024-11-11 14:40:40 +08:00
										 |  |  |  |               title: "巡检车辆", | 
					
						
							|  |  |  |  |               component: InspectionVehicles, | 
					
						
							| 
									
										
										
										
											2024-10-18 17:31:35 +08:00
										 |  |  |  |               selectIsShow: false, | 
					
						
							|  |  |  |  |               class: "twe", | 
					
						
							|  |  |  |  |             }, | 
					
						
							|  |  |  |  |           ]; | 
					
						
							| 
									
										
										
										
											2024-11-29 15:34:10 +08:00
										 |  |  |  |           // 不接收小车位置消息
 | 
					
						
							|  |  |  |  |           const data = { type: "carLocation", status: false }; | 
					
						
							|  |  |  |  |           this.$ws.send(data); | 
					
						
							| 
									
										
										
										
											2024-12-04 09:50:55 +08:00
										 |  |  |  |           this.carPointList = []; | 
					
						
							|  |  |  |  |           this.mapPointFeatures = []; | 
					
						
							| 
									
										
										
										
											2024-11-14 17:43:24 +08:00
										 |  |  |  |           // 地图右上角多选按钮隐藏
 | 
					
						
							|  |  |  |  |           this.showIconList = false; | 
					
						
							|  |  |  |  |           // 图层恢复
 | 
					
						
							| 
									
										
										
										
											2024-11-15 11:03:30 +08:00
										 |  |  |  |           this.mapZoom = ""; | 
					
						
							| 
									
										
										
										
											2024-10-18 17:31:35 +08:00
										 |  |  |  |         } else if (item.component === "RoadScreen") { | 
					
						
							|  |  |  |  |           this.leftModuleList = [ | 
					
						
							|  |  |  |  |             { | 
					
						
							|  |  |  |  |               width: "100%", | 
					
						
							| 
									
										
										
										
											2024-10-31 14:39:01 +08:00
										 |  |  |  |               height: "17%", | 
					
						
							| 
									
										
										
										
											2024-10-18 17:31:35 +08:00
										 |  |  |  |               title: "管养道路统计", | 
					
						
							|  |  |  |  |               component: ManageMaintain, | 
					
						
							|  |  |  |  |               selectIsShow: false, | 
					
						
							|  |  |  |  |               class: "one", | 
					
						
							|  |  |  |  |             }, | 
					
						
							|  |  |  |  |             { | 
					
						
							|  |  |  |  |               width: "100%", | 
					
						
							| 
									
										
										
										
											2024-10-31 14:39:01 +08:00
										 |  |  |  |               height: "55%", | 
					
						
							| 
									
										
										
										
											2024-10-18 17:31:35 +08:00
										 |  |  |  |               title: "附属设施分布", | 
					
						
							|  |  |  |  |               component: AncillaryFacilities, | 
					
						
							|  |  |  |  |               selectIsShow: false, | 
					
						
							|  |  |  |  |               class: "twe", | 
					
						
							|  |  |  |  |             }, | 
					
						
							|  |  |  |  |           ]; | 
					
						
							|  |  |  |  |           this.rightModuleList = [ | 
					
						
							|  |  |  |  |             { | 
					
						
							|  |  |  |  |               width: "100%", | 
					
						
							| 
									
										
										
										
											2024-10-31 14:39:01 +08:00
										 |  |  |  |               height: "29%", | 
					
						
							| 
									
										
										
										
											2024-10-18 17:31:35 +08:00
										 |  |  |  |               title: "附属设施异常统计", | 
					
						
							|  |  |  |  |               component: AnomalyFacilities, | 
					
						
							| 
									
										
										
										
											2024-10-22 09:55:33 +08:00
										 |  |  |  |               selectIsShow: true, | 
					
						
							| 
									
										
										
										
											2024-10-25 17:29:08 +08:00
										 |  |  |  |               select: "", | 
					
						
							| 
									
										
										
										
											2024-10-18 17:31:35 +08:00
										 |  |  |  |               class: "one", | 
					
						
							|  |  |  |  |             }, | 
					
						
							|  |  |  |  |             { | 
					
						
							|  |  |  |  |               width: "100%", | 
					
						
							| 
									
										
										
										
											2024-10-31 14:39:01 +08:00
										 |  |  |  |               height: "57%", | 
					
						
							| 
									
										
										
										
											2024-10-18 17:31:35 +08:00
										 |  |  |  |               title: "路产统计", | 
					
						
							|  |  |  |  |               component: RoadStatistic, | 
					
						
							| 
									
										
										
										
											2024-10-22 09:55:33 +08:00
										 |  |  |  |               selectIsShow: true, | 
					
						
							| 
									
										
										
										
											2024-10-25 17:29:08 +08:00
										 |  |  |  |               select: "", | 
					
						
							| 
									
										
										
										
											2024-10-22 09:55:33 +08:00
										 |  |  |  |               class: "twe", | 
					
						
							|  |  |  |  |             }, | 
					
						
							|  |  |  |  |           ]; | 
					
						
							| 
									
										
										
										
											2024-11-29 15:34:10 +08:00
										 |  |  |  |           // 发送小车位置消息
 | 
					
						
							|  |  |  |  |           const data = { type: "carLocation", status: true }; | 
					
						
							|  |  |  |  |           this.$ws.send(data); | 
					
						
							|  |  |  |  |           // 将地图层级初始化
 | 
					
						
							| 
									
										
										
										
											2024-11-14 17:43:24 +08:00
										 |  |  |  |           this.$nextTick(() => { | 
					
						
							|  |  |  |  |             const map = this.$refs.roadMap.instance.get("map"); | 
					
						
							|  |  |  |  |             map.getView().setZoom(10); | 
					
						
							|  |  |  |  |             map.getView().setCenter([123.30297096718999, 41.87942945541742]); | 
					
						
							|  |  |  |  |           }); | 
					
						
							|  |  |  |  |           // 地图右上角多选按钮显示
 | 
					
						
							|  |  |  |  |           this.getIconType(); | 
					
						
							|  |  |  |  |           this.showIconList = true; | 
					
						
							|  |  |  |  |           // 进行地图打点
 | 
					
						
							|  |  |  |  |           this.getCenterPiont(); | 
					
						
							|  |  |  |  |           this.getLinePoint(); | 
					
						
							| 
									
										
										
										
											2024-11-11 14:40:40 +08:00
										 |  |  |  |         } else if (item.component === "DiseaseScreen") { | 
					
						
							| 
									
										
										
										
											2024-10-22 09:55:33 +08:00
										 |  |  |  |           this.leftModuleList = [ | 
					
						
							|  |  |  |  |             { | 
					
						
							|  |  |  |  |               width: "100%", | 
					
						
							| 
									
										
										
										
											2024-10-31 14:39:01 +08:00
										 |  |  |  |               height: "27%", | 
					
						
							| 
									
										
										
										
											2024-11-13 15:37:25 +08:00
										 |  |  |  |               title: "今日巡查", | 
					
						
							| 
									
										
										
										
											2024-10-22 09:55:33 +08:00
										 |  |  |  |               component: TrafficSafety, | 
					
						
							|  |  |  |  |               selectIsShow: false, | 
					
						
							|  |  |  |  |               class: "one", | 
					
						
							|  |  |  |  |             }, | 
					
						
							|  |  |  |  |             { | 
					
						
							|  |  |  |  |               width: "100%", | 
					
						
							| 
									
										
										
										
											2024-10-31 14:39:01 +08:00
										 |  |  |  |               height: "27%", | 
					
						
							| 
									
										
										
										
											2024-11-26 16:26:39 +08:00
										 |  |  |  |               title: "主要病害趋势", | 
					
						
							| 
									
										
										
										
											2024-10-22 09:55:33 +08:00
										 |  |  |  |               component: TrafficTrend, | 
					
						
							| 
									
										
										
										
											2024-10-25 17:29:08 +08:00
										 |  |  |  |               selectIsShow: true, | 
					
						
							| 
									
										
										
										
											2024-10-22 09:55:33 +08:00
										 |  |  |  |               class: "twe", | 
					
						
							|  |  |  |  |             }, | 
					
						
							|  |  |  |  |             { | 
					
						
							|  |  |  |  |               width: "100%", | 
					
						
							| 
									
										
										
										
											2024-10-31 14:39:01 +08:00
										 |  |  |  |               height: "33%", | 
					
						
							| 
									
										
										
										
											2024-11-13 15:37:25 +08:00
										 |  |  |  |               title: "病害统计", | 
					
						
							| 
									
										
										
										
											2024-10-22 09:55:33 +08:00
										 |  |  |  |               component: TrafficStatistic, | 
					
						
							|  |  |  |  |               selectIsShow: true, | 
					
						
							| 
									
										
										
										
											2024-10-25 17:29:08 +08:00
										 |  |  |  |               select: "", | 
					
						
							| 
									
										
										
										
											2024-10-22 09:55:33 +08:00
										 |  |  |  |               class: "twe", | 
					
						
							|  |  |  |  |             }, | 
					
						
							|  |  |  |  |           ]; | 
					
						
							|  |  |  |  |           this.rightModuleList = [ | 
					
						
							|  |  |  |  |             { | 
					
						
							|  |  |  |  |               width: "100%", | 
					
						
							| 
									
										
										
										
											2024-11-11 14:40:40 +08:00
										 |  |  |  |               height: "85%", | 
					
						
							| 
									
										
										
										
											2024-11-13 15:37:25 +08:00
										 |  |  |  |               title: "病害日志", | 
					
						
							| 
									
										
										
										
											2024-11-11 14:40:40 +08:00
										 |  |  |  |               component: TrafficLog, | 
					
						
							| 
									
										
										
										
											2024-11-13 15:37:25 +08:00
										 |  |  |  |               selectIsShow: false, | 
					
						
							| 
									
										
										
										
											2024-10-25 17:29:08 +08:00
										 |  |  |  |               select: "", | 
					
						
							| 
									
										
										
										
											2024-10-22 09:55:33 +08:00
										 |  |  |  |               class: "one", | 
					
						
							|  |  |  |  |             }, | 
					
						
							| 
									
										
										
										
											2024-10-18 17:31:35 +08:00
										 |  |  |  |           ]; | 
					
						
							| 
									
										
										
										
											2024-11-29 15:34:10 +08:00
										 |  |  |  |           // 发送小车位置消息
 | 
					
						
							|  |  |  |  |           const data = { type: "carLocation", status: true }; | 
					
						
							|  |  |  |  |           this.$ws.send(data); | 
					
						
							| 
									
										
										
										
											2024-11-19 14:18:57 +08:00
										 |  |  |  |           // 地图右上角多选按钮隐藏
 | 
					
						
							|  |  |  |  |           this.showIconList = false; | 
					
						
							|  |  |  |  |           // 图层恢复
 | 
					
						
							|  |  |  |  |           this.mapZoom = ""; | 
					
						
							| 
									
										
										
										
											2024-11-14 17:43:24 +08:00
										 |  |  |  |           this.$nextTick(() => { | 
					
						
							|  |  |  |  |             const map = this.$refs.roadMap.instance.get("map"); | 
					
						
							| 
									
										
										
										
											2024-11-19 14:18:57 +08:00
										 |  |  |  |             map.removeLayer(this.clusters); | 
					
						
							|  |  |  |  |             this.clusters = null; | 
					
						
							| 
									
										
										
										
											2024-11-14 17:43:24 +08:00
										 |  |  |  |             map.getView().setZoom(10); | 
					
						
							|  |  |  |  |             map.getView().setCenter([123.30297096718999, 41.87942945541742]); | 
					
						
							|  |  |  |  |           }); | 
					
						
							|  |  |  |  |           this.getLinePoint(); | 
					
						
							| 
									
										
										
										
											2024-10-18 17:31:35 +08:00
										 |  |  |  |         } | 
					
						
							|  |  |  |  |       } | 
					
						
							|  |  |  |  |     }, | 
					
						
							| 
									
										
										
										
											2024-11-07 09:30:17 +08:00
										 |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-11-29 17:59:17 +08:00
										 |  |  |  |     /** | 
					
						
							|  |  |  |  |      * @description: 处理websocket消息 | 
					
						
							|  |  |  |  |      * @return {*} | 
					
						
							|  |  |  |  |      */ | 
					
						
							|  |  |  |  |     handleMessage() { | 
					
						
							| 
									
										
										
										
											2024-12-04 09:50:55 +08:00
										 |  |  |  |       this.$ws.on("message", (itemMessage) => { | 
					
						
							|  |  |  |  |         if (itemMessage.type === "carPosition") { | 
					
						
							|  |  |  |  |           if (this.carPointList.includes(itemMessage.data.entityId)) { | 
					
						
							| 
									
										
										
										
											2024-12-02 10:29:27 +08:00
										 |  |  |  |             // 获取当前位置和目标位置
 | 
					
						
							| 
									
										
										
										
											2024-12-04 09:50:55 +08:00
										 |  |  |  |             this.carMapPointSource.getFeatures().forEach((item) => { | 
					
						
							|  |  |  |  |               if (item.get("data") === itemMessage.data.entityId) { | 
					
						
							|  |  |  |  |                 const currentLocation = item.getGeometry().getCoordinates(); | 
					
						
							|  |  |  |  |                 const targetLocation = itemMessage.data.location; | 
					
						
							|  |  |  |  |                 // 计算两点之间的差值
 | 
					
						
							|  |  |  |  |                 const dx = | 
					
						
							|  |  |  |  |                   (targetLocation[0] * 1 - currentLocation[0] * 1) / 100; | 
					
						
							|  |  |  |  |                 const dy = | 
					
						
							|  |  |  |  |                   (targetLocation[1] * 1 - currentLocation[1] * 1) / 100; | 
					
						
							|  |  |  |  |                 // 设置计数器
 | 
					
						
							|  |  |  |  |                 let count = 0; | 
					
						
							|  |  |  |  |                 // 创建定时器,每10ms移动一次,总共移动100次,约1秒完成
 | 
					
						
							|  |  |  |  |                 const timer = setInterval(() => { | 
					
						
							|  |  |  |  |                   count++; | 
					
						
							|  |  |  |  |                   if (count >= 100) { | 
					
						
							|  |  |  |  |                     clearInterval(timer); | 
					
						
							|  |  |  |  |                     return; | 
					
						
							|  |  |  |  |                   } | 
					
						
							| 
									
										
										
										
											2024-12-02 10:29:27 +08:00
										 |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-12-04 09:50:55 +08:00
										 |  |  |  |                   // 计算当前帧的位置
 | 
					
						
							|  |  |  |  |                   const x = currentLocation[0] * 1 + dx * count; | 
					
						
							|  |  |  |  |                   const y = currentLocation[1] * 1 + dy * count; | 
					
						
							| 
									
										
										
										
											2024-12-02 10:29:27 +08:00
										 |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-12-04 09:50:55 +08:00
										 |  |  |  |                   // 更新小车位置
 | 
					
						
							|  |  |  |  |                   // const [features] = this.carMapPointSource.getFeatures();
 | 
					
						
							|  |  |  |  |                   item.setGeometry(new Point([x, y])); | 
					
						
							|  |  |  |  |                   item.setStyle([ | 
					
						
							|  |  |  |  |                     new Style({ | 
					
						
							|  |  |  |  |                       image: new Icon({ | 
					
						
							|  |  |  |  |                         crossOrigin: "anonymous", | 
					
						
							|  |  |  |  |                         src: logo, | 
					
						
							|  |  |  |  |                         // 图标缩放比例
 | 
					
						
							| 
									
										
										
										
											2024-12-10 10:43:44 +08:00
										 |  |  |  |                         scale: 0.5, | 
					
						
							| 
									
										
										
										
											2024-12-04 09:50:55 +08:00
										 |  |  |  |                         // 将角度转换为弧度,并除以180*π
 | 
					
						
							|  |  |  |  |                         rotation: | 
					
						
							|  |  |  |  |                           (itemMessage.data.direction - 90) * (Math.PI / 180), | 
					
						
							|  |  |  |  |                       }), | 
					
						
							|  |  |  |  |                     }), | 
					
						
							|  |  |  |  |                   ]); | 
					
						
							|  |  |  |  |                 }, 10); | 
					
						
							|  |  |  |  |               } | 
					
						
							|  |  |  |  |             }); | 
					
						
							|  |  |  |  |           } else { | 
					
						
							|  |  |  |  |             this.carPointList.push(itemMessage.data.entityId); | 
					
						
							|  |  |  |  |             this.drawCarMapPoint(itemMessage.data); | 
					
						
							| 
									
										
										
										
											2024-11-29 17:59:17 +08:00
										 |  |  |  |           } | 
					
						
							|  |  |  |  |         } | 
					
						
							|  |  |  |  |       }); | 
					
						
							|  |  |  |  |     }, | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |     /** | 
					
						
							|  |  |  |  |      * @description: 绘制小车地图点位 | 
					
						
							|  |  |  |  |      * @param {object} item | 
					
						
							|  |  |  |  |      * @return {void} | 
					
						
							|  |  |  |  |      */ | 
					
						
							|  |  |  |  |     drawCarMapPoint(item) { | 
					
						
							| 
									
										
										
										
											2024-12-04 09:50:55 +08:00
										 |  |  |  |       // const features = [];
 | 
					
						
							| 
									
										
										
										
											2024-11-29 17:59:17 +08:00
										 |  |  |  |       const feature = new Feature({ | 
					
						
							|  |  |  |  |         geometry: new Point(item.location), | 
					
						
							| 
									
										
										
										
											2024-12-04 09:50:55 +08:00
										 |  |  |  |         data: item.entityId, | 
					
						
							| 
									
										
										
										
											2024-11-29 17:59:17 +08:00
										 |  |  |  |         type: "carPoint", | 
					
						
							|  |  |  |  |       }); | 
					
						
							|  |  |  |  |       // 可以给点位设置样式
 | 
					
						
							|  |  |  |  |       feature.setStyle([ | 
					
						
							|  |  |  |  |         new Style({ | 
					
						
							|  |  |  |  |           image: new Icon({ | 
					
						
							|  |  |  |  |             crossOrigin: "anonymous", | 
					
						
							|  |  |  |  |             src: logo, | 
					
						
							|  |  |  |  |             // 图标缩放比例
 | 
					
						
							| 
									
										
										
										
											2024-12-10 10:43:44 +08:00
										 |  |  |  |             scale: 0.5, | 
					
						
							| 
									
										
										
										
											2024-11-29 17:59:17 +08:00
										 |  |  |  |             // 将角度转换为弧度,并除以180*π
 | 
					
						
							|  |  |  |  |             rotation: item.direction * (Math.PI / 180), | 
					
						
							|  |  |  |  |           }), | 
					
						
							|  |  |  |  |         }), | 
					
						
							|  |  |  |  |       ]); | 
					
						
							| 
									
										
										
										
											2024-12-04 09:50:55 +08:00
										 |  |  |  |       this.mapPointFeatures.push(feature); | 
					
						
							| 
									
										
										
										
											2024-11-29 17:59:17 +08:00
										 |  |  |  |       this.carMapPointSource = new VectorSource({ | 
					
						
							| 
									
										
										
										
											2024-12-04 09:50:55 +08:00
										 |  |  |  |         features: this.mapPointFeatures, | 
					
						
							| 
									
										
										
										
											2024-11-29 17:59:17 +08:00
										 |  |  |  |       }); | 
					
						
							|  |  |  |  |       const carMapPointLayer = new VectorLayer({ | 
					
						
							|  |  |  |  |         source: this.carMapPointSource, | 
					
						
							|  |  |  |  |         properties: { | 
					
						
							|  |  |  |  |           type: "carPoint", | 
					
						
							|  |  |  |  |         }, | 
					
						
							|  |  |  |  |       }); | 
					
						
							|  |  |  |  |       this.$nextTick(() => { | 
					
						
							|  |  |  |  |         const map = this.$refs.roadMap.instance.get("map"); | 
					
						
							|  |  |  |  |         map.addLayer(carMapPointLayer); | 
					
						
							|  |  |  |  |       }); | 
					
						
							|  |  |  |  |     }, | 
					
						
							|  |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-11-28 11:12:21 +08:00
										 |  |  |  |     /** | 
					
						
							|  |  |  |  |      * @description: 跳转系统首页 | 
					
						
							| 
									
										
										
										
											2024-11-29 15:34:10 +08:00
										 |  |  |  |      * @return {void} | 
					
						
							| 
									
										
										
										
											2024-11-28 11:12:21 +08:00
										 |  |  |  |      */ | 
					
						
							| 
									
										
										
										
											2024-10-18 17:31:35 +08:00
										 |  |  |  |     goIndex() { | 
					
						
							|  |  |  |  |       this.$router.push("/index"); | 
					
						
							|  |  |  |  |     }, | 
					
						
							| 
									
										
										
										
											2024-11-07 12:04:16 +08:00
										 |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-11-28 11:12:21 +08:00
										 |  |  |  |     /** | 
					
						
							|  |  |  |  |      * @description: 图片位置信息获取 | 
					
						
							| 
									
										
										
										
											2024-11-29 15:34:10 +08:00
										 |  |  |  |      * @return {void} | 
					
						
							| 
									
										
										
										
											2024-11-28 11:12:21 +08:00
										 |  |  |  |      */ | 
					
						
							| 
									
										
										
										
											2024-11-07 12:04:16 +08:00
										 |  |  |  |     updateScreenRects() { | 
					
						
							| 
									
										
										
										
											2024-11-07 12:51:04 +08:00
										 |  |  |  |       1; | 
					
						
							| 
									
										
										
										
											2024-11-07 12:04:16 +08:00
										 |  |  |  |       this.screenRects = []; | 
					
						
							|  |  |  |  |       const image = this.$refs.mainImage; | 
					
						
							|  |  |  |  |       const rects = this.screenImage?.rect?.split(",").map(Number) || []; | 
					
						
							|  |  |  |  |       this.screenRects = [ | 
					
						
							|  |  |  |  |         { | 
					
						
							|  |  |  |  |           left: rects[0], | 
					
						
							|  |  |  |  |           top: rects[1], | 
					
						
							|  |  |  |  |           width: rects[2], | 
					
						
							|  |  |  |  |           height: rects[3], | 
					
						
							|  |  |  |  |         }, | 
					
						
							|  |  |  |  |       ]; | 
					
						
							|  |  |  |  |     }, | 
					
						
							|  |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-11-28 11:12:21 +08:00
										 |  |  |  |     /** | 
					
						
							|  |  |  |  |      * @description: 图片红框位置 | 
					
						
							| 
									
										
										
										
											2024-11-29 15:34:10 +08:00
										 |  |  |  |      * @param {object} left | 
					
						
							|  |  |  |  |      * @param {object} top | 
					
						
							|  |  |  |  |      * @param {object} width | 
					
						
							|  |  |  |  |      * @param {object} height | 
					
						
							|  |  |  |  |      * @return {object} | 
					
						
							| 
									
										
										
										
											2024-11-28 11:12:21 +08:00
										 |  |  |  |      */ | 
					
						
							| 
									
										
										
										
											2024-11-07 12:04:16 +08:00
										 |  |  |  |     getScreenRectStyle({ left, top, width, height }) { | 
					
						
							|  |  |  |  |       const image = this.$refs.mainImage; | 
					
						
							|  |  |  |  |       const container = this.$refs.imageContainer; | 
					
						
							|  |  |  |  |       if (!image || !container) return {}; | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |       const scaleX = container.clientWidth / image.naturalWidth; | 
					
						
							|  |  |  |  |       const scaleY = container.clientHeight / image.naturalHeight; | 
					
						
							|  |  |  |  |       const scale = Math.min(scaleX, scaleY); | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |       const renderedWidth = image.naturalWidth * scale; | 
					
						
							|  |  |  |  |       const renderedHeight = image.naturalHeight * scale; | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |       const offsetX = (container.clientWidth - renderedWidth) / 2; | 
					
						
							|  |  |  |  |       const offsetY = (container.clientHeight - renderedHeight) / 2; | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |       return { | 
					
						
							|  |  |  |  |         position: "absolute", | 
					
						
							|  |  |  |  |         left: `${left * scale + offsetX}px`, | 
					
						
							|  |  |  |  |         top: `${top * scale + offsetY}px`, | 
					
						
							|  |  |  |  |         width: `${width * scale}px`, | 
					
						
							|  |  |  |  |         height: `${height * scale}px`, | 
					
						
							|  |  |  |  |         border: "2px solid #FF0000", | 
					
						
							|  |  |  |  |         boxSizing: "border-box", | 
					
						
							|  |  |  |  |       }; | 
					
						
							|  |  |  |  |     }, | 
					
						
							| 
									
										
										
										
											2024-10-18 17:31:35 +08:00
										 |  |  |  |   }, | 
					
						
							|  |  |  |  |   beforeDestroy() { | 
					
						
							| 
									
										
										
										
											2024-12-05 17:25:06 +08:00
										 |  |  |  |     clearInterval(this.messageTimer); | 
					
						
							| 
									
										
										
										
											2024-10-18 17:31:35 +08:00
										 |  |  |  |     clearInterval(this.timeFlag); | 
					
						
							| 
									
										
										
										
											2024-12-02 10:52:22 +08:00
										 |  |  |  |     // 发送停止接收小车位置
 | 
					
						
							| 
									
										
										
										
											2024-11-29 17:59:17 +08:00
										 |  |  |  |     const data = { type: "carLocation", status: false }; | 
					
						
							|  |  |  |  |     this.$ws.send(data); | 
					
						
							| 
									
										
										
										
											2024-10-18 17:31:35 +08:00
										 |  |  |  |   }, | 
					
						
							|  |  |  |  | }; | 
					
						
							|  |  |  |  | </script> | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  | <style lang="scss" scoped> | 
					
						
							|  |  |  |  | .screen-content { | 
					
						
							|  |  |  |  |   width: 100%; | 
					
						
							|  |  |  |  |   height: 100%; | 
					
						
							|  |  |  |  | } | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  | // 中间样式
 | 
					
						
							|  |  |  |  | .screen-middle { | 
					
						
							|  |  |  |  |   width: 100%; | 
					
						
							|  |  |  |  |   height: 100%; | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |   .screen-left { | 
					
						
							|  |  |  |  |     width: 25.5%; | 
					
						
							|  |  |  |  |     height: calc(100% - 5rem); | 
					
						
							|  |  |  |  |     padding-left: 3.5rem; | 
					
						
							|  |  |  |  |     position: fixed; | 
					
						
							|  |  |  |  |     top: 5rem; | 
					
						
							|  |  |  |  |     z-index: 1; | 
					
						
							|  |  |  |  |     background-image: url("../../assets/screen/index/bg-left.png"); | 
					
						
							|  |  |  |  |     background-repeat: no-repeat; | 
					
						
							|  |  |  |  |     background-size: 100% 100%; | 
					
						
							| 
									
										
										
										
											2024-10-23 17:17:37 +08:00
										 |  |  |  | 
 | 
					
						
							|  |  |  |  |     ::v-deep .screen-checkBox { | 
					
						
							|  |  |  |  |       .el-radio-button__inner { | 
					
						
							|  |  |  |  |         background-color: transparent; | 
					
						
							|  |  |  |  |         padding: 0 0.3rem; | 
					
						
							|  |  |  |  |         border: none; | 
					
						
							|  |  |  |  |       } | 
					
						
							|  |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-12-09 15:35:13 +08:00
										 |  |  |  |       .el-radio-button__orig-radio:checked + .el-radio-button__inner { | 
					
						
							| 
									
										
										
										
											2024-10-23 17:17:37 +08:00
										 |  |  |  |         color: #1cb6ff; | 
					
						
							|  |  |  |  |       } | 
					
						
							|  |  |  |  |     } | 
					
						
							| 
									
										
										
										
											2024-10-18 17:31:35 +08:00
										 |  |  |  |   } | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |   .screen-right { | 
					
						
							|  |  |  |  |     width: 25.5%; | 
					
						
							|  |  |  |  |     height: calc(100% - 5rem); | 
					
						
							|  |  |  |  |     top: 5rem; | 
					
						
							|  |  |  |  |     padding-right: 3.5rem; | 
					
						
							|  |  |  |  |     position: fixed; | 
					
						
							|  |  |  |  |     right: 0; | 
					
						
							|  |  |  |  |     z-index: 1; | 
					
						
							|  |  |  |  |     background-image: url("../../assets/screen/index/bg-right.png"); | 
					
						
							|  |  |  |  |     background-repeat: no-repeat; | 
					
						
							|  |  |  |  |     background-size: 100% 100%; | 
					
						
							|  |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-10-23 17:17:37 +08:00
										 |  |  |  |     ::v-deep .screen-checkBox { | 
					
						
							|  |  |  |  |       .el-radio-button__inner { | 
					
						
							|  |  |  |  |         background-color: transparent; | 
					
						
							|  |  |  |  |         padding: 0 0.3rem; | 
					
						
							|  |  |  |  |         border: none; | 
					
						
							|  |  |  |  |       } | 
					
						
							|  |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-12-09 15:35:13 +08:00
										 |  |  |  |       .el-radio-button__orig-radio:checked + .el-radio-button__inner { | 
					
						
							| 
									
										
										
										
											2024-10-23 17:17:37 +08:00
										 |  |  |  |         color: #1cb6ff; | 
					
						
							|  |  |  |  |       } | 
					
						
							|  |  |  |  |     } | 
					
						
							| 
									
										
										
										
											2024-10-18 17:31:35 +08:00
										 |  |  |  |   } | 
					
						
							| 
									
										
										
										
											2024-10-22 09:55:33 +08:00
										 |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-10-23 17:17:37 +08:00
										 |  |  |  |   .road-content { | 
					
						
							|  |  |  |  |     width: 100%; | 
					
						
							|  |  |  |  |     height: 100%; | 
					
						
							|  |  |  |  |     position: relative; | 
					
						
							|  |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-11-11 14:40:40 +08:00
										 |  |  |  |     // 图例
 | 
					
						
							|  |  |  |  |     .map-legend { | 
					
						
							|  |  |  |  |       height: 7rem; | 
					
						
							|  |  |  |  |       width: 2rem; | 
					
						
							| 
									
										
										
										
											2024-10-23 17:17:37 +08:00
										 |  |  |  |       position: absolute; | 
					
						
							| 
									
										
										
										
											2024-11-11 14:40:40 +08:00
										 |  |  |  |       top: 17%; | 
					
						
							|  |  |  |  |       left: 26%; | 
					
						
							|  |  |  |  |       z-index: 1; | 
					
						
							|  |  |  |  |       background-image: url("../../assets/screen/index/map-legend.png"); | 
					
						
							|  |  |  |  |       background-repeat: no-repeat; | 
					
						
							|  |  |  |  |       background-size: 100% 100%; | 
					
						
							| 
									
										
										
										
											2024-10-22 09:55:33 +08:00
										 |  |  |  |     } | 
					
						
							|  |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-10-23 17:17:37 +08:00
										 |  |  |  |     // 右上角切换图标样式多选框
 | 
					
						
							|  |  |  |  |     .road-checkBox { | 
					
						
							|  |  |  |  |       width: 8rem; | 
					
						
							|  |  |  |  |       height: 10rem; | 
					
						
							|  |  |  |  |       position: absolute; | 
					
						
							| 
									
										
										
										
											2024-10-25 17:29:08 +08:00
										 |  |  |  |       right: 26%; | 
					
						
							|  |  |  |  |       top: 10%; | 
					
						
							| 
									
										
										
										
											2024-10-23 17:17:37 +08:00
										 |  |  |  |       padding: 0.4rem; | 
					
						
							|  |  |  |  |       border-radius: 0.4rem; | 
					
						
							|  |  |  |  |       border: 1px solid #193dae; | 
					
						
							|  |  |  |  |       background-color: #082843; | 
					
						
							|  |  |  |  |       z-index: 1; | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |       .road-scroll { | 
					
						
							|  |  |  |  |         overflow-x: hidden; | 
					
						
							|  |  |  |  |       } | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |       ::v-deep .el-checkbox__label { | 
					
						
							|  |  |  |  |         color: #9aadd8; | 
					
						
							|  |  |  |  |       } | 
					
						
							|  |  |  |  |     } | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |     // 图片背景样式
 | 
					
						
							|  |  |  |  |     .disease-content { | 
					
						
							|  |  |  |  |       width: 100%; | 
					
						
							|  |  |  |  |       height: 100%; | 
					
						
							|  |  |  |  |       background-image: url("../../assets/screen/index/map-liaoning.jpg"); | 
					
						
							|  |  |  |  |       background-repeat: no-repeat; | 
					
						
							|  |  |  |  |       background-size: 100% 100%; | 
					
						
							|  |  |  |  |       position: relative; | 
					
						
							|  |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-10-25 17:29:08 +08:00
										 |  |  |  |       // 标题
 | 
					
						
							| 
									
										
										
										
											2024-10-23 17:17:37 +08:00
										 |  |  |  |       .disease-title { | 
					
						
							|  |  |  |  |         width: 20rem; | 
					
						
							|  |  |  |  |         height: 2.8rem; | 
					
						
							|  |  |  |  |         position: absolute; | 
					
						
							|  |  |  |  |         // top: 5rem;
 | 
					
						
							|  |  |  |  |         left: 50%; | 
					
						
							|  |  |  |  |         transform: translate(-50%, 5rem); | 
					
						
							|  |  |  |  |         background-image: url("../../assets/screen/index/disease-title.png"); | 
					
						
							|  |  |  |  |         background-repeat: no-repeat; | 
					
						
							|  |  |  |  |         background-size: 100%; | 
					
						
							|  |  |  |  |       } | 
					
						
							| 
									
										
										
										
											2024-10-25 17:29:08 +08:00
										 |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-11-11 14:40:40 +08:00
										 |  |  |  |       // 筛选病害类型下拉
 | 
					
						
							|  |  |  |  |       .map-image-select { | 
					
						
							| 
									
										
										
										
											2024-10-29 14:46:32 +08:00
										 |  |  |  |         left: 28%; | 
					
						
							| 
									
										
										
										
											2024-11-11 14:40:40 +08:00
										 |  |  |  |         top: 10%; | 
					
						
							| 
									
										
										
										
											2024-12-10 12:59:10 +08:00
										 |  |  |  |         font-size: 1rem; | 
					
						
							| 
									
										
										
										
											2024-11-11 14:40:40 +08:00
										 |  |  |  |         position: absolute; | 
					
						
							| 
									
										
										
										
											2024-11-13 15:37:25 +08:00
										 |  |  |  |         color: #ffffff; | 
					
						
							| 
									
										
										
										
											2024-10-25 17:29:08 +08:00
										 |  |  |  |       } | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |       // 打点部分
 | 
					
						
							|  |  |  |  |       .map-care { | 
					
						
							|  |  |  |  |         width: 48%; | 
					
						
							|  |  |  |  |         height: 73%; | 
					
						
							|  |  |  |  |         position: absolute; | 
					
						
							|  |  |  |  |         left: 26%; | 
					
						
							|  |  |  |  |         top: 13%; | 
					
						
							| 
									
										
										
										
											2024-10-28 10:00:28 +08:00
										 |  |  |  | 
 | 
					
						
							|  |  |  |  |         .map-care-div { | 
					
						
							|  |  |  |  |           height: 8.5rem; | 
					
						
							|  |  |  |  |           min-width: 3.5rem; | 
					
						
							|  |  |  |  |           display: flex; | 
					
						
							|  |  |  |  |           justify-content: center; | 
					
						
							|  |  |  |  |           line-height: 1.6rem; | 
					
						
							|  |  |  |  |           font-size: 0.7rem; | 
					
						
							|  |  |  |  |           color: #ffffff; | 
					
						
							|  |  |  |  |           position: absolute; | 
					
						
							|  |  |  |  |           background-repeat: no-repeat; | 
					
						
							|  |  |  |  |           background-size: 100% 100%; | 
					
						
							|  |  |  |  |           background-position: 50%; | 
					
						
							|  |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-10-29 09:45:49 +08:00
										 |  |  |  |           span { | 
					
						
							|  |  |  |  |             height: 1rem; | 
					
						
							| 
									
										
										
										
											2024-10-28 10:00:28 +08:00
										 |  |  |  |           } | 
					
						
							|  |  |  |  |         } | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |         .map-care-div-1 { | 
					
						
							|  |  |  |  |           background-image: url("../../assets/screen/index/map-care-div-1.png"); | 
					
						
							|  |  |  |  |         } | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |         .map-care-div-2 { | 
					
						
							|  |  |  |  |           background-image: url("../../assets/screen/index/map-care-div-2.png"); | 
					
						
							|  |  |  |  |         } | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |         .map-care-div-3 { | 
					
						
							|  |  |  |  |           background-image: url("../../assets/screen/index/map-care-div-3.png"); | 
					
						
							|  |  |  |  |         } | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |         .map-care-div-4 { | 
					
						
							|  |  |  |  |           background-image: url("../../assets/screen/index/map-care-div-4.png"); | 
					
						
							|  |  |  |  |         } | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |         .map-care-div-5 { | 
					
						
							|  |  |  |  |           background-image: url("../../assets/screen/index/map-care-div-5.png"); | 
					
						
							|  |  |  |  |         } | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |         .map-care-div-6 { | 
					
						
							|  |  |  |  |           background-image: url("../../assets/screen/index/map-care-div-6.png"); | 
					
						
							|  |  |  |  |         } | 
					
						
							| 
									
										
										
										
											2024-10-25 17:29:08 +08:00
										 |  |  |  |       } | 
					
						
							| 
									
										
										
										
											2024-10-23 17:17:37 +08:00
										 |  |  |  |     } | 
					
						
							|  |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-10-22 09:55:33 +08:00
										 |  |  |  |   } | 
					
						
							| 
									
										
										
										
											2024-10-18 17:31:35 +08:00
										 |  |  |  | } | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  | // 头部样式
 | 
					
						
							|  |  |  |  | .screen-header { | 
					
						
							|  |  |  |  |   width: 100%; | 
					
						
							|  |  |  |  |   height: 5rem; | 
					
						
							| 
									
										
										
										
											2024-10-22 09:55:33 +08:00
										 |  |  |  |   padding: 1rem 3rem; | 
					
						
							| 
									
										
										
										
											2024-10-18 17:31:35 +08:00
										 |  |  |  |   position: fixed; | 
					
						
							|  |  |  |  |   top: 0; | 
					
						
							|  |  |  |  |   display: flex; | 
					
						
							|  |  |  |  |   justify-content: space-between; | 
					
						
							|  |  |  |  |   z-index: 1; | 
					
						
							|  |  |  |  |   background-image: url("../../assets/screen/index/bg-top.png"); | 
					
						
							|  |  |  |  |   background-repeat: no-repeat; | 
					
						
							|  |  |  |  |   background-size: 100% 120%; | 
					
						
							|  |  |  |  |   background-position-x: 50%; | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |   .header-weather { | 
					
						
							|  |  |  |  |     display: flex; | 
					
						
							|  |  |  |  |     align-items: flex-end; | 
					
						
							|  |  |  |  |     font-size: 1rem; | 
					
						
							|  |  |  |  |     color: #89c5e8; | 
					
						
							|  |  |  |  |   } | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |   .header-time { | 
					
						
							|  |  |  |  |     display: flex; | 
					
						
							|  |  |  |  |     color: #89c5e8; | 
					
						
							| 
									
										
										
										
											2024-12-10 12:59:10 +08:00
										 |  |  |  |     font-size: 1rem; | 
					
						
							| 
									
										
										
										
											2024-10-18 17:31:35 +08:00
										 |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-12-09 15:35:13 +08:00
										 |  |  |  |     > div { | 
					
						
							| 
									
										
										
										
											2024-10-18 17:31:35 +08:00
										 |  |  |  |       margin: 0 0.5rem; | 
					
						
							|  |  |  |  |       display: flex; | 
					
						
							|  |  |  |  |       align-items: flex-end; | 
					
						
							|  |  |  |  |     } | 
					
						
							|  |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-11-20 14:46:20 +08:00
										 |  |  |  |     // 消息中心样式
 | 
					
						
							| 
									
										
										
										
											2024-11-19 14:18:57 +08:00
										 |  |  |  |     .header-news { | 
					
						
							| 
									
										
										
										
											2024-11-20 14:46:20 +08:00
										 |  |  |  |       i { | 
					
						
							|  |  |  |  |         position: relative; | 
					
						
							|  |  |  |  |         cursor: pointer; | 
					
						
							|  |  |  |  |         font-size: 1.5rem; | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |         .num { | 
					
						
							|  |  |  |  |           min-width: 0.9rem; | 
					
						
							|  |  |  |  |           position: absolute; | 
					
						
							|  |  |  |  |           top: -0.2rem; | 
					
						
							|  |  |  |  |           right: -0.5rem; | 
					
						
							|  |  |  |  |           padding: 0.2rem; | 
					
						
							|  |  |  |  |           font-size: 0.6rem; | 
					
						
							|  |  |  |  |           border-radius: 0.5rem; | 
					
						
							|  |  |  |  |           color: #ffffff; | 
					
						
							|  |  |  |  |           background-color: red; | 
					
						
							|  |  |  |  |         } | 
					
						
							|  |  |  |  |       } | 
					
						
							| 
									
										
										
										
											2024-11-19 14:18:57 +08:00
										 |  |  |  |     } | 
					
						
							|  |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-10-18 17:31:35 +08:00
										 |  |  |  |     .header-data { | 
					
						
							|  |  |  |  |       font-size: 1.8rem; | 
					
						
							|  |  |  |  |     } | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |     .header-week { | 
					
						
							|  |  |  |  |       display: flex; | 
					
						
							|  |  |  |  |       align-items: flex-start; | 
					
						
							|  |  |  |  |       justify-content: flex-end; | 
					
						
							|  |  |  |  |       flex-direction: column; | 
					
						
							|  |  |  |  |     } | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |     .header-home { | 
					
						
							| 
									
										
										
										
											2024-10-22 09:55:33 +08:00
										 |  |  |  |       .home { | 
					
						
							|  |  |  |  |         cursor: pointer; | 
					
						
							|  |  |  |  |         height: 1.5rem; | 
					
						
							|  |  |  |  |         width: 1.2rem; | 
					
						
							|  |  |  |  |         background-image: url("../../assets/screen/index/exit.png"); | 
					
						
							|  |  |  |  |         background-repeat: no-repeat; | 
					
						
							|  |  |  |  |         background-size: 100%; | 
					
						
							|  |  |  |  |       } | 
					
						
							| 
									
										
										
										
											2024-10-18 17:31:35 +08:00
										 |  |  |  |     } | 
					
						
							|  |  |  |  |   } | 
					
						
							|  |  |  |  | } | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  | // 大屏下方样式
 | 
					
						
							|  |  |  |  | .screen-footer { | 
					
						
							|  |  |  |  |   width: 49%; | 
					
						
							|  |  |  |  |   height: 7.55rem; | 
					
						
							|  |  |  |  |   position: fixed; | 
					
						
							|  |  |  |  |   bottom: 0; | 
					
						
							|  |  |  |  |   left: 25.5%; | 
					
						
							|  |  |  |  |   background-image: url("../../assets/screen/index/bg-foot.png"); | 
					
						
							|  |  |  |  |   background-repeat: no-repeat; | 
					
						
							|  |  |  |  |   background-size: 100.1% 99%; | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |   .footer-change-map { | 
					
						
							|  |  |  |  |     width: 100%; | 
					
						
							|  |  |  |  |     height: 40%; | 
					
						
							|  |  |  |  |     display: flex; | 
					
						
							|  |  |  |  |     justify-content: center; | 
					
						
							|  |  |  |  |     align-items: center; | 
					
						
							|  |  |  |  |     color: #8deeff; | 
					
						
							|  |  |  |  |     font-style: italic; | 
					
						
							|  |  |  |  |     font-size: 0.7rem; | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |     .change-map-div { | 
					
						
							| 
									
										
										
										
											2024-10-23 17:17:37 +08:00
										 |  |  |  |       cursor: pointer; | 
					
						
							| 
									
										
										
										
											2024-10-25 17:29:08 +08:00
										 |  |  |  |       margin: 0 2rem; | 
					
						
							| 
									
										
										
										
											2024-10-18 17:31:35 +08:00
										 |  |  |  |     } | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |     .change-map-click { | 
					
						
							|  |  |  |  |       color: #fffed2; | 
					
						
							|  |  |  |  |     } | 
					
						
							|  |  |  |  |   } | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |   .footer-change-vue { | 
					
						
							|  |  |  |  |     width: 100%; | 
					
						
							|  |  |  |  |     height: 60%; | 
					
						
							|  |  |  |  |     display: flex; | 
					
						
							|  |  |  |  |     justify-content: center; | 
					
						
							|  |  |  |  |     align-items: center; | 
					
						
							|  |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-12-09 15:35:13 +08:00
										 |  |  |  |     > div { | 
					
						
							| 
									
										
										
										
											2024-10-18 17:31:35 +08:00
										 |  |  |  |       height: 100%; | 
					
						
							|  |  |  |  |       width: 37.5%; | 
					
						
							|  |  |  |  |     } | 
					
						
							|  |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-12-09 15:35:13 +08:00
										 |  |  |  |     > div:nth-child(2) { | 
					
						
							| 
									
										
										
										
											2024-10-18 17:31:35 +08:00
										 |  |  |  |       height: 100%; | 
					
						
							|  |  |  |  |       width: 25%; | 
					
						
							|  |  |  |  |     } | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |     // 未点击样式
 | 
					
						
							| 
									
										
										
										
											2024-11-11 14:40:40 +08:00
										 |  |  |  |     .change-vue-OverviewScreen { | 
					
						
							| 
									
										
										
										
											2024-11-13 15:37:25 +08:00
										 |  |  |  |       background-image: url("../../assets//screen/index/button-overview.png"); | 
					
						
							| 
									
										
										
										
											2024-10-18 17:31:35 +08:00
										 |  |  |  |       background-repeat: no-repeat; | 
					
						
							| 
									
										
										
										
											2024-11-13 15:37:25 +08:00
										 |  |  |  |       background-size: 95% 60%; | 
					
						
							|  |  |  |  |       background-position: 75% 15%; | 
					
						
							| 
									
										
										
										
											2024-10-18 17:31:35 +08:00
										 |  |  |  |     } | 
					
						
							|  |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-11-11 14:40:40 +08:00
										 |  |  |  |     .change-vue-click-OverviewScreen { | 
					
						
							| 
									
										
										
										
											2024-11-13 15:37:25 +08:00
										 |  |  |  |       background-image: url("../../assets//screen/index/button-overview-click.png"); | 
					
						
							| 
									
										
										
										
											2024-10-18 17:31:35 +08:00
										 |  |  |  |       background-repeat: no-repeat; | 
					
						
							| 
									
										
										
										
											2024-11-13 15:37:25 +08:00
										 |  |  |  |       background-size: 95% 60%; | 
					
						
							|  |  |  |  |       background-position: 75% 15%; | 
					
						
							| 
									
										
										
										
											2024-10-18 17:31:35 +08:00
										 |  |  |  |     } | 
					
						
							|  |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-11-13 15:37:25 +08:00
										 |  |  |  |     .change-vue-DiseaseScreen { | 
					
						
							|  |  |  |  |       background-image: url("../../assets//screen/index/button-disease.png"); | 
					
						
							| 
									
										
										
										
											2024-10-18 17:31:35 +08:00
										 |  |  |  |       background-repeat: no-repeat; | 
					
						
							| 
									
										
										
										
											2024-11-13 15:37:25 +08:00
										 |  |  |  |       background-size: 99% 60%; | 
					
						
							|  |  |  |  |       background-position: 50% 13%; | 
					
						
							| 
									
										
										
										
											2024-10-18 17:31:35 +08:00
										 |  |  |  |     } | 
					
						
							| 
									
										
										
										
											2024-11-13 15:37:25 +08:00
										 |  |  |  | 
 | 
					
						
							|  |  |  |  |     .change-vue-click-DiseaseScreen { | 
					
						
							|  |  |  |  |       background-image: url("../../assets//screen/index/button-disease-click.png"); | 
					
						
							| 
									
										
										
										
											2024-10-18 17:31:35 +08:00
										 |  |  |  |       background-repeat: no-repeat; | 
					
						
							| 
									
										
										
										
											2024-11-13 15:37:25 +08:00
										 |  |  |  |       background-size: 99% 60%; | 
					
						
							|  |  |  |  |       background-position: 50% 13%; | 
					
						
							| 
									
										
										
										
											2024-10-18 17:31:35 +08:00
										 |  |  |  |     } | 
					
						
							|  |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-11-13 15:37:25 +08:00
										 |  |  |  |     .change-vue-RoadScreen { | 
					
						
							|  |  |  |  |       background-image: url("../../assets//screen/index/button-road.png"); | 
					
						
							| 
									
										
										
										
											2024-10-18 17:31:35 +08:00
										 |  |  |  |       background-repeat: no-repeat; | 
					
						
							| 
									
										
										
										
											2024-11-13 15:37:25 +08:00
										 |  |  |  |       background-size: 93% 60%; | 
					
						
							| 
									
										
										
										
											2024-10-18 17:31:35 +08:00
										 |  |  |  |       background-position: 15% 15%; | 
					
						
							|  |  |  |  |     } | 
					
						
							| 
									
										
										
										
											2024-12-05 17:25:06 +08:00
										 |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-11-13 15:37:25 +08:00
										 |  |  |  |     .change-vue-click-RoadScreen { | 
					
						
							|  |  |  |  |       background-image: url("../../assets//screen/index/button-road-click.png"); | 
					
						
							| 
									
										
										
										
											2024-10-18 17:31:35 +08:00
										 |  |  |  |       background-repeat: no-repeat; | 
					
						
							| 
									
										
										
										
											2024-11-13 15:37:25 +08:00
										 |  |  |  |       background-size: 93% 60%; | 
					
						
							| 
									
										
										
										
											2024-10-18 17:31:35 +08:00
										 |  |  |  |       background-position: 15% 15%; | 
					
						
							|  |  |  |  |     } | 
					
						
							| 
									
										
										
										
											2024-11-13 15:37:25 +08:00
										 |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-10-18 17:31:35 +08:00
										 |  |  |  |     // .change-vue-click {
 | 
					
						
							|  |  |  |  |     //   color: red;
 | 
					
						
							|  |  |  |  |     // }
 | 
					
						
							|  |  |  |  |   } | 
					
						
							|  |  |  |  | } | 
					
						
							| 
									
										
										
										
											2024-10-23 17:17:37 +08:00
										 |  |  |  | 
 | 
					
						
							|  |  |  |  | /* 修改弹窗样式 */ | 
					
						
							| 
									
										
										
										
											2024-11-21 11:52:44 +08:00
										 |  |  |  | ::v-deep .el-dialog { | 
					
						
							|  |  |  |  |   background-color: transparent; | 
					
						
							|  |  |  |  | } | 
					
						
							|  |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-10-23 17:17:37 +08:00
										 |  |  |  | ::v-deep .el-dialog__header { | 
					
						
							| 
									
										
										
										
											2024-11-11 14:40:40 +08:00
										 |  |  |  |   padding: 10px; | 
					
						
							| 
									
										
										
										
											2024-10-23 17:17:37 +08:00
										 |  |  |  |   background-color: #113463; | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |   span, | 
					
						
							|  |  |  |  |   i { | 
					
						
							|  |  |  |  |     color: #ffffff; | 
					
						
							|  |  |  |  |   } | 
					
						
							|  |  |  |  | } | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  | ::v-deep .el-dialog__body { | 
					
						
							| 
									
										
										
										
											2024-11-11 14:40:40 +08:00
										 |  |  |  |   padding: 0; | 
					
						
							| 
									
										
										
										
											2024-10-23 17:17:37 +08:00
										 |  |  |  |   background-color: #113463; | 
					
						
							| 
									
										
										
										
											2024-11-07 12:04:16 +08:00
										 |  |  |  | 
 | 
					
						
							|  |  |  |  |   /* 查看点位大图弹窗 */ | 
					
						
							| 
									
										
										
										
											2024-11-11 14:40:40 +08:00
										 |  |  |  |   .view-image-container { | 
					
						
							| 
									
										
										
										
											2024-11-07 12:04:16 +08:00
										 |  |  |  |     position: relative; | 
					
						
							|  |  |  |  |     width: 100%; | 
					
						
							| 
									
										
										
										
											2024-12-09 15:35:13 +08:00
										 |  |  |  |     height: 50rem; | 
					
						
							| 
									
										
										
										
											2024-11-07 12:04:16 +08:00
										 |  |  |  |     display: flex; | 
					
						
							| 
									
										
										
										
											2024-11-19 14:18:57 +08:00
										 |  |  |  |     flex-direction: column; | 
					
						
							| 
									
										
										
										
											2024-11-07 12:04:16 +08:00
										 |  |  |  |     align-items: center; | 
					
						
							|  |  |  |  |     justify-content: center; | 
					
						
							|  |  |  |  |     overflow: hidden; | 
					
						
							|  |  |  |  |   } | 
					
						
							|  |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-11-11 14:40:40 +08:00
										 |  |  |  |   .view-image-container img { | 
					
						
							| 
									
										
										
										
											2024-11-07 12:04:16 +08:00
										 |  |  |  |     max-width: 100%; | 
					
						
							|  |  |  |  |     max-height: 100%; | 
					
						
							|  |  |  |  |     object-fit: contain; | 
					
						
							|  |  |  |  |   } | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |   .rect-overlay { | 
					
						
							|  |  |  |  |     position: absolute; | 
					
						
							| 
									
										
										
										
											2024-11-13 15:37:25 +08:00
										 |  |  |  |     // pointer-events: none;
 | 
					
						
							| 
									
										
										
										
											2024-11-07 12:04:16 +08:00
										 |  |  |  |     border: 2px solid red; | 
					
						
							|  |  |  |  |   } | 
					
						
							| 
									
										
										
										
											2024-10-23 17:17:37 +08:00
										 |  |  |  | } | 
					
						
							| 
									
										
										
										
											2024-11-11 14:40:40 +08:00
										 |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-11-19 14:18:57 +08:00
										 |  |  |  | // 图片信息
 | 
					
						
							|  |  |  |  | .rect-image { | 
					
						
							| 
									
										
										
										
											2024-12-05 17:25:06 +08:00
										 |  |  |  |   width: 90%; | 
					
						
							| 
									
										
										
										
											2024-11-19 14:18:57 +08:00
										 |  |  |  |   position: absolute; | 
					
						
							|  |  |  |  |   top: 0; | 
					
						
							| 
									
										
										
										
											2024-11-21 11:52:44 +08:00
										 |  |  |  |   font-size: 1.2rem; | 
					
						
							| 
									
										
										
										
											2024-11-19 14:18:57 +08:00
										 |  |  |  |   color: #ffffff; | 
					
						
							|  |  |  |  |   background-color: rgba(0, 0, 0, 0.5); | 
					
						
							|  |  |  |  | } | 
					
						
							|  |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-11-11 14:40:40 +08:00
										 |  |  |  | // 大屏下拉框样式
 | 
					
						
							|  |  |  |  | ::v-deep .el-select { | 
					
						
							|  |  |  |  |   width: 6.5rem; | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |   .el-input .el-select__caret { | 
					
						
							|  |  |  |  |     line-height: 1.5rem; | 
					
						
							|  |  |  |  |   } | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |   .el-input--medium .el-input__inner { | 
					
						
							|  |  |  |  |     height: 1.5rem; | 
					
						
							|  |  |  |  |     background-color: transparent; | 
					
						
							|  |  |  |  |     color: #89c5e8; | 
					
						
							|  |  |  |  |     border-color: #6991cd; | 
					
						
							|  |  |  |  |   } | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |   .el-select-dropdown { | 
					
						
							|  |  |  |  |     background-color: #102649; | 
					
						
							|  |  |  |  |     border-color: #08204f; | 
					
						
							| 
									
										
										
										
											2024-12-05 17:25:06 +08:00
										 |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-11-11 14:40:40 +08:00
										 |  |  |  |     .el-scrollbar { | 
					
						
							|  |  |  |  |       .el-select-dropdown__wrap { | 
					
						
							|  |  |  |  |         .el-scrollbar__view { | 
					
						
							| 
									
										
										
										
											2024-11-13 15:37:25 +08:00
										 |  |  |  |           .el-select-dropdown__item { | 
					
						
							|  |  |  |  |             color: #aaabb8; | 
					
						
							|  |  |  |  |           } | 
					
						
							|  |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-11-11 14:40:40 +08:00
										 |  |  |  |           .el-select-dropdown__item:hover { | 
					
						
							|  |  |  |  |             background-color: #2b4c7e; | 
					
						
							|  |  |  |  |           } | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |           .el-select-dropdown__item.selected { | 
					
						
							|  |  |  |  |             background-color: #2b4c7e; | 
					
						
							|  |  |  |  |           } | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |           .el-select-dropdown__item.hover { | 
					
						
							|  |  |  |  |             background-color: #2b4c7e; | 
					
						
							|  |  |  |  |           } | 
					
						
							|  |  |  |  |         } | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |         .el-select-dropdown__list { | 
					
						
							|  |  |  |  |           background-color: #102649; | 
					
						
							|  |  |  |  |         } | 
					
						
							|  |  |  |  |       } | 
					
						
							|  |  |  |  |     } | 
					
						
							|  |  |  |  |   } | 
					
						
							|  |  |  |  | } | 
					
						
							| 
									
										
										
										
											2024-11-15 11:03:30 +08:00
										 |  |  |  | 
 | 
					
						
							|  |  |  |  | // 修改级联样式
 | 
					
						
							|  |  |  |  | ::v-deep .el-cascader { | 
					
						
							|  |  |  |  |   width: 8rem; | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |   .el-input--medium .el-input__inner { | 
					
						
							|  |  |  |  |     height: 1.5rem; | 
					
						
							|  |  |  |  |     background-color: transparent; | 
					
						
							|  |  |  |  |     color: #89c5e8; | 
					
						
							|  |  |  |  |     border-color: #6991cd; | 
					
						
							|  |  |  |  |   } | 
					
						
							|  |  |  |  | } | 
					
						
							|  |  |  |  | </style> | 
					
						
							|  |  |  |  | <style lang="scss"> | 
					
						
							|  |  |  |  | .screen-index-cascader { | 
					
						
							|  |  |  |  |   background-color: #102649; | 
					
						
							|  |  |  |  |   border-color: #08204f; | 
					
						
							| 
									
										
										
										
											2024-11-15 18:08:37 +08:00
										 |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-11-15 11:03:30 +08:00
										 |  |  |  |   .el-cascader-node__label { | 
					
						
							|  |  |  |  |     color: #aaabb8; | 
					
						
							|  |  |  |  |   } | 
					
						
							| 
									
										
										
										
											2024-11-15 18:08:37 +08:00
										 |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-11-15 11:03:30 +08:00
										 |  |  |  |   .el-cascader-node:hover { | 
					
						
							|  |  |  |  |     background-color: #2b4c7e; | 
					
						
							|  |  |  |  |   } | 
					
						
							| 
									
										
										
										
											2024-11-15 18:08:37 +08:00
										 |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-11-15 11:03:30 +08:00
										 |  |  |  |   .el-cascader-node:active { | 
					
						
							|  |  |  |  |     background-color: #2b4c7e; | 
					
						
							|  |  |  |  |   } | 
					
						
							| 
									
										
										
										
											2024-11-15 18:08:37 +08:00
										 |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-11-15 11:03:30 +08:00
										 |  |  |  |   .el-cascader-node:focus { | 
					
						
							|  |  |  |  |     background-color: #2b4c7e; | 
					
						
							|  |  |  |  |   } | 
					
						
							|  |  |  |  | } | 
					
						
							|  |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-11-20 14:46:20 +08:00
										 |  |  |  | // 大屏消息弹出框样式
 | 
					
						
							|  |  |  |  | .screen-message-popover { | 
					
						
							|  |  |  |  |   background-color: rgba(0, 0, 0, 0.8); | 
					
						
							|  |  |  |  |   border: none; | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |   .screen-message-content { | 
					
						
							|  |  |  |  |     width: 100%; | 
					
						
							|  |  |  |  |     color: #ffffff; | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |     .message-content { | 
					
						
							|  |  |  |  |       width: 100%; | 
					
						
							| 
									
										
										
										
											2024-12-05 17:25:06 +08:00
										 |  |  |  |       max-height: 12rem; | 
					
						
							| 
									
										
										
										
											2024-11-20 14:46:20 +08:00
										 |  |  |  | 
 | 
					
						
							|  |  |  |  |       .message-item { | 
					
						
							|  |  |  |  |         padding: 0.5rem 0; | 
					
						
							|  |  |  |  |         border-bottom: 1px dashed rgb(115, 115, 116); | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |         .item-top { | 
					
						
							|  |  |  |  |           width: 100%; | 
					
						
							|  |  |  |  |           display: flex; | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |           &:hover { | 
					
						
							|  |  |  |  |             span { | 
					
						
							|  |  |  |  |               color: rgb(113, 179, 255); | 
					
						
							|  |  |  |  |             } | 
					
						
							|  |  |  |  |           } | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |           .time { | 
					
						
							|  |  |  |  |             width: 40%; | 
					
						
							|  |  |  |  |           } | 
					
						
							|  |  |  |  |         } | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |         .item-content { | 
					
						
							|  |  |  |  |           padding-left: 1rem; | 
					
						
							|  |  |  |  |         } | 
					
						
							|  |  |  |  |       } | 
					
						
							|  |  |  |  |     } | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |     .message-footer { | 
					
						
							|  |  |  |  |       display: flex; | 
					
						
							|  |  |  |  |       justify-content: flex-end; | 
					
						
							|  |  |  |  |     } | 
					
						
							|  |  |  |  |   } | 
					
						
							|  |  |  |  | } | 
					
						
							| 
									
										
										
										
											2024-11-15 11:03:30 +08:00
										 |  |  |  | </style> |