comparison artifacts/src/main/java/org/dive4elements/river/artifacts/sinfo/collision/CollisionArtifact.java @ 9125:820ae41c81b6

Fixed adding missing files for the river bed collision counts selectable in the datacage
author mschaefer
date Wed, 06 Jun 2018 08:02:55 +0200
parents
children f9bb5d0a6ff3
comparison
equal deleted inserted replaced
9124:3f619f8dfa8e 9125:820ae41c81b6
1 /** Copyright (C) 2017 by Bundesanstalt für Gewässerkunde
2 * Software engineering by
3 * Björnsen Beratende Ingenieure GmbH
4 * Dr. Schumacher Ingenieurbüro für Wasser und Umwelt
5 *
6 * This file is Free Software under the GNU AGPL (>=v3)
7 * and comes with ABSOLUTELY NO WARRANTY! Check out the
8 * documentation coming with Dive4Elements River for details.
9 */
10
11 package org.dive4elements.river.artifacts.sinfo.collision;
12
13 import java.util.ArrayList;
14 import java.util.List;
15
16 import org.apache.log4j.Logger;
17 import org.dive4elements.artifactdatabase.state.DefaultOutput;
18 import org.dive4elements.artifactdatabase.state.Facet;
19 import org.dive4elements.artifactdatabase.state.FacetActivity;
20 import org.dive4elements.artifacts.Artifact;
21 import org.dive4elements.artifacts.ArtifactFactory;
22 import org.dive4elements.artifacts.CallMeta;
23 import org.dive4elements.artifacts.common.utils.XMLUtils;
24 import org.dive4elements.river.artifacts.AbstractStaticStateArtifact;
25 import org.dive4elements.river.artifacts.D4EArtifact;
26 import org.dive4elements.river.artifacts.model.FacetTypes;
27 import org.dive4elements.river.artifacts.sinfo.common.CollisionCountProcessor;
28 import org.dive4elements.river.artifacts.states.StaticState;
29 import org.w3c.dom.Document;
30
31 /**
32 * Display of a river bed collision data series loaded from database
33 *
34 * @author Matthias Schäfer
35 *
36 */
37 public class CollisionArtifact extends AbstractStaticStateArtifact implements FacetTypes {
38
39 /** The log for this class. */
40 private static Logger log = Logger.getLogger(CollisionArtifact.class);
41
42 /** Artifact name. */
43 private static final String NAME = "collision";
44
45 static {
46 // TODO: Move to configuration.
47 FacetActivity.Registry.getInstance().register(NAME, FacetActivity.INACTIVE);
48 }
49
50 public static final String STATIC_STATE_NAME = "state.collision.static";
51
52 /**
53 * Trivial Constructor.
54 */
55 public CollisionArtifact() {
56 log.debug("new CollisionArtifact");
57 }
58
59 @Override
60 public String getName() {
61 return NAME;
62 }
63
64 /**
65 * Gets called from factory, to set things up.
66 */
67 @Override
68 public void setup(final String identifier, final ArtifactFactory factory, final Object context, final CallMeta callMeta, final Document data,
69 final List<Class> loadFacets) {
70
71 log.debug("CollisionArtifact.setup");
72
73 if (log.isDebugEnabled()) {
74 log.debug(XMLUtils.toString(data));
75 }
76
77 final String code = getDatacageIDValue(data);
78 final String[] parts = code.split("-");
79 if (parts.length >= 2)
80 addStringData("collision_id", parts[1]);
81 if (parts.length >= 3)
82 addStringData("year", parts[2]);
83 else
84 addStringData("year", "jahr?");
85 String seriesName;
86 if (parts.length >= 4)
87 seriesName = parts[3];
88 else
89 seriesName = "name?";
90
91 createFacets(callMeta, code, seriesName, getDataAsString("year"));
92
93 super.setup(identifier, factory, context, callMeta, data, loadFacets);
94 }
95
96 private void createFacets(final CallMeta callMeta, final String code, final String seriesName, final String year) {
97 if (code == null)
98 return;
99 final String[] parts = code.split("-");
100 if (parts.length < 2) {
101 log.error("Invalid datacage ID '" + code + "'");
102 return;
103 }
104 final ArrayList<Facet> facets = new ArrayList<>(2);
105 facets.add(CollisionCountProcessor.createFacet(callMeta, year));
106 // facets.add(CollisionGaugeWProcessor.createFacet(callMeta, seriesName)); //REMARK gauge_w is the cm above gauge datum,
107 // therefore only useful with transformation to NHN
108 addFacets(STATIC_STATE_NAME, facets);
109 }
110
111 @Override
112 protected void initStaticState() {
113
114 log.debug("initStaticState " + getName() + " " + identifier());
115
116 final StaticState state = new StaticState(STATIC_STATE_NAME);
117 final DefaultOutput output = new DefaultOutput("general", "general", "image/png", "chart");
118
119 final List<Facet> facets = getFacets(STATIC_STATE_NAME);
120 output.addFacets(facets);
121 state.addOutput(output);
122
123 setStaticState(state);
124 }
125
126 @Override
127 protected void initialize(final Artifact artifact, final Object context, final CallMeta meta) {
128 // do not clone facets, etc. from master artifact
129
130 log.debug("initialize");
131 importData((D4EArtifact) artifact, "river");
132 importData((D4EArtifact) artifact, "ld_from");
133 importData((D4EArtifact) artifact, "ld_to");
134
135 log.debug("ld_from " + getDataAsString("ld_from"));
136 log.debug("ld_to " + getDataAsString("ld_to"));
137 }
138 }

http://dive4elements.wald.intevation.org