fix:小车打点
This commit is contained in:
		
							parent
							
								
									d52c5bb169
								
							
						
					
					
						commit
						8c54ee60e0
					
				| @ -1,3 +1,5 @@ | ||||
| import modal from "./modal"; | ||||
| 
 | ||||
| // WebSocketService.js
 | ||||
| class WebSocketService { | ||||
|   constructor() { | ||||
| @ -10,22 +12,27 @@ class WebSocketService { | ||||
|     this.ws = new WebSocket(url); | ||||
| 
 | ||||
|     this.ws.onopen = () => { | ||||
|       console.log('WebSocket connected'); | ||||
|       this.emit('open'); | ||||
|       console.log("WebSocket connected"); | ||||
|       this.emit("open"); | ||||
|     }; | ||||
| 
 | ||||
|     this.ws.onmessage = (event) => { | ||||
|       this.emit('message', JSON.parse(event.data)); | ||||
|       const message = JSON.parse(event.data); | ||||
|       if (message.type === "info") { | ||||
|         modal.msgSuccess(message.data); | ||||
|         return; | ||||
|       } | ||||
|       this.emit("message", message); | ||||
|     }; | ||||
| 
 | ||||
|     this.ws.onerror = (error) => { | ||||
|       console.error('WebSocket error:', error); | ||||
|       this.emit('error', error); | ||||
|       console.error("WebSocket error:", error); | ||||
|       this.emit("error", error); | ||||
|     }; | ||||
| 
 | ||||
|     this.ws.onclose = () => { | ||||
|       console.log('WebSocket closed'); | ||||
|       this.emit('close'); | ||||
|       console.log("WebSocket closed"); | ||||
|       this.emit("close"); | ||||
|       setTimeout(() => this.connect(url), this.reconnectInterval); | ||||
|     }; | ||||
|   } | ||||
| @ -34,20 +41,18 @@ class WebSocketService { | ||||
|     if (this.ws && this.ws.readyState === WebSocket.OPEN) { | ||||
|       this.ws.send(JSON.stringify(data)); | ||||
|     } else { | ||||
|       console.error('WebSocket is not connected'); | ||||
|       console.error("WebSocket is not connected"); | ||||
|     } | ||||
|   } | ||||
| 
 | ||||
|   on(event, callback) { | ||||
|     if (!this.eventListeners[event]) { | ||||
|       this.eventListeners[event] = []; | ||||
|     } | ||||
|     this.eventListeners[event] = []; | ||||
|     this.eventListeners[event].push(callback); | ||||
|   } | ||||
| 
 | ||||
|   emit(event, data) { | ||||
|     if (this.eventListeners[event]) { | ||||
|       this.eventListeners[event].forEach(callback => callback(data)); | ||||
|       this.eventListeners[event].forEach((callback) => callback(data)); | ||||
|     } | ||||
|   } | ||||
| 
 | ||||
| @ -58,4 +63,4 @@ class WebSocketService { | ||||
|   } | ||||
| } | ||||
| 
 | ||||
| export default WebSocketService; | ||||
| export default WebSocketService; | ||||
|  | ||||
| @ -2,7 +2,7 @@ | ||||
|  * @Author: SunTao 328867980@qq.com | ||||
|  * @Date: 2024-10-17 11:34:00 | ||||
|  * @LastEditors: SunTao 328867980@qq.com | ||||
|  * @LastEditTime: 2024-11-29 15:31:24 | ||||
|  * @LastEditTime: 2024-11-29 17:41:31 | ||||
|  * @FilePath: \znxjxt-ui\src\views\big-screen\index.vue | ||||
|  * @Description: 大屏首页 | ||||
| --> | ||||
| @ -322,6 +322,7 @@ import VectorSource from "ol/source/Vector"; | ||||
| import VectorLayer from "ol/layer/Vector"; | ||||
| import * as geomExports from "ol/geom"; | ||||
| import Cluster from "ol/source/Cluster"; | ||||
| import logo from "@/assets/xc.png"; | ||||
| // 组件 | ||||
| import ModuleBlock from "./module-block.vue"; | ||||
| import TodayInspection from "./overview-components/today-inspection.vue"; | ||||
| @ -499,6 +500,9 @@ export default { | ||||
|       showImageDialog: false, | ||||
|       // 查看大图点位图片弹窗红框数据 | ||||
|       screenRects: [], | ||||
| 
 | ||||
|       // 小车地图点位数据源 | ||||
|       carMapPointSource: null, | ||||
|     }; | ||||
|   }, | ||||
|   created() { | ||||
| @ -512,16 +516,6 @@ export default { | ||||
|   }, | ||||
|   mounted() {}, | ||||
|   methods: { | ||||
|     /** | ||||
|      * @description: 处理websocket消息 | ||||
|      * @return {*} | ||||
|      */ | ||||
|     handleMessage() { | ||||
|       this.$ws.on("message", (data) => { | ||||
|         console.log("收到xxxxxxxx消息:", data); | ||||
|       }); | ||||
|     }, | ||||
| 
 | ||||
|     /** | ||||
|      * @description: 获取当前时间 | ||||
|      * @return {*} | ||||
| @ -1228,6 +1222,80 @@ export default { | ||||
|       } | ||||
|     }, | ||||
| 
 | ||||
|     /** | ||||
|      * @description: 处理websocket消息 | ||||
|      * @return {*} | ||||
|      */ | ||||
|     handleMessage() { | ||||
|       this.$ws.on("message", (item) => { | ||||
|         if (item.type === "carPosition") { | ||||
|           if (!this.carMapPointSource) { | ||||
|             this.drawCarMapPoint(item.data); | ||||
|           } else { | ||||
|             console.log(item.data, "location"); | ||||
|             // 获取小车图层的features数组 | ||||
|             const [features] = this.carMapPointSource.getFeatures(); | ||||
|             // 修改geometry定位 | ||||
|             features.set("geometry", new Point(item.data.location)); | ||||
|             features.setStyle([ | ||||
|               new Style({ | ||||
|                 image: new Icon({ | ||||
|                   crossOrigin: "anonymous", | ||||
|                   src: logo, | ||||
|                   // 图标缩放比例 | ||||
|                   scale: 0.03, | ||||
|                   // 将角度转换为弧度,并除以180*π | ||||
|                   rotation: (item.data.direction-90) * (Math.PI / 180), | ||||
|                 }), | ||||
|               }), | ||||
|             ]); | ||||
|           } | ||||
|         } | ||||
|       }); | ||||
|     }, | ||||
| 
 | ||||
|     /** | ||||
|      * @description: 绘制小车地图点位 | ||||
|      * @param {object} item | ||||
|      * @return {void} | ||||
|      */ | ||||
|     drawCarMapPoint(item) { | ||||
|       console.log(item, "小车点位"); | ||||
|       const features = []; | ||||
|       const feature = new Feature({ | ||||
|         geometry: new Point(item.location), | ||||
|         data: item, | ||||
|         type: "carPoint", | ||||
|       }); | ||||
|       // 可以给点位设置样式 | ||||
|       feature.setStyle([ | ||||
|         new Style({ | ||||
|           image: new Icon({ | ||||
|             crossOrigin: "anonymous", | ||||
|             src: logo, | ||||
|             // 图标缩放比例 | ||||
|             scale: 0.03, | ||||
|             // 将角度转换为弧度,并除以180*π | ||||
|             rotation: item.direction * (Math.PI / 180), | ||||
|           }), | ||||
|         }), | ||||
|       ]); | ||||
|       features.push(feature); | ||||
|       this.carMapPointSource = new VectorSource({ | ||||
|         features, | ||||
|       }); | ||||
|       const carMapPointLayer = new VectorLayer({ | ||||
|         source: this.carMapPointSource, | ||||
|         properties: { | ||||
|           type: "carPoint", | ||||
|         }, | ||||
|       }); | ||||
|       this.$nextTick(() => { | ||||
|         const map = this.$refs.roadMap.instance.get("map"); | ||||
|         map.addLayer(carMapPointLayer); | ||||
|       }); | ||||
|     }, | ||||
| 
 | ||||
|     /** | ||||
|      * @description: 跳转系统首页 | ||||
|      * @return {void} | ||||
| @ -1291,7 +1359,8 @@ export default { | ||||
|   }, | ||||
|   beforeDestroy() { | ||||
|     clearInterval(this.timeFlag); | ||||
|     this.$ws.close(); | ||||
|     const data = { type: "carLocation", status: false }; | ||||
|     this.$ws.send(data); | ||||
|   }, | ||||
| }; | ||||
| </script> | ||||
|  | ||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user