From 594de76ed51fd49fb79b912212bb0052a63e7671 Mon Sep 17 00:00:00 2001
From: feiyu02 <risaku@163.com>
Date: 星期四, 09 四月 2026 16:10:45 +0800
Subject: [PATCH] 2026.4.9
---
src/main/kotlin/com/flightfeather/uav/domain/repository/impl/AirDataRepImpl.kt | 59 ++++++++++++-----------------------------------------------
1 files changed, 12 insertions(+), 47 deletions(-)
diff --git a/src/main/kotlin/com/flightfeather/uav/domain/repository/impl/AirDataRepImpl.kt b/src/main/kotlin/com/flightfeather/uav/domain/repository/impl/AirDataRepImpl.kt
index 5008d5b..59e2d87 100644
--- a/src/main/kotlin/com/flightfeather/uav/domain/repository/impl/AirDataRepImpl.kt
+++ b/src/main/kotlin/com/flightfeather/uav/domain/repository/impl/AirDataRepImpl.kt
@@ -35,11 +35,11 @@
private val tmpVehicleDataList = mutableListOf<BaseRealTimeData>()
// 璧拌埅鐩戞祴鏍″噯绯绘暟
- private val calibrationMap = mutableMapOf<String, MutableMap<Int, Float>>()
+ private val calibrationMap = mutableMapOf<String?, MutableMap<Int, Float>>()
// 璧拌埅鐩戞祴鏍″噯绯绘暟鏇存柊鏃堕棿
private var cUpdateTime = LocalDateTime.now()
// 璧拌埅鐩戞祴鏍″噯绯绘暟鏇存柊鏃堕棿闂撮殧锛堝垎閽燂級
- private val cInterval = 5L
+ private val cInterval = 1L
override fun saveAirData(dataPackage: AirDataPackage): Int {
val data = RealTimeData().apply {
@@ -132,18 +132,16 @@
dataList.forEach {vo ->
when (UWDeviceType.getType(vo.deviceCode)) {
UWDeviceType.VEHICLE -> {
- val d = RealTimeDataVehicle()
- dataTransform(vo, d)
+ val d = vo.toBaseRealTimeData(RealTimeDataVehicle::class.java)
/***************************************************************************************************/
// FIXME: 2021/10/27 杞﹁浇鐩戞祴閮ㄥ垎鍥犲瓙閲忕骇璋冩暣
- calibration(d, UWDeviceType.VEHICLE)
+ calibration(d, d.deviceCode)
/***************************************************************************************************/
realTimeDataVehicleMapper.insert(d)
res.add(d)
}
UWDeviceType.UAV -> {
- val d = RealTimeDataUav()
- dataTransform(vo, d)
+ val d = vo.toBaseRealTimeData(RealTimeDataUav::class.java)
/***************************************************************************************************/
// FIXME: 2021/10/25 鏃犱汉鏈洪儴鍒嗗洜瀛愰噰鐢ㄨ溅杞芥暟鎹~鍏咃紝鍙栨渶鏂扮殑15鍒嗛挓鐨勬暟鎹�
if (tmpVehicleDataList.isEmpty()) {
@@ -167,8 +165,7 @@
res.add(d)
}
UWDeviceType.GRID -> {
- val d = RealTimeDataGrid()
- dataTransform(vo, d)
+ val d = vo.toBaseRealTimeData(RealTimeDataGrid::class.java)
/**************************************************************************/
// FIXME: 2021/11/8 閽堝鍘嗗彶缃戞牸鍖栧師濮嬫暟鎹紝杩涜涓存椂鏍″噯澶勭悊
// val dTime = LocalDateTime.ofInstant(d.dataTime?.toInstant(), ZoneId.systemDefault())
@@ -270,52 +267,20 @@
}
}
- fun dataTransform(vo: DataVo, bean: BaseRealTimeData) {
- bean.apply {
- deviceCode = vo.deviceCode
- latitude = vo.lat?.toBigDecimal()
- longitude = vo.lng?.toBigDecimal()
- dataTime = SimpleDateFormat("yyyy-MM-dd HH:mm:ss").parse(vo.time)
- createTime = Date()
- vo.values?.forEach {
- when (it.factorId?.toInt()) {
- FactorType.NO2.value -> no2 = it.factorData?.toFloat()
- FactorType.CO.value -> co = it.factorData?.toFloat()
- FactorType.H2S.value -> h2s = it.factorData?.toFloat()
- FactorType.SO2.value -> so2 = it.factorData?.toFloat()
- FactorType.O3.value -> o3 = it.factorData?.toFloat()
-
- FactorType.PM25.value -> pm25 = it.factorData?.toFloat()
- FactorType.PM10.value -> pm10 = it.factorData?.toFloat()
- FactorType.TEMPERATURE.value -> temperature = it.factorData?.toFloat()
- FactorType.HUMIDITY.value -> humidity = it.factorData?.toFloat()
- FactorType.VOC.value -> voc = it.factorData?.toFloat()
-
- FactorType.NOI.value -> noi = it.factorData?.toFloat()
- FactorType.VELOCITY.value -> velocity = it.factorData?.toFloat()
- FactorType.WIND_SPEED.value -> windSpeed = it.factorData?.toFloat()
- FactorType.WIND_DIRECTION.value -> windDirection = it.factorData?.toFloat()
- FactorType.HEIGHT.value -> height = it.factorData?.toFloat()
- }
- }
-
- }
- }
-
- private fun calibration(data: BaseRealTimeData, type: UWDeviceType) {
+ private fun calibration(data: BaseRealTimeData, deviceCode: String?) {
//1. 鏍″噯绯绘暟鎸夌収涓�瀹氭椂闂撮棿闅旇繘琛屽埛鏂�
val now = LocalDateTime.now()
- if (calibrationMap.isEmpty() || now.minusMinutes(cInterval).isAfter(cUpdateTime)) {
+ if (calibrationMap[deviceCode].isNullOrEmpty() || now.minusMinutes(cInterval).isAfter(cUpdateTime)) {
cUpdateTime = now
- calibrationMap[type.value] = mutableMapOf()
+ calibrationMap[deviceCode] = mutableMapOf()
factorCalibrationMapper.selectByExample(Example(FactorCalibration::class.java).apply {
- createCriteria().andEqualTo("deviceType", type.value)
+ createCriteria().andEqualTo("deviceType", deviceCode)
}).forEach {
- calibrationMap[type.value]?.put(it.factorId, it.factorScale)
+ calibrationMap[deviceCode]?.put(it.factorId, it.factorScale)
}
}
//2. 鏍规嵁鏍″噯绯绘暟璁$畻
- calibrationMap[type.value]?.let{
+ calibrationMap[deviceCode]?.let {
data.voc = data.voc?.times(it[FactorType.VOC.value] ?: 1f)
data.co = data.co?.times(it[FactorType.CO.value] ?: 1f)
data.pm25 = data.pm25?.times(it[FactorType.PM25.value] ?: 1f)
--
Gitblit v1.9.3