| 
									
										
										
										
											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-11-15 18:08:37 +08:00
										 |  |  |  |  * @LastEditTime: 2024-11-15 17:40:06 | 
					
						
							| 
									
										
										
										
											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"> | 
					
						
							|  |  |  |  |         <iframe | 
					
						
							|  |  |  |  |           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" | 
					
						
							|  |  |  |  |         ></iframe> | 
					
						
							|  |  |  |  |       </div> | 
					
						
							| 
									
										
										
										
											2024-10-18 17:31:35 +08:00
										 |  |  |  |       <div class="header-time"> | 
					
						
							|  |  |  |  |         <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"> | 
					
						
							|  |  |  |  |         <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-10-22 09:55:33 +08:00
										 |  |  |  |           <template | 
					
						
							| 
									
										
										
										
											2024-11-11 14:40:40 +08:00
										 |  |  |  |             ><component | 
					
						
							|  |  |  |  |               :select="item.select" | 
					
						
							|  |  |  |  |               :is="item.component" | 
					
						
							|  |  |  |  |               :bottomTipClick="bottomTipClick" | 
					
						
							|  |  |  |  |             ></component | 
					
						
							| 
									
										
										
										
											2024-10-22 09:55:33 +08:00
										 |  |  |  |           ></template> | 
					
						
							|  |  |  |  |           <template slot="operation" v-if="item.selectIsShow"> | 
					
						
							|  |  |  |  |             <el-radio-group class="screen-checkBox" v-model="item.select"> | 
					
						
							| 
									
										
										
										
											2024-10-25 17:29:08 +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"> | 
					
						
							|  |  |  |  |         <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-10-25 17:29:08 +08:00
										 |  |  |  |           <template | 
					
						
							| 
									
										
										
										
											2024-11-11 14:40:40 +08:00
										 |  |  |  |             ><component | 
					
						
							|  |  |  |  |               :select="item.select" | 
					
						
							|  |  |  |  |               :is="item.component" | 
					
						
							|  |  |  |  |               :bottomTipClick="bottomTipClick" | 
					
						
							| 
									
										
										
										
											2024-11-14 17:43:24 +08:00
										 |  |  |  |               @imagePoint="getimagePoint" | 
					
						
							| 
									
										
										
										
											2024-11-11 14:40:40 +08:00
										 |  |  |  |             ></component | 
					
						
							| 
									
										
										
										
											2024-10-25 17:29:08 +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-10-25 17:29:08 +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"> | 
					
						
							|  |  |  |  |               <el-checkbox | 
					
						
							|  |  |  |  |                 v-for="(item, index) in iconTypeList" | 
					
						
							|  |  |  |  |                 :label="item.value" | 
					
						
							|  |  |  |  |                 :key="`check-${index}`" | 
					
						
							| 
									
										
										
										
											2024-11-01 13:15:24 +08:00
										 |  |  |  |                 >{{ 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-11-15 11:03:30 +08:00
										 |  |  |  |             <!-- <el-select | 
					
						
							| 
									
										
										
										
											2024-11-11 14:40:40 +08:00
										 |  |  |  |               :popper-append-to-body="false" | 
					
						
							|  |  |  |  |               v-model="mapCareSelect" | 
					
						
							|  |  |  |  |               placeholder="请选择" | 
					
						
							|  |  |  |  |               @change="getMapCare" | 
					
						
							| 
									
										
										
										
											2024-11-15 11:03:30 +08:00
										 |  |  |  |               clearable | 
					
						
							| 
									
										
										
										
											2024-11-11 14:40:40 +08:00
										 |  |  |  |             > | 
					
						
							|  |  |  |  |               <el-option | 
					
						
							|  |  |  |  |                 v-for="item in dieaseTypeList" | 
					
						
							|  |  |  |  |                 :key="item.value" | 
					
						
							|  |  |  |  |                 :label="item.label" | 
					
						
							|  |  |  |  |                 :value="item.value" | 
					
						
							|  |  |  |  |               /> | 
					
						
							| 
									
										
										
										
											2024-11-15 11:03:30 +08:00
										 |  |  |  |             </el-select> --> | 
					
						
							|  |  |  |  |             <el-cascader | 
					
						
							|  |  |  |  |               v-model="mapCareSelect" | 
					
						
							|  |  |  |  |               popper-class="screen-index-cascader" | 
					
						
							|  |  |  |  |               :options="dieaseOptions" | 
					
						
							|  |  |  |  |               :props="{ checkStrictly: true, emitPath: false }" | 
					
						
							|  |  |  |  |               @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-10-28 10:00:28 +08:00
										 |  |  |  |             <div | 
					
						
							|  |  |  |  |               class="map-care-div" | 
					
						
							| 
									
										
										
										
											2024-11-07 09:30:17 +08:00
										 |  |  |  |               :class="`map-care-div-${item.status}`" | 
					
						
							| 
									
										
										
										
											2024-10-28 10:00:28 +08:00
										 |  |  |  |               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> | 
					
						
							|  |  |  |  |         <!-- 地图 --> | 
					
						
							|  |  |  |  |         <fssm-map | 
					
						
							| 
									
										
										
										
											2024-11-11 14:40:40 +08:00
										 |  |  |  |           v-if="elementDiv !== 'OverviewScreen'" | 
					
						
							| 
									
										
										
										
											2024-10-23 17:17:37 +08:00
										 |  |  |  |           ref="roadMap" | 
					
						
							| 
									
										
										
										
											2024-11-05 11:22:23 +08:00
										 |  |  |  |           :showChange="true" | 
					
						
							| 
									
										
										
										
											2024-11-11 14:40:40 +08:00
										 |  |  |  |           :controlStyle="{ top: '10%', left: '26%' }" | 
					
						
							| 
									
										
										
										
											2024-10-23 17:17:37 +08:00
										 |  |  |  |           @feature-select="featureSelect" | 
					
						
							| 
									
										
										
										
											2024-11-14 17:43:24 +08:00
										 |  |  |  |           @map-zoom="getZoom" | 
					
						
							| 
									
										
										
										
											2024-10-23 17:17:37 +08:00
										 |  |  |  |         ></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-10-22 09:55:33 +08:00
										 |  |  |  |           <div | 
					
						
							|  |  |  |  |             class="change-map-div" | 
					
						
							| 
									
										
										
										
											2024-11-11 14:40:40 +08:00
										 |  |  |  |             :class="bottomTipClick === item.click ? 'change-map-click' : ''" | 
					
						
							| 
									
										
										
										
											2024-10-22 09:55:33 +08:00
										 |  |  |  |             v-for="(item, index) in changeMapBtn" | 
					
						
							|  |  |  |  |             :key="`btn-${index}`" | 
					
						
							| 
									
										
										
										
											2024-10-23 17:17:37 +08:00
										 |  |  |  |             @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"> | 
					
						
							|  |  |  |  |         <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> | 
					
						
							|  |  |  |  |       </div> | 
					
						
							|  |  |  |  |     </div> | 
					
						
							| 
									
										
										
										
											2024-11-14 17:43:24 +08:00
										 |  |  |  |     <!-- 详情图片弹窗 --> | 
					
						
							| 
									
										
										
										
											2024-10-23 17:17:37 +08:00
										 |  |  |  |     <el-dialog | 
					
						
							|  |  |  |  |       :title="imgTitle" | 
					
						
							|  |  |  |  |       :visible.sync="imgVisible" | 
					
						
							| 
									
										
										
										
											2024-11-11 14:40:40 +08:00
										 |  |  |  |       width="85rem" | 
					
						
							| 
									
										
										
										
											2024-10-23 17:17:37 +08:00
										 |  |  |  |       append-to-body | 
					
						
							|  |  |  |  |       :close-on-click-modal="false" | 
					
						
							|  |  |  |  |       destroy-on-close | 
					
						
							|  |  |  |  |       @close="imgCancel" | 
					
						
							|  |  |  |  |     > | 
					
						
							| 
									
										
										
										
											2024-11-14 17:43:24 +08:00
										 |  |  |  |       <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
										 |  |  |  | 
 | 
					
						
							|  |  |  |  |     <!-- 查看点位图片弹窗 --> | 
					
						
							|  |  |  |  |     <el-dialog | 
					
						
							|  |  |  |  |       title="查看点位" | 
					
						
							|  |  |  |  |       :visible.sync="showImageDialog" | 
					
						
							|  |  |  |  |       width="80rem" | 
					
						
							|  |  |  |  |       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-11-07 12:04:16 +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> | 
					
						
							|  |  |  |  |       </div> | 
					
						
							|  |  |  |  |     </el-dialog> | 
					
						
							| 
									
										
										
										
											2024-10-18 17:31:35 +08:00
										 |  |  |  |   </div> | 
					
						
							|  |  |  |  | </template> | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  | <script> | 
					
						
							| 
									
										
										
										
											2024-11-14 17:43:24 +08:00
										 |  |  |  | // websocket
 | 
					
						
							|  |  |  |  | import { | 
					
						
							|  |  |  |  |   connectWebsocket, | 
					
						
							|  |  |  |  |   closeWebsocket, | 
					
						
							|  |  |  |  |   sendMsg, | 
					
						
							|  |  |  |  | } from "@/plugins/websocket.js"; | 
					
						
							|  |  |  |  | // 登陆人信息
 | 
					
						
							|  |  |  |  | import { getToken } from "@/utils/auth.js"; | 
					
						
							| 
									
										
										
										
											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-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-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-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-10-22 09:55:33 +08:00
										 |  |  |  |           title: "病害趋势", | 
					
						
							|  |  |  |  |           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: "", | 
					
						
							|  |  |  |  |       // 图片背景下病害类型下拉选择数据
 | 
					
						
							|  |  |  |  |       dieaseTypeList: [], | 
					
						
							| 
									
										
										
										
											2024-11-15 11:03:30 +08:00
										 |  |  |  |       dieaseOptions: [ | 
					
						
							|  |  |  |  |         { | 
					
						
							|  |  |  |  |           value: "zhinan", | 
					
						
							|  |  |  |  |           label: "指南", | 
					
						
							|  |  |  |  |           children: [ | 
					
						
							|  |  |  |  |             { | 
					
						
							|  |  |  |  |               value: "shejiyuanze", | 
					
						
							|  |  |  |  |               label: "设计原则", | 
					
						
							|  |  |  |  |             }, | 
					
						
							|  |  |  |  |             { | 
					
						
							|  |  |  |  |               value: "daohang", | 
					
						
							|  |  |  |  |               label: "导航", | 
					
						
							|  |  |  |  |             }, | 
					
						
							|  |  |  |  |           ], | 
					
						
							|  |  |  |  |         }, | 
					
						
							|  |  |  |  |         { | 
					
						
							|  |  |  |  |           value: "zujian", | 
					
						
							|  |  |  |  |           label: "组件", | 
					
						
							|  |  |  |  |           children: [ | 
					
						
							|  |  |  |  |             { | 
					
						
							|  |  |  |  |               value: "basic", | 
					
						
							|  |  |  |  |               label: "Basic", | 
					
						
							|  |  |  |  |             }, | 
					
						
							|  |  |  |  |             { | 
					
						
							|  |  |  |  |               value: "form", | 
					
						
							|  |  |  |  |               label: "Form", | 
					
						
							|  |  |  |  |               children: [ | 
					
						
							|  |  |  |  |                 { | 
					
						
							|  |  |  |  |                   value: "radio", | 
					
						
							|  |  |  |  |                   label: "Radio 单选框", | 
					
						
							|  |  |  |  |                 }, | 
					
						
							|  |  |  |  |                 { | 
					
						
							|  |  |  |  |                   value: "checkbox", | 
					
						
							|  |  |  |  |                   label: "Checkbox 多选框", | 
					
						
							|  |  |  |  |                 }, | 
					
						
							|  |  |  |  |                 { | 
					
						
							|  |  |  |  |                   value: "input", | 
					
						
							|  |  |  |  |                   label: "Input 输入框", | 
					
						
							|  |  |  |  |                 }, | 
					
						
							|  |  |  |  |                 { | 
					
						
							|  |  |  |  |                   value: "input-number", | 
					
						
							|  |  |  |  |                   label: "InputNumber 计数器", | 
					
						
							|  |  |  |  |                 }, | 
					
						
							|  |  |  |  |                 { | 
					
						
							|  |  |  |  |                   value: "select", | 
					
						
							|  |  |  |  |                   label: "Select 选择器", | 
					
						
							|  |  |  |  |                 }, | 
					
						
							|  |  |  |  |                 { | 
					
						
							|  |  |  |  |                   value: "cascader", | 
					
						
							|  |  |  |  |                   label: "Cascader 级联选择器", | 
					
						
							|  |  |  |  |                 }, | 
					
						
							|  |  |  |  |                 { | 
					
						
							|  |  |  |  |                   value: "switch", | 
					
						
							|  |  |  |  |                   label: "Switch 开关", | 
					
						
							|  |  |  |  |                 }, | 
					
						
							|  |  |  |  |                 { | 
					
						
							|  |  |  |  |                   value: "slider", | 
					
						
							|  |  |  |  |                   label: "Slider 滑块", | 
					
						
							|  |  |  |  |                 }, | 
					
						
							|  |  |  |  |                 { | 
					
						
							|  |  |  |  |                   value: "time-picker", | 
					
						
							|  |  |  |  |                   label: "TimePicker 时间选择器", | 
					
						
							|  |  |  |  |                 }, | 
					
						
							|  |  |  |  |                 { | 
					
						
							|  |  |  |  |                   value: "date-picker", | 
					
						
							|  |  |  |  |                   label: "DatePicker 日期选择器", | 
					
						
							|  |  |  |  |                 }, | 
					
						
							|  |  |  |  |                 { | 
					
						
							|  |  |  |  |                   value: "datetime-picker", | 
					
						
							|  |  |  |  |                   label: "DateTimePicker 日期时间选择器", | 
					
						
							|  |  |  |  |                 }, | 
					
						
							|  |  |  |  |                 { | 
					
						
							|  |  |  |  |                   value: "upload", | 
					
						
							|  |  |  |  |                   label: "Upload 上传", | 
					
						
							|  |  |  |  |                 }, | 
					
						
							|  |  |  |  |                 { | 
					
						
							|  |  |  |  |                   value: "rate", | 
					
						
							|  |  |  |  |                   label: "Rate 评分", | 
					
						
							|  |  |  |  |                 }, | 
					
						
							|  |  |  |  |                 { | 
					
						
							|  |  |  |  |                   value: "form", | 
					
						
							|  |  |  |  |                   label: "Form 表单", | 
					
						
							|  |  |  |  |                 }, | 
					
						
							|  |  |  |  |               ], | 
					
						
							|  |  |  |  |             }, | 
					
						
							|  |  |  |  |             { | 
					
						
							|  |  |  |  |               value: "data", | 
					
						
							|  |  |  |  |               label: "Data", | 
					
						
							|  |  |  |  |               children: [ | 
					
						
							|  |  |  |  |                 { | 
					
						
							|  |  |  |  |                   value: "table", | 
					
						
							|  |  |  |  |                   label: "Table 表格", | 
					
						
							|  |  |  |  |                 }, | 
					
						
							|  |  |  |  |                 { | 
					
						
							|  |  |  |  |                   value: "tag", | 
					
						
							|  |  |  |  |                   label: "Tag 标签", | 
					
						
							|  |  |  |  |                 }, | 
					
						
							|  |  |  |  |                 { | 
					
						
							|  |  |  |  |                   value: "progress", | 
					
						
							|  |  |  |  |                   label: "Progress 进度条", | 
					
						
							|  |  |  |  |                 }, | 
					
						
							|  |  |  |  |                 { | 
					
						
							|  |  |  |  |                   value: "tree", | 
					
						
							|  |  |  |  |                   label: "Tree 树形控件", | 
					
						
							|  |  |  |  |                 }, | 
					
						
							|  |  |  |  |                 { | 
					
						
							|  |  |  |  |                   value: "pagination", | 
					
						
							|  |  |  |  |                   label: "Pagination 分页", | 
					
						
							|  |  |  |  |                 }, | 
					
						
							|  |  |  |  |                 { | 
					
						
							|  |  |  |  |                   value: "badge", | 
					
						
							|  |  |  |  |                   label: "Badge 标记", | 
					
						
							|  |  |  |  |                 }, | 
					
						
							|  |  |  |  |               ], | 
					
						
							|  |  |  |  |             }, | 
					
						
							|  |  |  |  |             { | 
					
						
							|  |  |  |  |               value: "notice", | 
					
						
							|  |  |  |  |               label: "Notice", | 
					
						
							|  |  |  |  |               children: [ | 
					
						
							|  |  |  |  |                 { | 
					
						
							|  |  |  |  |                   value: "alert", | 
					
						
							|  |  |  |  |                   label: "Alert 警告", | 
					
						
							|  |  |  |  |                 }, | 
					
						
							|  |  |  |  |                 { | 
					
						
							|  |  |  |  |                   value: "loading", | 
					
						
							|  |  |  |  |                   label: "Loading 加载", | 
					
						
							|  |  |  |  |                 }, | 
					
						
							|  |  |  |  |                 { | 
					
						
							|  |  |  |  |                   value: "message", | 
					
						
							|  |  |  |  |                   label: "Message 消息提示", | 
					
						
							|  |  |  |  |                 }, | 
					
						
							|  |  |  |  |                 { | 
					
						
							|  |  |  |  |                   value: "message-box", | 
					
						
							|  |  |  |  |                   label: "MessageBox 弹框", | 
					
						
							|  |  |  |  |                 }, | 
					
						
							|  |  |  |  |                 { | 
					
						
							|  |  |  |  |                   value: "notification", | 
					
						
							|  |  |  |  |                   label: "Notification 通知", | 
					
						
							|  |  |  |  |                 }, | 
					
						
							|  |  |  |  |               ], | 
					
						
							|  |  |  |  |             }, | 
					
						
							|  |  |  |  |             { | 
					
						
							|  |  |  |  |               value: "navigation", | 
					
						
							|  |  |  |  |               label: "Navigation", | 
					
						
							|  |  |  |  |               children: [ | 
					
						
							|  |  |  |  |                 { | 
					
						
							|  |  |  |  |                   value: "menu", | 
					
						
							|  |  |  |  |                   label: "NavMenu 导航菜单", | 
					
						
							|  |  |  |  |                 }, | 
					
						
							|  |  |  |  |                 { | 
					
						
							|  |  |  |  |                   value: "tabs", | 
					
						
							|  |  |  |  |                   label: "Tabs 标签页", | 
					
						
							|  |  |  |  |                 }, | 
					
						
							|  |  |  |  |                 { | 
					
						
							|  |  |  |  |                   value: "breadcrumb", | 
					
						
							|  |  |  |  |                   label: "Breadcrumb 面包屑", | 
					
						
							|  |  |  |  |                 }, | 
					
						
							|  |  |  |  |                 { | 
					
						
							|  |  |  |  |                   value: "dropdown", | 
					
						
							|  |  |  |  |                   label: "Dropdown 下拉菜单", | 
					
						
							|  |  |  |  |                 }, | 
					
						
							|  |  |  |  |                 { | 
					
						
							|  |  |  |  |                   value: "steps", | 
					
						
							|  |  |  |  |                   label: "Steps 步骤条", | 
					
						
							|  |  |  |  |                 }, | 
					
						
							|  |  |  |  |               ], | 
					
						
							|  |  |  |  |             }, | 
					
						
							|  |  |  |  |             { | 
					
						
							|  |  |  |  |               value: "others", | 
					
						
							|  |  |  |  |               label: "Others", | 
					
						
							|  |  |  |  |               children: [ | 
					
						
							|  |  |  |  |                 { | 
					
						
							|  |  |  |  |                   value: "dialog", | 
					
						
							|  |  |  |  |                   label: "Dialog 对话框", | 
					
						
							|  |  |  |  |                 }, | 
					
						
							|  |  |  |  |                 { | 
					
						
							|  |  |  |  |                   value: "tooltip", | 
					
						
							|  |  |  |  |                   label: "Tooltip 文字提示", | 
					
						
							|  |  |  |  |                 }, | 
					
						
							|  |  |  |  |                 { | 
					
						
							|  |  |  |  |                   value: "popover", | 
					
						
							|  |  |  |  |                   label: "Popover 弹出框", | 
					
						
							|  |  |  |  |                 }, | 
					
						
							|  |  |  |  |                 { | 
					
						
							|  |  |  |  |                   value: "card", | 
					
						
							|  |  |  |  |                   label: "Card 卡片", | 
					
						
							|  |  |  |  |                 }, | 
					
						
							|  |  |  |  |                 { | 
					
						
							|  |  |  |  |                   value: "carousel", | 
					
						
							|  |  |  |  |                   label: "Carousel 走马灯", | 
					
						
							|  |  |  |  |                 }, | 
					
						
							|  |  |  |  |                 { | 
					
						
							|  |  |  |  |                   value: "collapse", | 
					
						
							|  |  |  |  |                   label: "Collapse 折叠面板", | 
					
						
							|  |  |  |  |                 }, | 
					
						
							|  |  |  |  |               ], | 
					
						
							|  |  |  |  |             }, | 
					
						
							|  |  |  |  |           ], | 
					
						
							|  |  |  |  |         }, | 
					
						
							|  |  |  |  |         { | 
					
						
							|  |  |  |  |           value: "ziyuan", | 
					
						
							|  |  |  |  |           label: "资源", | 
					
						
							|  |  |  |  |           children: [ | 
					
						
							|  |  |  |  |             { | 
					
						
							|  |  |  |  |               value: "axure", | 
					
						
							|  |  |  |  |               label: "Axure Components", | 
					
						
							|  |  |  |  |             }, | 
					
						
							|  |  |  |  |             { | 
					
						
							|  |  |  |  |               value: "sketch", | 
					
						
							|  |  |  |  |               label: "Sketch Templates", | 
					
						
							|  |  |  |  |             }, | 
					
						
							|  |  |  |  |             { | 
					
						
							|  |  |  |  |               value: "jiaohu", | 
					
						
							|  |  |  |  |               label: "组件交互文档", | 
					
						
							|  |  |  |  |             }, | 
					
						
							|  |  |  |  |           ], | 
					
						
							|  |  |  |  |         }, | 
					
						
							|  |  |  |  |       ], | 
					
						
							| 
									
										
										
										
											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-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-14 17:43:24 +08:00
										 |  |  |  |     // this.initWebSocket();
 | 
					
						
							| 
									
										
										
										
											2024-10-18 17:31:35 +08:00
										 |  |  |  |   }, | 
					
						
							|  |  |  |  |   methods: { | 
					
						
							|  |  |  |  |     /* 获取当前时间 */ | 
					
						
							|  |  |  |  |     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-10-25 17:29:08 +08:00
										 |  |  |  |     /* 获取数据栏右上角选项数据 */ | 
					
						
							|  |  |  |  |     getSelect() { | 
					
						
							|  |  |  |  |       selectTypeList().then(({ code, data }) => { | 
					
						
							|  |  |  |  |         if (code === 200) { | 
					
						
							|  |  |  |  |           this.selectTypeArr = data; | 
					
						
							|  |  |  |  |         } | 
					
						
							|  |  |  |  |       }); | 
					
						
							|  |  |  |  |     }, | 
					
						
							| 
									
										
										
										
											2024-11-07 09:30:17 +08:00
										 |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-11-07 12:04:16 +08:00
										 |  |  |  |     /* 获取路段下拉数据 */ | 
					
						
							|  |  |  |  |     getRoadList() { | 
					
						
							|  |  |  |  |       getRoadListTypes().then(({ code, data }) => { | 
					
						
							|  |  |  |  |         if (code === 200) { | 
					
						
							|  |  |  |  |           this.roadList = data; | 
					
						
							|  |  |  |  |         } | 
					
						
							|  |  |  |  |       }); | 
					
						
							|  |  |  |  |     }, | 
					
						
							|  |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-11-11 14:40:40 +08:00
										 |  |  |  |     /* 获取图片背景左上角病害类型下拉 */ | 
					
						
							|  |  |  |  |     getDieaseTypeList() { | 
					
						
							| 
									
										
										
										
											2024-11-14 17:43:24 +08:00
										 |  |  |  |       getItemTypes().then(({ code, data }) => { | 
					
						
							| 
									
										
										
										
											2024-11-13 15:37:25 +08:00
										 |  |  |  |         if (code === 200) { | 
					
						
							|  |  |  |  |           this.dieaseTypeList = data; | 
					
						
							|  |  |  |  |         } | 
					
						
							|  |  |  |  |       }); | 
					
						
							| 
									
										
										
										
											2024-11-11 14:40:40 +08:00
										 |  |  |  |     }, | 
					
						
							|  |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-10-28 10:00:28 +08:00
										 |  |  |  |     /* 获取图片背景下坐标数据 */ | 
					
						
							| 
									
										
										
										
											2024-11-15 11:03:30 +08:00
										 |  |  |  |     getMapCare(value) { | 
					
						
							| 
									
										
										
										
											2024-11-15 18:08:37 +08:00
										 |  |  |  |       console.log(value,this.mapCareSelect, "获取图片背景下坐标数据"); | 
					
						
							|  |  |  |  |       comppanyImg({ type: value }).then(({ code, data }) => { | 
					
						
							| 
									
										
										
										
											2024-10-31 14:39:01 +08:00
										 |  |  |  |         if (code === 200) { | 
					
						
							| 
									
										
										
										
											2024-11-07 09:30:17 +08:00
										 |  |  |  |           this.mapCareList = data; | 
					
						
							| 
									
										
										
										
											2024-10-31 14:39:01 +08:00
										 |  |  |  |         } | 
					
						
							|  |  |  |  |       }); | 
					
						
							| 
									
										
										
										
											2024-10-28 10:00:28 +08:00
										 |  |  |  |     }, | 
					
						
							| 
									
										
										
										
											2024-11-07 09:30:17 +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-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-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-07 12:04:16 +08:00
										 |  |  |  |     /* 关闭查看点位大图弹窗 */ | 
					
						
							|  |  |  |  |     screenImgCancel() { | 
					
						
							|  |  |  |  |       this.showImageDialog = false; | 
					
						
							|  |  |  |  |     }, | 
					
						
							|  |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-10-23 17:17:37 +08:00
										 |  |  |  |     /* 切换icon类型多选框事件 */ | 
					
						
							|  |  |  |  |     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-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 []; | 
					
						
							|  |  |  |  |           }); | 
					
						
							|  |  |  |  |           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-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-06 11:07:52 +08:00
										 |  |  |  |           data: { | 
					
						
							|  |  |  |  |             iconType: element.iconType, | 
					
						
							| 
									
										
										
										
											2024-11-07 12:04:16 +08:00
										 |  |  |  |             imageUrl: element.imageUrl, | 
					
						
							| 
									
										
										
										
											2024-11-06 11:07:52 +08:00
										 |  |  |  |             rect: element.rect, | 
					
						
							|  |  |  |  |           }, | 
					
						
							| 
									
										
										
										
											2024-10-23 17:17:37 +08:00
										 |  |  |  |           // 自己设置一个标识
 | 
					
						
							|  |  |  |  |           type: "icon", | 
					
						
							|  |  |  |  |         }); | 
					
						
							|  |  |  |  |         // 可以给点位设置样式
 | 
					
						
							|  |  |  |  |         // feature.setStyle([
 | 
					
						
							|  |  |  |  |         //   new Style({
 | 
					
						
							|  |  |  |  |         //     image: new Icon({
 | 
					
						
							|  |  |  |  |         //       crossOrigin: "anonymous",
 | 
					
						
							|  |  |  |  |         //       src: logo,
 | 
					
						
							|  |  |  |  |         //       // 图标缩放比例
 | 
					
						
							|  |  |  |  |         //       scale: 0.05,
 | 
					
						
							|  |  |  |  |         //     }),
 | 
					
						
							|  |  |  |  |         //   }),
 | 
					
						
							|  |  |  |  |         // ]);
 | 
					
						
							|  |  |  |  |         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", | 
					
						
							|  |  |  |  |                 src: require(`@/assets/screen/index/${ | 
					
						
							|  |  |  |  |                   this.mapLogeList[ | 
					
						
							|  |  |  |  |                     feature.getProperties().features[0].get("data").iconType | 
					
						
							|  |  |  |  |                   ] | 
					
						
							|  |  |  |  |                 }.png`),
 | 
					
						
							|  |  |  |  |                 // 图标缩放比例
 | 
					
						
							|  |  |  |  |                 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-10-23 17:17:37 +08:00
										 |  |  |  |     /* 获取地图线段点位信息 */ | 
					
						
							|  |  |  |  |     getLinePoint() { | 
					
						
							| 
									
										
										
										
											2024-11-14 17:43:24 +08:00
										 |  |  |  |       if (!this.markLayerLines) { | 
					
						
							|  |  |  |  |         mapPciList().then(({ code, data }) => { | 
					
						
							|  |  |  |  |           if (code === 200) { | 
					
						
							|  |  |  |  |             this.lineString = data; | 
					
						
							|  |  |  |  |             this.drawLine(); | 
					
						
							|  |  |  |  |           } | 
					
						
							|  |  |  |  |         }); | 
					
						
							|  |  |  |  |       } | 
					
						
							| 
									
										
										
										
											2024-10-23 17:17:37 +08:00
										 |  |  |  |     }, | 
					
						
							| 
									
										
										
										
											2024-11-07 09:30:17 +08:00
										 |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-10-23 17:17:37 +08:00
										 |  |  |  |     /* 绘制地图线段 */ | 
					
						
							|  |  |  |  |     drawLine() { | 
					
						
							|  |  |  |  |       const features = []; | 
					
						
							|  |  |  |  |       this.lineString.forEach((element) => { | 
					
						
							| 
									
										
										
										
											2024-11-07 12:04:16 +08:00
										 |  |  |  |         const lines = element?.coordinates?.split(";").map((it) => { | 
					
						
							|  |  |  |  |           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", | 
					
						
							|  |  |  |  |               }), | 
					
						
							|  |  |  |  |             }), | 
					
						
							|  |  |  |  |           }), | 
					
						
							|  |  |  |  |         ]); | 
					
						
							|  |  |  |  |         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-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-07 12:04:16 +08:00
										 |  |  |  |     /* 地图下方4图标类别切换点击事件 */ | 
					
						
							| 
									
										
										
										
											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-14 17:43:24 +08:00
										 |  |  |  |         this.getIconType(); | 
					
						
							|  |  |  |  |         this.getCenterPiont(); | 
					
						
							| 
									
										
										
										
											2024-10-23 17:17:37 +08:00
										 |  |  |  |       } | 
					
						
							|  |  |  |  |     }, | 
					
						
							| 
									
										
										
										
											2024-11-07 09:30:17 +08:00
										 |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-10-23 17:17:37 +08:00
										 |  |  |  |     /* 获取icon多选数据 */ | 
					
						
							| 
									
										
										
										
											2024-11-14 17:43:24 +08:00
										 |  |  |  |     getIconType() { | 
					
						
							| 
									
										
										
										
											2024-11-01 13:15:24 +08:00
										 |  |  |  |       this.mapLogeList = {}; | 
					
						
							| 
									
										
										
										
											2024-11-15 18:08:37 +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-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-10-23 17:17:37 +08:00
										 |  |  |  |     /* 地图选中feature事件 */ | 
					
						
							|  |  |  |  |     featureSelect(e) { | 
					
						
							|  |  |  |  |       const map = this.$refs.roadMap.instance.get("map"); | 
					
						
							|  |  |  |  |       let selectedFeatures = e.selected; | 
					
						
							|  |  |  |  |       if (selectedFeatures.length > 0) { | 
					
						
							|  |  |  |  |         let feature = selectedFeatures[0]; | 
					
						
							|  |  |  |  |         let features = feature.get("features"); | 
					
						
							|  |  |  |  |         // 点击线段事件
 | 
					
						
							|  |  |  |  |         if (feature.getProperties().type === "line") { | 
					
						
							|  |  |  |  |           console.log(feature, "线段参数"); | 
					
						
							|  |  |  |  |         } 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-10-23 17:17:37 +08:00
										 |  |  |  |             console.log(selectFeature.get("data")); | 
					
						
							|  |  |  |  |           } 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-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-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-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-13 15:37:25 +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-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-10-18 17:31:35 +08:00
										 |  |  |  |         } | 
					
						
							|  |  |  |  |       } | 
					
						
							|  |  |  |  |     }, | 
					
						
							| 
									
										
										
										
											2024-11-07 09:30:17 +08:00
										 |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-10-18 17:31:35 +08:00
										 |  |  |  |     /* 跳转系统首页 */ | 
					
						
							|  |  |  |  |     goIndex() { | 
					
						
							|  |  |  |  |       this.$router.push("/index"); | 
					
						
							|  |  |  |  |     }, | 
					
						
							| 
									
										
										
										
											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], | 
					
						
							|  |  |  |  |         }, | 
					
						
							|  |  |  |  |       ]; | 
					
						
							|  |  |  |  |     }, | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |     /* 图片红框位置 */ | 
					
						
							|  |  |  |  |     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-11-14 17:43:24 +08:00
										 |  |  |  | 
 | 
					
						
							|  |  |  |  |     /* 初始化websocket */ | 
					
						
							|  |  |  |  |     initWebSocket() { | 
					
						
							|  |  |  |  |       const url = `ws://192.168.1.188:8080/websocket?token=${getToken()}`; | 
					
						
							|  |  |  |  |       const data = { type: "carLocation", status: true }; | 
					
						
							|  |  |  |  |       connectWebsocket( | 
					
						
							|  |  |  |  |         url, | 
					
						
							|  |  |  |  |         data, | 
					
						
							|  |  |  |  |         (res) => { | 
					
						
							|  |  |  |  |           // console.log("onWsMessage接收到服务器的数据: ", res);
 | 
					
						
							|  |  |  |  |           console.log(JSON.parse(res)); | 
					
						
							|  |  |  |  |         }, | 
					
						
							|  |  |  |  |         (err) => { | 
					
						
							|  |  |  |  |           console.log("断开重连"); | 
					
						
							|  |  |  |  |         } | 
					
						
							|  |  |  |  |       ); | 
					
						
							|  |  |  |  |     }, | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |     /* 发送消息 */ | 
					
						
							|  |  |  |  |     sendMsg() { | 
					
						
							|  |  |  |  |       sendMsg(5555); //value是发送的值
 | 
					
						
							|  |  |  |  |       // this.value = "";
 | 
					
						
							|  |  |  |  |     }, | 
					
						
							| 
									
										
										
										
											2024-10-18 17:31:35 +08:00
										 |  |  |  |   }, | 
					
						
							|  |  |  |  |   beforeDestroy() { | 
					
						
							|  |  |  |  |     clearInterval(this.timeFlag); | 
					
						
							| 
									
										
										
										
											2024-11-14 17:43:24 +08:00
										 |  |  |  |     closeWebsocket(); | 
					
						
							| 
									
										
										
										
											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; | 
					
						
							|  |  |  |  |       } | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |       .el-radio-button__orig-radio:checked + .el-radio-button__inner { | 
					
						
							|  |  |  |  |         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; | 
					
						
							|  |  |  |  |       } | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |       .el-radio-button__orig-radio:checked + .el-radio-button__inner { | 
					
						
							|  |  |  |  |         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%; | 
					
						
							|  |  |  |  |         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-25 17:29:08 +08:00
										 |  |  |  |     ::v-deep .baseLayerClass { | 
					
						
							| 
									
										
										
										
											2024-10-23 17:17:37 +08:00
										 |  |  |  |       filter: grayscale(200%) invert(200%) sepia(50%) hue-rotate(175deg) | 
					
						
							|  |  |  |  |         brightness(80%) saturate(550%); | 
					
						
							| 
									
										
										
										
											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; | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |     > div { | 
					
						
							|  |  |  |  |       margin: 0 0.5rem; | 
					
						
							|  |  |  |  |       display: flex; | 
					
						
							|  |  |  |  |       align-items: flex-end; | 
					
						
							|  |  |  |  |     } | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |     .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; | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |     > div { | 
					
						
							|  |  |  |  |       height: 100%; | 
					
						
							|  |  |  |  |       width: 37.5%; | 
					
						
							|  |  |  |  |     } | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |     > div:nth-child(2) { | 
					
						
							|  |  |  |  |       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-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
										 |  |  |  | 
 | 
					
						
							|  |  |  |  | /* 修改弹窗样式 */ | 
					
						
							|  |  |  |  | ::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%; | 
					
						
							|  |  |  |  |     height: 80%; | 
					
						
							|  |  |  |  |     display: flex; | 
					
						
							|  |  |  |  |     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
										 |  |  |  | 
 | 
					
						
							|  |  |  |  | // 大屏下拉框样式
 | 
					
						
							|  |  |  |  | ::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; | 
					
						
							|  |  |  |  |     .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; | 
					
						
							|  |  |  |  |   } | 
					
						
							|  |  |  |  | } | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  | input[aria-hidden="true"] { | 
					
						
							|  |  |  |  |   display: none !important; | 
					
						
							|  |  |  |  | } | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  | .el-radio:focus:not(.is-focus):not(:active):not(.is-disabled) .el-radio__inner { | 
					
						
							|  |  |  |  |   box-shadow: none; | 
					
						
							|  |  |  |  | } | 
					
						
							|  |  |  |  | </style> |