Mercurial > dive4elements > river
view artifacts/src/main/java/org/dive4elements/river/artifacts/bundu/bezugswst/BezugswstMissVolCalculationResult2.java @ 9598:17414e70746e
Softwaretests...20181219 10.1/10.2/10.5/10.9: corrected computation of missing volume and excavation volume, date range for density queries as in Sinfo/Tkh, empty values instead of 0 if computation not possible
author | mschaefer |
---|---|
date | Tue, 05 Feb 2019 15:51:35 +0100 |
parents | 4deb6b24f072 |
children |
line wrap: on
line source
/** Copyright (C) 2017 by Bundesanstalt für Gewässerkunde * Software engineering by * Björnsen Beratende Ingenieure GmbH * Dr. Schumacher Ingenieurbüro für Wasser und Umwelt * * This file is Free Software under the GNU AGPL (>=v3) * and comes with ABSOLUTELY NO WARRANTY! Check out the * documentation coming with Dive4Elements River for details. */ package org.dive4elements.river.artifacts.bundu.bezugswst; import java.util.ArrayList; import java.util.Collection; import java.util.List; import org.dive4elements.river.artifacts.bundu.BunduResultType; import org.dive4elements.river.artifacts.common.AbstractCalculationExportableResult; import org.dive4elements.river.artifacts.common.AbstractExportContext; import org.dive4elements.river.artifacts.common.ExportContextCSV; import org.dive4elements.river.artifacts.common.ExportContextPDF; import org.dive4elements.river.artifacts.common.GeneralResultType; import org.dive4elements.river.artifacts.common.MetaAndTableJRDataSource; import org.dive4elements.river.artifacts.common.ResultRow; import org.dive4elements.river.artifacts.sinfo.util.RiverInfo; import org.dive4elements.river.model.BedHeightValueType; /** * Contains the results of a //TODO LINK{@link BezugswstCalculation}. * * @author Gernot Belger */ final class BezugswstMissVolCalculationResult2 extends AbstractCalculationExportableResult implements BunduWstExporter.MissResultType { private static final long serialVersionUID = 1L; private static final String fieldBedheightMsgKey = "bundu.export.bezugswst.csv.meta.miss.bedheight.field"; private static final String fieldFlowdepthMsgKey = "bundu.export.bezugswst.csv.meta.miss.flowdepth.field"; private static final String fieldVolumeMsgKey = "bundu.export.bezugswst.csv.meta.miss.volume.field"; private static final String fieldMassMsgKey = "bundu.export.bezugswst.csv.meta.miss.mass.field"; public BezugswstMissVolCalculationResult2(final String label, final Collection<ResultRow> rows) { super(label, rows); } @Override protected boolean pdfExportEnabled() { return false; } @Override protected void writeCSVResultMetadata(final ExportContextCSV exportContextCSV) { // no metadata } @Override protected String getJasperFile() { throw new UnsupportedOperationException(); } protected String[] formatRow(final AbstractExportContext exportContext, final ResultRow row) { final Collection<String> lines = new ArrayList<>(44); lines.add(exportContext.formatRowValue(row, GeneralResultType.station)); @SuppressWarnings("unchecked") final List<Double> vFields = (List<Double>) row.getValue(BunduResultType.missVolumeFields); assert (vFields.size() == fieldSize()); // immer abgleichen mit der Calculation! @SuppressWarnings("unchecked") final List<Double> mFields = (List<Double>) row.getValue(BunduResultType.missMassFields); assert (vFields.size() == mFields.size()); @SuppressWarnings("unchecked") final List<Double> hFields = (List<Double>) row.getValue(BunduResultType.bedHeightFields); @SuppressWarnings("unchecked") final List<Double> dFields = (List<Double>) row.getValue(BunduResultType.depthFields); for (int i = 0; i < vFields.size(); i++) { lines.add(BunduResultType.bedHeightFields.exportValue(exportContext.getContext(), hFields.get(i))); lines.add(BunduResultType.depthFields.exportValue(exportContext.getContext(), dFields.get(i))); lines.add(BunduResultType.missVolumeFields.exportValue(exportContext.getContext(), vFields.get(i))); lines.add(BunduResultType.missMassFields.exportValue(exportContext.getContext(), mFields.get(i))); } lines.add(exportContext.formatRowValue(row, BunduResultType.heightMeanBed)); lines.add(exportContext.formatRowValue(row, BunduResultType.flowdepthMeanBed)); lines.add(exportContext.formatRowValue(row, BunduResultType.missVolumeMeanBed)); lines.add(exportContext.formatRowValue(row, BunduResultType.missMassMeanBed)); return lines.toArray(new String[lines.size()]); } @Override public void writeCSVHeader(final ExportContextCSV exportContextCSV, final RiverInfo river) { final int colSize = 4 * fieldSize() + 3; exportContextCSV.writeTitleForTabs("bundu.export.csv.title.bezugswst.result2", colSize); // Voraussetzung für Tabs ist, dass der Titel vor den Headern final Collection<String> header = new ArrayList<>(colSize); header.add(exportContextCSV.formatCsvHeader(GeneralResultType.station)); for (int i = 1, j = 1; i <= fieldSize() * 4; i += 4, j++) { header.add(exportContextCSV.msg(fieldBedheightMsgKey, j) + " [" + river.getWstUnit() + "]"); header.add(exportContextCSV.msg(fieldFlowdepthMsgKey, j)); header.add(exportContextCSV.msg(fieldVolumeMsgKey, j)); header.add(exportContextCSV.msg(fieldMassMsgKey, j)); } header.add(exportContextCSV.formatCsvHeader(BunduResultType.heightMeanBed) + " [" + river.getWstUnit() + "]"); header.add(exportContextCSV.formatCsvHeader(BunduResultType.flowdepthMeanBed)); header.add(exportContextCSV.formatCsvHeader(BunduResultType.missVolumeMeanBed)); header.add(exportContextCSV.formatCsvHeader(BunduResultType.missMassMeanBed)); exportContextCSV.writeCSVLine(header.toArray(new String[header.size()])); } /** * Number of elements of the various field lists */ private int fieldSize() { return BedHeightValueType.FIELD_LAST_INDEX - BedHeightValueType.FIELD_FIRST_INDEX + 1; } @Override protected String[] formatCSVRow(final ExportContextCSV exportContextCSV, final ResultRow row) { return this.formatRow(exportContextCSV, row); } @Override protected String[] formatPDFRow(final ExportContextPDF exportContextPDF, final ResultRow row) { throw new UnsupportedOperationException(); } @Override protected void addJRTableHeader(final ExportContextPDF exportContext, final MetaAndTableJRDataSource source) { throw new UnsupportedOperationException(); } }