Mercurial > dive4elements > river
view flys-artifacts/src/main/java/de/intevation/flys/artifacts/access/BedHeightAccess.java @ 3743:51f76225823b
Extreme waterlevels: calculate the segments for Q km ranges.
flys-artifacts/trunk@5426 c6561f87-3c4e-4783-a992-168aeb5c3f6f
author | Sascha L. Teichmann <sascha.teichmann@intevation.de> |
---|---|
date | Mon, 10 Sep 2012 15:59:34 +0000 |
parents | 68beaa827751 |
children | 0f60efc39953 |
line wrap: on
line source
package de.intevation.flys.artifacts.access; import gnu.trove.TIntArrayList; import org.apache.log4j.Logger; import de.intevation.flys.artifacts.FLYSArtifact; import de.intevation.flys.artifacts.states.SoundingsSelect; public class BedHeightAccess extends Access { private static final Logger logger = Logger.getLogger(BedHeightAccess.class); private int[] singleIDs; private int[] epochIDs; private Double lowerKM; private Double upperKM; private String time; public BedHeightAccess(FLYSArtifact artifact) { super(artifact); } public Double getLowerKM() { if (lowerKM == null) { lowerKM = getDouble("ld_from"); } return lowerKM; } public Double getUpperKM() { if (upperKM == null) { upperKM = getDouble("ld_to"); } return upperKM; } public int[] getBedHeightSingleIDs() { if (singleIDs == null) { String data = getString("soundings"); if (data == null) { logger.warn("No 'soundings' parameter specified!"); return null; } String[] parts = data.split(";"); TIntArrayList ids = new TIntArrayList(); for (String part: parts) { if (part.indexOf(SoundingsSelect.PREFIX_SINGLE) >= 0) { String tmp = part.replace(SoundingsSelect.PREFIX_SINGLE, ""); try { ids.add(Integer.parseInt(tmp)); } catch (NumberFormatException nfe) { logger.warn("Cannot parse int from string: '" + tmp + "'"); } } } singleIDs = ids.toNativeArray(); } return singleIDs; } public String getYearEpoch() { if (time == null) { time = getString("ye_select"); } return time; } public int[] getBedHeightEpochIDs() { if (epochIDs == null) { String data = getString("soundings"); if (data == null) { logger.warn("No 'soundings' parameter specified!"); return null; } String[] parts = data.split(";"); TIntArrayList ids = new TIntArrayList(); for (String part: parts) { if (part.indexOf(SoundingsSelect.PREFIX_EPOCH) >= 0) { String tmp = part.replace(SoundingsSelect.PREFIX_EPOCH, ""); try { ids.add(Integer.parseInt(tmp)); } catch (NumberFormatException nfe) { logger.warn("Cannot parse int from string: '" + tmp + "'"); } } } epochIDs = ids.toNativeArray(); } return epochIDs; } } // vim:set ts=4 sw=4 si et sta sts=4 fenc=utf8 :