From 8eb584869b4fd4de0f51c93f2616f12e51df9193 Mon Sep 17 00:00:00 2001
From: feiyu02 <risaku@163.com>
Date: 星期四, 18 十二月 2025 17:48:29 +0800
Subject: [PATCH] 2025.12.18 1. 动态溯源相关分析逻辑调整; 2. 走航报告接口参数调整;

---
 src/main/kotlin/com/flightfeather/uav/biz/sourcetrace/model/PollutedClue.kt |   35 +++++++++++++++++++++--------------
 1 files changed, 21 insertions(+), 14 deletions(-)

diff --git a/src/main/kotlin/com/flightfeather/uav/biz/sourcetrace/model/PollutedClue.kt b/src/main/kotlin/com/flightfeather/uav/biz/sourcetrace/model/PollutedClue.kt
index 6775572..e8c29b7 100644
--- a/src/main/kotlin/com/flightfeather/uav/biz/sourcetrace/model/PollutedClue.kt
+++ b/src/main/kotlin/com/flightfeather/uav/biz/sourcetrace/model/PollutedClue.kt
@@ -2,6 +2,7 @@
 
 import com.flightfeather.uav.biz.FactorFilter
 import com.flightfeather.uav.biz.dataanalysis.BaseExceptionResult
+import com.flightfeather.uav.biz.dataanalysis.model.ExceptionTag
 import com.flightfeather.uav.biz.dataanalysis.model.ExceptionType
 import com.flightfeather.uav.biz.sourcetrace.config.RTExcWindLevelConfig
 import com.flightfeather.uav.common.utils.DateUtil
@@ -9,6 +10,7 @@
 import com.flightfeather.uav.domain.entity.BaseRealTimeData
 import com.flightfeather.uav.domain.entity.SceneInfo
 import com.flightfeather.uav.domain.repository.SceneInfoRep
+import com.flightfeather.uav.socket.sender.MsgType
 
 /**
  * 姹℃煋绾跨储
@@ -19,23 +21,28 @@
 class PollutedClue() : BaseExceptionResult() {
 
     constructor(
-        start: BaseRealTimeData,
-        end: BaseRealTimeData?,
-        factor: FactorFilter.SelectedFactor,
-        exceptionData: List<BaseRealTimeData>,
+        exceptions: List<Pair<FactorFilter.SelectedFactor, ExceptionTag>>,
         eType: ExceptionType,
         config: RTExcWindLevelConfig,
-        windLevelCondition: RTExcWindLevelConfig.WindLevelCondition
+        windLevelCondition: RTExcWindLevelConfig.WindLevelCondition?,
     ) : this() {
-        this.factor = factor
-        if (exceptionData.isEmpty()) return
-        pollutedData = PollutedData(start, end, factor, exceptionData, eType, windLevelCondition)
-        pollutedArea = PollutedArea(exceptionData, config, windLevelCondition)
+        if (exceptions.isEmpty() || exceptions[0].second.exceptionData.isEmpty()) return
+        deviceCode = exceptions[0].second.startData?.deviceCode
+
+
+        // 鑾峰彇鍘婚噸鍚庣殑鐩戞祴鍥犲瓙绫诲瀷
+        val factorList = exceptions.map { it.first }.distinct()
+        pollutedData = PollutedData(exceptions, eType)
+        pollutedArea = PollutedArea(pollutedData!!, config, windLevelCondition)
+
     }
 
     /**
-     * 6. 灞曠ず鏁版嵁鍙樺寲鎯呭喌锛屼笂鍗囬�熺巼绛夌瓑
+     * @see [MsgType]
      */
+    var msgType: Int? = null
+
+    var deviceCode: String? = null
 
     var pollutedData: PollutedData? = null
 
@@ -43,13 +50,13 @@
 
     var pollutedSource: PollutedSource? = null
 
-    private var factor: FactorFilter.SelectedFactor? = null
-
     /**
      * 鏌ユ壘绯荤粺鍐呴儴婧簮鑼冨洿鍐呯殑姹℃煋浼佷笟
      */
     fun searchScenes(sceneInfoRep: SceneInfoRep) {
-        if (pollutedArea == null || factor == null) return
-        pollutedSource = PollutedSource().also { it.searchScenes(pollutedArea!!, sceneInfoRep, factor!!) }
+        if (pollutedArea == null || pollutedData == null) return
+        pollutedSource = PollutedSource().also {
+            it.searchScenes(pollutedArea!!, sceneInfoRep, pollutedData!!)
+        }
     }
 }
\ No newline at end of file

--
Gitblit v1.9.3