package com.moral.api.service.impl; import com.fasterxml.jackson.databind.ObjectMapper; import com.moral.api.entity.HistorySecondRadar; import com.moral.api.mapper.HistorySecondRadarMapper; import com.moral.api.pojo.query.radar.RadarListCond; import com.moral.api.pojo.vo.radar.HistorySecondRadarListVo; import com.moral.api.pojo.vo.radar.RadarListVo; import com.moral.api.service.HistorySecondRadarService; import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl; import org.springframework.stereotype.Service; import java.math.BigDecimal; import java.math.RoundingMode; import java.util.ArrayList; import java.util.List; /** *

* 服务实现类 *

* * @author moral * @since 2026-05-14 */ @Service public class HistorySecondRadarServiceImpl extends ServiceImpl implements HistorySecondRadarService { private static final ObjectMapper OBJECT_MAPPER = new ObjectMapper(); private static final double HEIGHT_INTERVAL = 7.5; @Override public RadarListVo radarList(RadarListCond cond) { RadarListVo radarListVo = new RadarListVo(); List time = new ArrayList<>(); List list = this.baseMapper.listRadar(cond); List> pm25 = new ArrayList<>(); List> pm10 = new ArrayList<>(); for(HistorySecondRadarListVo ot : list){ pm10.add(convertSingleRecordToJson(ot.getRadarDataPm10(),cond.getHigh1(),cond.getHigh2())); pm25.add(convertSingleRecordToJson(ot.getRadarDataPm25(),cond.getHigh1(),cond.getHigh2())); time.add(ot.getTimeStr()); } radarListVo.setPm25(pm25); radarListVo.setTime(time); radarListVo.setPm10(pm10); return radarListVo; } private List convertSingleRecordToJson(String rawData,int high1,int high2){ if (rawData == null || rawData.isEmpty()) { return new ArrayList<>(); } try { // 3. 分割字符串 String[] valuesStr = rawData.split("\\*"); // 4. 预分配列表大小,假设约2000个数据,减少扩容 List seriesData = new ArrayList<>(valuesStr.length); for (int i = 10; i < valuesStr.length; i++) { // 简单的空值检查,避免 NumberFormatException if (valuesStr[i].isEmpty()) continue; double height = (i + 1) * HEIGHT_INTERVAL; if(height> high1 && height < high2){ double pm25Value = Double.parseDouble(valuesStr[i]); pm25Value = new BigDecimal(Double.toString(pm25Value)) .setScale(1, RoundingMode.HALF_UP) .doubleValue(); // 使用 double 数组存储 [浓度, 高度],比对象更节省内存 seriesData.add(new double[]{pm25Value, height}); } } // 5. 序列化为 JSON return seriesData; } catch (Exception e) { // 生产环境中建议记录日志,而不是打印堆栈 System.err.println("处理数据出错: " + e.getMessage()); return new ArrayList<>(); } } }