From 8b9087bf29053274c77a0e63e4a04f58a5f5bb6b Mon Sep 17 00:00:00 2001 From: 潘志宝 <979469083@qq.com> Date: 星期二, 24 六月 2025 10:25:52 +0800 Subject: [PATCH] 修正计划 --- ansteel-biz/src/main/java/com/iailab/module/ansteel/api/service/impl/DataServiceImpl.java | 81 ++++++++++++++++++++++++++++++++++++---- 1 files changed, 72 insertions(+), 9 deletions(-) diff --git a/ansteel-biz/src/main/java/com/iailab/module/ansteel/api/service/impl/DataServiceImpl.java b/ansteel-biz/src/main/java/com/iailab/module/ansteel/api/service/impl/DataServiceImpl.java index 9328b6b..1caa5cc 100644 --- a/ansteel-biz/src/main/java/com/iailab/module/ansteel/api/service/impl/DataServiceImpl.java +++ b/ansteel-biz/src/main/java/com/iailab/module/ansteel/api/service/impl/DataServiceImpl.java @@ -175,20 +175,36 @@ if (predictItem == null || predictItem.getLastTime() == null) { return null; } + String timeFormat = StringUtils.isBlank(reqVO.getTimeFormat()) ? DateUtils.FORMAT_YEAR_MONTH_DAY_HOUR_MINUTE_SECOND : reqVO.getTimeFormat(); int lengthLeft = tMap.get(CommonConstant.LENGTH_LEFT) == null ? predictItem.getPredictLength() : new BigDecimal(tMap.get(CommonConstant.LENGTH_LEFT)).intValue(); int lengthRight = tMap.get(CommonConstant.LENGTH_RIGHT) == null ? predictItem.getPredictLength() : new BigDecimal(tMap.get(CommonConstant.LENGTH_RIGHT)).intValue(); String trendsDataH = tMap.get(CommonConstant.TRENDSDATA_H) == null ? null : tMap.get(CommonConstant.TRENDSDATA_H); String trendsDataL = tMap.get(CommonConstant.TRENDSDATA_L) == null ? null : tMap.get(CommonConstant.TRENDSDATA_L); String culIndex = tMap.get(CommonConstant.CUL_INDEX) == null ? null : tMap.get(CommonConstant.CUL_INDEX);//累计量 + String lineType = tMap.get(CommonConstant.LINE_TYPE) == null ? null : tMap.get(CommonConstant.LINE_TYPE); Date[] timeArray = calResultTime(predictItem, reqVO.getStartTime(), reqVO.getEndTime(), lengthLeft, lengthRight); Date startTime = timeArray[1]; Date endTime = timeArray[2]; + /*String timeFormat = null; + if (StringUtils.isNotBlank(reqVO.getTimeFormat())) { + timeFormat = reqVO.getTimeFormat(); + } else if ((endTime.getTime() - startTime.getTime()) < 1000 * 60 * 60 * 24 ) { + // 时间范围短,默认使用短时间格式 "HH:mm" + timeFormat = DateUtils.FORMAT_SIMPLE_TIME; + } else { + timeFormat = DateUtils.FORMAT_YEAR_MONTH_DAY_HOUR_MINUTE_SECOND; + }*/ + final String finalTimeFormat = timeFormat; + // reqVO.setTimeFormat(finalTimeFormat); PreDataSingleChartRespVO resultOld = mcsApi.getPreDataSingleChart(reqVO); PreDataChartRespVO result = ConvertUtils.sourceToTarget(resultOld, PreDataChartRespVO.class); + //result.setPredictTime(DateUtils.format(resultOld.getPredictTime(), finalTimeFormat)); PreDataViewDTO preDataView = ConvertUtils.sourceToTarget(resultOld.getDataView(), PreDataViewDTO.class); + //preDataView.setPredictTime(DateUtils.format(resultOld.getDataView().getPredictTime(), finalTimeFormat)); + if (StringUtils.isNotBlank(trendsDataH)) { // 动态上限 ApiPointValueQueryDTO pointValueQueryDTO = new ApiPointValueQueryDTO(); @@ -199,7 +215,7 @@ List<Object[]> newList = new ArrayList<>(); trendsDataHList.forEach(item -> { Object[] dataItem = new Object[2]; - dataItem[0] = item.getT(); + dataItem[0] = DateUtils.format(item.getT(), finalTimeFormat); dataItem[1] = item.getV(); newList.add(dataItem); }); @@ -215,7 +231,7 @@ List<Object[]> newList = new ArrayList<>(); trendsDataLList.forEach(item -> { Object[] dataItem = new Object[2]; - dataItem[0] = item.getT(); + dataItem[0] = DateUtils.format(item.getT(), finalTimeFormat); dataItem[1] = item.getV(); newList.add(dataItem); }); @@ -235,7 +251,16 @@ } } preDataView.setCulData(culData); - preDataView.setPreData(resultOld.getDataView().getPreDataL()); + switch (lineType) { + case "0": + preDataView.setPreData(resultOld.getDataView().getPreDataN()); + break; + case "1": + preDataView.setPreData(resultOld.getDataView().getPreDataL()); + break; + default: + break; + } result.setPreDataView(preDataView); return result; } @@ -299,7 +324,7 @@ // 修正计划数据 LinkedHashMap<String, List<String[]>> predData = new LinkedHashMap<>(); for (int i = 0; i < reqVO.getPlanCodes().size(); i++) { - predData.put(reqVO.getPlanCodes().get(i), getPrePlanData(reqVO.getPlanPreds().get(i), predictTime, endTime)); + predData.put(reqVO.getPlanCodes().get(i), getPrePlanData(reqVO.getPlanPreds().get(i), startTime, endTime, predictTime)); } result.put("planData", planData); result.put("predData", predData); @@ -341,25 +366,61 @@ } //修正计划 - public List<String[]> getPrePlanData(String charCode, Date startTime, Date endTime) { + public List<String[]> getPrePlanData(String charCode, Date startTime, Date endTime, Date predictTime) { List<String[]> result = new ArrayList<>(); PreDataSingleChartReqVO queryDto = new PreDataSingleChartReqVO(); queryDto.setChartCode(charCode); queryDto.setStartTime(startTime); queryDto.setEndTime(endTime); PreDataSingleChartRespVO chartData = mcsApi.getPreDataSingleChart(queryDto); - if (CollectionUtils.isEmpty(chartData.getDataView().getPreDataN())) { + if (CollectionUtils.isEmpty(chartData.getDataView().getCurData())) { return result; + } + String lineType = chartData.getDataView().getLineType(); + List<Object[]> preData = new ArrayList<>(); + if ("1".equals(lineType)) { + // 两部分组成,左侧T+L,右侧当前 + if(!CollectionUtils.isEmpty(chartData.getDataView().getPreDataL())) { + for (int i = 0; i < chartData.getDataView().getPreDataL().size(); i++) { + Object[] dataItem = chartData.getDataView().getPreDataL().get(i); + Date t = DateUtils.parse(dataItem[0].toString(), DateUtils.FORMAT_YEAR_MONTH_DAY_HOUR_MINUTE_SECOND); + if (t.getTime() <= predictTime.getTime()) { + preData.add(dataItem); + } + } + } + if(!CollectionUtils.isEmpty(chartData.getDataView().getCurData())) { + for (int i = 0; i < chartData.getDataView().getCurData().size(); i++) { + Object[] dataItem = chartData.getDataView().getCurData().get(i); + preData.add(dataItem); + } + } + } else if ("2".equals(lineType)) { + // 展示T+N + if(!CollectionUtils.isEmpty(chartData.getDataView().getPreDataN())) { + for (int i = 0; i < chartData.getDataView().getPreDataN().size(); i++) { + Object[] dataItem = chartData.getDataView().getPreDataN().get(i); + preData.add(dataItem); + } + } + } else { + // 展示当前值 + if(!CollectionUtils.isEmpty(chartData.getDataView().getCurData())) { + for (int i = 0; i < chartData.getDataView().getCurData().size(); i++) { + Object[] dataItem = chartData.getDataView().getCurData().get(i); + preData.add(dataItem); + } + } } double lastValue = 0; - for (int i = 0; i < chartData.getDataView().getPreDataN().size(); i++) { - Object[] dataItem = chartData.getDataView().getPreDataN().get(i); + for (int i = 0; i < preData.size(); i++) { + Object[] dataItem = preData.get(i); double cv = new BigDecimal(dataItem[1].toString()).doubleValue(); if (cv == 1 && cv != lastValue) { String[] sa = new String[3]; sa[0] = (String) dataItem[0]; - sa[1] = getEndTime(chartData.getDataView().getPreDataN(), i); + sa[1] = getEndTime(preData, i); sa[2] = "2"; result.add(sa); } @@ -468,6 +529,8 @@ @Override public List<PreDataViewSimpleDTO> getPreDataByOutIds(PreDataBarLineReqVO reqVO) { PreDataBarLineRespVO preDataBarLineRespVO = mcsApi.getPreDataCharts(reqVO); + String predictTime = DateUtils.format(preDataBarLineRespVO.getPredictTime(), DateUtils.FORMAT_YEAR_MONTH_DAY_HOUR_MINUTE_SECOND); + List<PreDataViewSimpleDTO> preDataViewSimpleDTOList = new ArrayList<>(); preDataBarLineRespVO.getDataViewList().forEach(item -> { PreDataViewSimpleDTO preDataViewSimpleDTO = new PreDataViewSimpleDTO(); -- Gitblit v1.9.3