From 38d72198bfcced01ed9513b978163e5cd1d84625 Mon Sep 17 00:00:00 2001 From: feiyu02 <risaku@163.com> Date: 星期一, 21 七月 2025 15:31:41 +0800 Subject: [PATCH] 2025.7.21 1. 修改动态溯源异常判断逻辑 --- src/main/kotlin/com/flightfeather/uav/biz/sourcetrace/SourceTraceController.kt | 39 +++++++++++++++++++++++++++------------ 1 files changed, 27 insertions(+), 12 deletions(-) diff --git a/src/main/kotlin/com/flightfeather/uav/biz/sourcetrace/SourceTraceController.kt b/src/main/kotlin/com/flightfeather/uav/biz/sourcetrace/SourceTraceController.kt index 504efa2..83bb5c7 100644 --- a/src/main/kotlin/com/flightfeather/uav/biz/sourcetrace/SourceTraceController.kt +++ b/src/main/kotlin/com/flightfeather/uav/biz/sourcetrace/SourceTraceController.kt @@ -2,13 +2,11 @@ import com.flightfeather.uav.biz.FactorFilter import com.flightfeather.uav.biz.dataanalysis.BaseExceptionAnalysis -import com.flightfeather.uav.biz.sourcetrace.RealTimeAnalysisConfig import com.flightfeather.uav.biz.sourcetrace.config.RTExcWindLevelConfig import com.flightfeather.uav.biz.sourcetrace.exceptiontype.* import com.flightfeather.uav.biz.sourcetrace.model.AnalysisResult import com.flightfeather.uav.biz.sourcetrace.model.PollutedClue import com.flightfeather.uav.biz.sourcetrace.model.PollutedSummary -import com.flightfeather.uav.common.utils.GsonUtils import com.flightfeather.uav.domain.entity.BaseRealTimeData import com.flightfeather.uav.domain.repository.SceneInfoRep import com.flightfeather.uav.domain.repository.SourceTraceRep @@ -38,14 +36,20 @@ } else { RTExcWindLevelConfig( FactorFilter.builder() -// .withMain(FactorType.NO2) -// .withMain(FactorType.CO) + .withMain(FactorType.NO2) + .withMain(FactorType.CO) // .withMain(FactorType.H2S) // .withMain(FactorType.SO2) -// .withMain(FactorType.O3) + .withMain(FactorType.O3) .withMain(FactorType.PM25) .withMain(FactorType.PM10) - .withMain(FactorType.VOC) +// .withMain(FactorType.VOC) + .withCombination( + listOf( + listOf(FactorType.PM25, FactorType.PM10), + listOf(FactorType.VOC, FactorType.CO), + ) + ) .create() ) } @@ -59,6 +63,8 @@ private val sceneInfoRep: SceneInfoRep private val sourceTraceRep: SourceTraceRep private val config: RTExcWindLevelConfig + private val timer = Timer() + private var timerTask: TimerTask? = null private val taskList = mutableListOf<BaseExceptionAnalysis<RTExcWindLevelConfig, PollutedClue>>() @@ -74,8 +80,13 @@ add(RTExcWindLevel1_1(config) { exceptionCallback(it) }.also { it.init() }) add(RTExcWindLevel4(config) { exceptionCallback(it) }.also { it.init() }) add(RTExcWindLevel6(config) { exceptionCallback(it) }.also { it.init() }) - add(RTExcChangeRate(config) { exceptionCallback(it) }.also { it.init() }) + + add(RTExcChangeRate1(config) { exceptionCallback(it) }.also { it.init() }) + add(RTExcChangeRate4(config) { exceptionCallback(it) }.also { it.init() }) + add(RTExcChangeRate6(config) { exceptionCallback(it) }.also { it.init() }) + add(RTWarnChangeRate(config) { dataChangeCallback(it) }.also { it.init() }) + add(RTWarnChangeRate2(config) { dataChangeCallback(it) }.also { it.init() }) } } @@ -83,23 +94,27 @@ * 璁$畻鏂扮殑涓�鏉″疄鏃惰蛋鑸暟鎹� */ fun addOneData(data: BaseRealTimeData) { +// println("====================>") // 璁$畻寮傚父 taskList.forEach { it.onNextData(data) } pollutedSummary.refreshLatestMonitorData(data) // 闄愬畾鏃堕棿鍐呮病鏈夋柊鏁版嵁浼犲叆锛屽垯缁撴潫褰撳墠鐨勮绠� + dealOnTimeout() } /** * 瓒呮椂澶勭悊锛岃緝闀挎椂闂存病鏈夋柊鏁版嵁杩涘叆锛岃繘琛屽垵濮嬪寲鎿嶄綔 */ private fun dealOnTimeout() { - val timer = Timer(true) - timer.schedule(object : TimerTask() { +// val timer = Timer() + timerTask?.cancel() + timer.purge() + timerTask = object : TimerTask() { override fun run() { - TODO("Not yet implemented") + initTask() } - }, 60 * 1000) - timer.cancel() + } + timer.schedule(timerTask, 2 * 60 * 60 * 1000) } // 鏁版嵁绐佸彉寮傚父鍥炶皟 -- Gitblit v1.9.3