ingo@921: package de.intevation.flys.artifacts.states;
ingo@921:
ingo@1712: import java.util.Date;
ingo@921: import java.util.List;
ingo@921:
ingo@921: import org.apache.log4j.Logger;
ingo@921:
ingo@921: import org.w3c.dom.Element;
ingo@921:
ingo@921: import de.intevation.artifacts.Artifact;
ingo@921: import de.intevation.artifacts.CallContext;
ingo@921:
ingo@921: import de.intevation.artifacts.common.utils.XMLUtils;
ingo@921:
ingo@921: import de.intevation.artifactdatabase.ProtocolUtils;
ingo@921: import de.intevation.artifactdatabase.data.StateData;
ingo@921: import de.intevation.artifactdatabase.state.Facet;
ingo@921:
ingo@1712: import de.intevation.flys.model.DischargeTable;
ingo@1712: import de.intevation.flys.model.Gauge;
ingo@1712: import de.intevation.flys.model.TimeInterval;
ingo@921:
ingo@921: import de.intevation.flys.artifacts.FLYSArtifact;
ingo@921: import de.intevation.flys.artifacts.WINFOArtifact;
raimund@2132: import de.intevation.flys.artifacts.ChartArtifact;
raimund@2132:
ingo@921: import de.intevation.flys.artifacts.model.CalculationResult;
ingo@921: import de.intevation.flys.artifacts.model.FacetTypes;
ingo@1712: import de.intevation.flys.artifacts.model.GaugesFactory;
ingo@921: import de.intevation.flys.artifacts.model.WaterlevelFacet;
ingo@921: import de.intevation.flys.artifacts.model.WQKms;
ingo@921: import de.intevation.flys.artifacts.resources.Resources;
ingo@921:
felix@2235: import de.intevation.flys.utils.FLYSUtils;
felix@2235:
felix@2235:
ingo@921: /**
ingo@921: * @author Ingo Weinzierl
ingo@921: */
ingo@921: public class ComputationRangeState
ingo@921: extends RangeState
ingo@921: implements FacetTypes
ingo@921: {
ingo@921: private static Logger logger =
ingo@921: Logger.getLogger(ComputationRangeState.class);
ingo@921:
ingo@921: /** The name of the 'from' field. */
ingo@921: public static final String FROM = "ld_from";
ingo@921:
ingo@921: /** The name of the 'to' field. */
ingo@921: public static final String TO = "ld_to";
ingo@921:
ingo@921: /** The name of the 'step' field. */
ingo@921: public static final String STEP = "ld_step";
ingo@921:
felix@1685: /** The default step width. */
ingo@921: public static final int DEFAULT_STEP = 100;
ingo@921:
ingo@921:
ingo@921: public ComputationRangeState() {
ingo@921: }
ingo@921:
ingo@921:
ingo@921: @Override
ingo@921: protected Element createData(
ingo@921: XMLUtils.ElementCreator cr,
ingo@921: Artifact artifact,
ingo@921: StateData data,
ingo@921: CallContext context)
ingo@921: {
ingo@921: Element select = ProtocolUtils.createArtNode(
ingo@921: cr, "select", null, null);
ingo@921:
ingo@921: cr.addAttr(select, "name", data.getName(), true);
ingo@921:
ingo@921: Element label = ProtocolUtils.createArtNode(
ingo@921: cr, "label", null, null);
ingo@921:
ingo@921: Element choices = ProtocolUtils.createArtNode(
ingo@921: cr, "choices", null, null);
ingo@921:
ingo@921: label.setTextContent(Resources.getMsg(
ingo@921: context.getMeta(),
ingo@921: data.getName(),
ingo@921: data.getName()));
ingo@921:
ingo@921: select.appendChild(label);
ingo@921:
ingo@921: return select;
ingo@921: }
ingo@921:
ingo@921:
ingo@921: @Override
ingo@921: protected Element[] createItems(
ingo@921: XMLUtils.ElementCreator cr,
ingo@921: Artifact artifact,
ingo@921: String name,
ingo@921: CallContext context)
ingo@921: {
ingo@921: double[] minmax = getMinMax(artifact);
ingo@921:
ingo@921: double minVal = Double.MIN_VALUE;
ingo@921: double maxVal = Double.MAX_VALUE;
ingo@921:
ingo@921: if (minmax != null) {
ingo@921: minVal = minmax[0];
ingo@921: maxVal = minmax[1];
ingo@921: }
ingo@921: else {
ingo@921: logger.warn("Could not read min/max distance values!");
ingo@921: }
ingo@921:
ingo@921: if (name.equals("ld_from")) {
ingo@921: Element min = createItem(
ingo@921: cr,
ingo@921: new String[] {"min", new Double(minVal).toString()});
ingo@921:
ingo@921: return new Element[] { min };
ingo@921: }
ingo@921: else if (name.equals("ld_to")) {
ingo@921: Element max = createItem(
ingo@921: cr,
ingo@921: new String[] {"max", new Double(maxVal).toString()});
ingo@921:
ingo@921: return new Element[] { max };
ingo@921: }
ingo@921: else {
ingo@921: Element step = createItem(
ingo@921: cr,
ingo@921: new String[] {"step", String.valueOf(getDefaultStep())});
ingo@921: return new Element[] { step };
ingo@921: }
ingo@921:
ingo@921: }
ingo@921:
ingo@921:
ingo@921: protected Element createItem(XMLUtils.ElementCreator cr, Object obj) {
ingo@921: Element item = ProtocolUtils.createArtNode(cr, "item", null, null);
ingo@921: Element label = ProtocolUtils.createArtNode(cr, "label", null, null);
ingo@921: Element value = ProtocolUtils.createArtNode(cr, "value", null, null);
ingo@921:
ingo@921: String[] arr = (String[]) obj;
ingo@921:
ingo@921: label.setTextContent(arr[0]);
ingo@921: value.setTextContent(arr[1]);
ingo@921:
ingo@921: item.appendChild(label);
ingo@921: item.appendChild(value);
ingo@921:
ingo@921: return item;
ingo@921: }
ingo@921:
ingo@921:
ingo@921: @Override
ingo@921: public Object computeFeed(
ingo@921: FLYSArtifact artifact,
ingo@921: String hash,
ingo@921: CallContext context,
ingo@921: List facets,
ingo@921: Object old
ingo@921: ) {
ingo@921: logger.debug("computeFeed");
ingo@921:
raimund@2132: if (artifact instanceof ChartArtifact) {
raimund@2132: return null;
raimund@2132: }
ingo@921: WINFOArtifact winfo = (WINFOArtifact)artifact;
ingo@921:
ingo@921: CalculationResult res = old instanceof CalculationResult
ingo@921: ? (CalculationResult)old
ingo@921: : winfo.getDischargeCurveData();
ingo@921:
ingo@921: if (facets == null) {
ingo@921: logger.debug("generate no facets");
ingo@921: return res;
ingo@921: }
ingo@921:
ingo@921: WQKms [] wqkms = (WQKms [])res.getData();
ingo@921:
ingo@921: logger.debug("generate " + wqkms.length + " facets.");
ingo@921:
ingo@921: String stateID = winfo.getCurrentStateId();
ingo@921:
ingo@921: for (int i = 0; i < wqkms.length; ++i) {
ingo@1712: String name = getSeriesName(context, wqkms[i].getName());
ingo@921: facets.add(new WaterlevelFacet(
ingo@921: i, DISCHARGE_CURVE, name, ComputeType.FEED, stateID, hash));
ingo@921: }
ingo@921:
ingo@921:
ingo@921: return res;
ingo@921: }
ingo@921:
ingo@1712: protected String getSeriesName(CallContext cc, String gaugeName) {
ingo@1712: Gauge gauge = GaugesFactory.getGauge(gaugeName);
ingo@1712:
ingo@1712: if (gauge == null) {
ingo@1712: logger.warn("Cannot determine Gauge for name: " + gaugeName);
ingo@1712: return gaugeName;
ingo@1712: }
ingo@1712:
ingo@1712: List dts = gauge.getDischargeTables();
ingo@1712:
ingo@1712: for (DischargeTable dt: dts) {
ingo@1712: if (dt.getKind() == 0) {
ingo@1712: TimeInterval ti = dt.getTimeInterval();
ingo@1712:
ingo@1712: Date start = ti.getStartTime();
ingo@1712: Date end = ti.getStopTime();
ingo@1712:
ingo@1712: String name = gauge.getName();
ingo@1712:
ingo@1712: if (end == null) {
ingo@1712: Object[] args = new Object[] { name, start };
ingo@1712: return Resources.getMsg(
ingo@1712: cc.getMeta(),
ingo@1712: "chart.discharge.curve.curve.valid.from",
ingo@1712: "",
ingo@1712: args);
ingo@1712: }
ingo@1712: else {
ingo@1712: Object[] args = new Object[] { name, start, end };
ingo@1712: return Resources.getMsg(
ingo@1712: cc.getMeta(),
ingo@1712: "chart.discharge.curve.curve.valid.range",
ingo@1712: "",
ingo@1712: args);
ingo@1712: }
ingo@1712: }
ingo@1712: }
ingo@1712:
ingo@1712: return gauge.getName();
ingo@1712: }
ingo@1712:
ingo@921:
ingo@921: @Override
ingo@921: protected double[] getMinMax(Artifact artifact) {
ingo@921: FLYSArtifact flysArtifact = (FLYSArtifact) artifact;
felix@2235: return FLYSUtils.getRiverMinMax(flysArtifact);
ingo@921: }
ingo@921:
ingo@921:
ingo@921: protected double getDefaultStep() {
ingo@921: return DEFAULT_STEP;
ingo@921: }
ingo@921:
ingo@921:
ingo@921: @Override
ingo@921: protected String getLowerField() {
ingo@921: return FROM;
ingo@921: }
ingo@921:
ingo@921:
ingo@921: @Override
ingo@921: protected String getUpperField() {
ingo@921: return TO;
ingo@921: }
ingo@921:
ingo@921:
ingo@921: @Override
ingo@921: protected String getStepField() {
ingo@921: return STEP;
ingo@921: }
ingo@921: }
ingo@921: // vim:set ts=4 sw=4 si et sta sts=4 fenc=utf-8 :