Mercurial > dive4elements > river
diff artifacts/src/main/java/org/dive4elements/river/artifacts/sinfo/flood_duration/FloodDurationProcessor.java @ 9229:0dcd1cd41915
Different themes/facets for left bank and right bank infrastructures in S-Info flood durations, some fixmes done
author | mschaefer |
---|---|
date | Thu, 05 Jul 2018 16:49:42 +0200 |
parents | 0fc9c82e744e |
children | e5367900dd6d |
line wrap: on
line diff
--- a/artifacts/src/main/java/org/dive4elements/river/artifacts/sinfo/flood_duration/FloodDurationProcessor.java Thu Jul 05 13:46:36 2018 +0200 +++ b/artifacts/src/main/java/org/dive4elements/river/artifacts/sinfo/flood_duration/FloodDurationProcessor.java Thu Jul 05 16:49:42 2018 +0200 @@ -19,10 +19,12 @@ import org.dive4elements.river.artifacts.common.AbstractCalculationResult; import org.dive4elements.river.artifacts.resources.Resources; import org.dive4elements.river.artifacts.sinfo.common.AbstractSInfoProcessor; +import org.dive4elements.river.artifacts.sinfo.common.SInfoResultFacet; import org.dive4elements.river.artifacts.sinfo.common.SInfoResultType; import org.dive4elements.river.artifacts.sinfo.flood_duration.FloodDurationCalculationResult.ValueGetter; import org.dive4elements.river.artifacts.states.DefaultState.ComputeType; import org.dive4elements.river.exports.DiagramGenerator; +import org.dive4elements.river.model.Attribute.AttributeKey; import org.dive4elements.river.themes.ThemeDocument; /** @@ -33,7 +35,9 @@ */ public final class FloodDurationProcessor extends AbstractSInfoProcessor { - private static final String FACET_FLOOD_DURATION = "sinfo_facet_flood_duration"; + private static final String FACET_FLOOD_DURATION_LEFT = "sinfo_facet_flood_duration.left"; + + private static final String FACET_FLOOD_DURATION_RIGHT = "sinfo_facet_flood_duration.right"; private static final String FACET_FLOOD_DURATION_DESCRIPTION = "sinfo_facet_flood_duration.description"; @@ -46,9 +50,9 @@ private static final Set<String> HANDLED_FACET_TYPES = new HashSet<>(); static { - HANDLED_FACET_TYPES.add(FACET_FLOOD_DURATION); + HANDLED_FACET_TYPES.add(FACET_FLOOD_DURATION_LEFT); + HANDLED_FACET_TYPES.add(FACET_FLOOD_DURATION_RIGHT); HANDLED_FACET_TYPES.add(FACET_MAIN_VALUE_DURATION); - } public FloodDurationProcessor() { @@ -56,10 +60,18 @@ } public static Facet createFloodDurationFacet(final CallContext context, final String hash, final String id, final AbstractCalculationResult result, - final int resultIndex) { + final int facetIndex, final int resultIndex) { - return AbstractSInfoProcessor.createFacet(context, hash, id, result, resultIndex, I18N_AXIS_LABEL, FACET_FLOOD_DURATION, - FACET_FLOOD_DURATION_DESCRIPTION); + if (facetIndex == 0) { + final String description = Resources.getMsg(context.getMeta(), FACET_FLOOD_DURATION_DESCRIPTION, FACET_FLOOD_DURATION_DESCRIPTION, + SInfoResultType.localizeRiverside(context, AttributeKey.LEFT)); + return new SInfoResultFacet(facetIndex, resultIndex, FACET_FLOOD_DURATION_LEFT, description, I18N_AXIS_LABEL, ComputeType.ADVANCE, id, hash); + } + else { + final String description = Resources.getMsg(context.getMeta(), FACET_FLOOD_DURATION_DESCRIPTION, FACET_FLOOD_DURATION_DESCRIPTION, + SInfoResultType.localizeRiverside(context, AttributeKey.RIGHT)); + return new SInfoResultFacet(facetIndex, resultIndex, FACET_FLOOD_DURATION_RIGHT, description, I18N_AXIS_LABEL, ComputeType.ADVANCE, id, hash); + } } public static Facet createMainValueDurationFacet(final CallContext context, final String hash, final String id, final FloodDurationCalculationResult result, @@ -74,10 +86,15 @@ @Override protected String generateSeries(final DiagramGenerator generator, final ArtifactAndFacet bundle, final ThemeDocument theme, final boolean visible) { + final String facetName = bundle.getFacetName(); - if (FACET_FLOOD_DURATION.contentEquals(facetName)) - return buildSeriesForType(generator, bundle, theme, visible, SInfoResultType.floodDuration, null); + if (FACET_FLOOD_DURATION_LEFT.contentEquals(facetName)) { + return buildInfrastructureSeries(generator, bundle, theme, visible, AttributeKey.LEFT); + } + + if (FACET_FLOOD_DURATION_RIGHT.contentEquals(facetName)) + return buildInfrastructureSeries(generator, bundle, theme, visible, AttributeKey.RIGHT); if (FACET_MAIN_VALUE_DURATION.contentEquals(facetName)) { @@ -94,11 +111,21 @@ } }; final double[][] points = ((FloodDurationCalculationResult) data).getMainValueDurationPoints(generator, valuegetter, index); - return buildSeriesForType(points, generator, bundle, theme, visible, null); + return buildStepLineSeriesForType(points, generator, bundle, theme, visible); } } final String error = String.format("Unknown facet name: %s", facetName); throw new UnsupportedOperationException(error); } + + private String buildInfrastructureSeries(final DiagramGenerator generator, final ArtifactAndFacet bundle, final ThemeDocument theme, final boolean visible, + final AttributeKey riverside) { + + final FloodDurationCalculationResult data = (FloodDurationCalculationResult) getResult(generator, bundle); + + final double[][] points = data.getInfrastructurePoints(SInfoResultType.floodDuration, riverside); + + return buildSeriesForType(points, generator, bundle, theme, visible, null); + } } \ No newline at end of file