| | |
| | | import com.flightfeather.uav.socket.bean.AirDataPackage |
| | | import com.flightfeather.uav.socket.eunm.FactorType |
| | | import com.flightfeather.uav.socket.eunm.UWDeviceType |
| | | import com.github.pagehelper.PageHelper |
| | | import com.google.gson.Gson |
| | | import org.springframework.stereotype.Repository |
| | | import tk.mybatis.mapper.entity.Example |
| | | import java.math.BigDecimal |
| | | import java.text.SimpleDateFormat |
| | | import java.util.* |
| | | |
| | | /** |
| | | * @author riku |
| | |
| | | private val realTimeDataGridMapper: RealTimeDataGridMapper |
| | | ): AirDataRepository { |
| | | |
| | | // FIXME: 2021/10/25 临时车载数据,由于无人机部分监测因子数据无效,因此暂时采用车载数据作为填充 |
| | | private val tmpVehicleDataList = mutableListOf<BaseRealTimeData>() |
| | | |
| | | override fun saveAirData(dataPackage: AirDataPackage): Int { |
| | | val data = RealTimeData().apply { |
| | | deviceCode = dataPackage.deviceCode |
| | | latitude |
| | | longitude |
| | | latitude = BigDecimal.ZERO |
| | | longitude = BigDecimal.ZERO |
| | | altitude |
| | | height |
| | | factors = Gson().toJson(dataPackage.dataUnit) |
| | |
| | | } |
| | | |
| | | override fun savePrepData(dataPackage: AirDataPackage): Int { |
| | | var mapper: MyMapper<out BaseRealTimeData?>? = null |
| | | var count = 0 |
| | | when (UWDeviceType.getType(dataPackage.deviceCode)) { |
| | | UWDeviceType.VEHICLE -> { |
| | | mapper = realTimeDataVehicleMapper |
| | | RealTimeDataVehicle() |
| | | val d = RealTimeDataVehicle() |
| | | dataTransform(dataPackage, d) |
| | | realTimeDataVehicleMapper.insert(d) |
| | | count++ |
| | | } |
| | | UWDeviceType.UAV -> { |
| | | mapper = realTimeDataUavMapper |
| | | RealTimeDataUav() |
| | | val d = RealTimeDataUav() |
| | | dataTransform(dataPackage, d) |
| | | realTimeDataUavMapper.insert(d) |
| | | count++ |
| | | } |
| | | UWDeviceType.GRID -> { |
| | | mapper = realTimeDataGridMapper |
| | | RealTimeDataGrid() |
| | | val d = RealTimeDataGrid() |
| | | dataTransform(dataPackage, d) |
| | | realTimeDataGridMapper.insert(d) |
| | | count++ |
| | | } |
| | | else -> null |
| | | }?.run { |
| | | deviceCode = dataPackage.deviceCode |
| | | dataPackage.dataUnit.forEach { |
| | | if (it is AirData) { |
| | | 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() |
| | | |
| | | FactorType.LAT.value -> latitude = it.factorData?.toBigDecimal() |
| | | FactorType.LNG.value -> longitude = it.factorData?.toBigDecimal() |
| | | FactorType.TIME.value -> it.statusList?.takeIf { l -> l.isNotEmpty() }?.get(0)?.let { d -> |
| | | dataTime = SimpleDateFormat("yyyy-MM-dd HH:mm:ss").parse(d) |
| | | } |
| | | } |
| | | } |
| | | } |
| | | |
| | | // mapper?.insert(this) |
| | | return 1 |
| | | } |
| | | return 0 |
| | | return count |
| | | } |
| | | |
| | | override fun savePrepData(dataList: List<RealTimeData>): Int { |
| | |
| | | UWDeviceType.UAV -> { |
| | | val d = RealTimeDataUav() |
| | | dataTransform(vo, d) |
| | | realTimeDataUavMapper.insert(d) |
| | | count++ |
| | | } |
| | | UWDeviceType.GRID -> { |
| | | val d = RealTimeDataGrid() |
| | | dataTransform(vo, d) |
| | | realTimeDataGridMapper.insert(d) |
| | | count++ |
| | | } |
| | | } |
| | | } |
| | | return count |
| | | } |
| | | |
| | | override fun savePrepData2(dataList: List<DataVo>): Int { |
| | | var count = 0 |
| | | dataList.forEach {vo -> |
| | | when (UWDeviceType.getType(vo.deviceCode)) { |
| | | UWDeviceType.VEHICLE -> { |
| | | val d = RealTimeDataVehicle() |
| | | dataTransform(vo, d) |
| | | /***************************************************************************************************/ |
| | | // FIXME: 2021/10/27 车载监测部分因子量级调整:NO2*0.6,H2S*0.3, SO2*0.2, O3*0.5,其他要素不变 |
| | | d.no2 = d.no2?.times(0.6f) |
| | | d.h2s = d.h2s?.times(0.3f) |
| | | d.so2 = d.so2?.times(0.2f) |
| | | d.o3 = d.o3?.times(0.5f) |
| | | /***************************************************************************************************/ |
| | | realTimeDataVehicleMapper.insert(d) |
| | | count++ |
| | | } |
| | | UWDeviceType.UAV -> { |
| | | val d = RealTimeDataUav() |
| | | dataTransform(vo, d) |
| | | /***************************************************************************************************/ |
| | | // FIXME: 2021/10/25 无人机部分因子采用车载数据填充,取最新的15分钟的数据 |
| | | if (tmpVehicleDataList.isEmpty()) { |
| | | val p = PageHelper.startPage<RealTimeDataVehicle>(1, 225) |
| | | realTimeDataVehicleMapper.selectByExample(Example(RealTimeDataVehicle::class.java).apply { |
| | | orderBy("dataTime").desc() |
| | | }).let { tmpVehicleDataList.addAll(it) } |
| | | } |
| | | if (tmpVehicleDataList.isNotEmpty()) { |
| | | tmpVehicleDataList[0].let { |
| | | d.no2 = it.no2 |
| | | d.co = it.co |
| | | d.h2s = it.h2s |
| | | d.so2 = it.so2 |
| | | d.o3 = it.o3 |
| | | } |
| | | tmpVehicleDataList.removeFirst() |
| | | } |
| | | /***************************************************************************************************/ |
| | | realTimeDataUavMapper.insert(d) |
| | | count++ |
| | | } |
| | |
| | | |
| | | } |
| | | } |
| | | |
| | | private fun dataTransform(dataPackage: AirDataPackage, bean: BaseRealTimeData) { |
| | | bean.apply { |
| | | deviceCode = dataPackage.deviceCode |
| | | dataPackage.dataUnit.forEach { |
| | | if (it is AirData) { |
| | | 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() |
| | | |
| | | FactorType.LAT.value -> latitude = it.factorData?.toBigDecimal() |
| | | FactorType.LNG.value -> longitude = it.factorData?.toBigDecimal() |
| | | FactorType.TIME.value -> it.statusList?.takeIf { l -> l.isNotEmpty() }?.get(0)?.let { d -> |
| | | dataTime = SimpleDateFormat("yyyy-MM-dd HH:mm:ss").parse(d) |
| | | } |
| | | } |
| | | } |
| | | } |
| | | } |
| | | } |
| | | |
| | | private 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() |
| | | } |
| | | } |
| | | |
| | | } |
| | | } |
| | | } |