Mercurial > dive4elements > river
comparison flys-artifacts/src/main/java/de/intevation/flys/artifacts/states/WaterlevelState.java @ 704:eab5e5089d77
Merged revisions 2127-2133,2136-2137,2140,2143-2144,2146,2150-2151,2153-2154 via svnmerge from
svn+ssh://teichmann@thoe/home/projects/Geospatial/bsh-generischer-viewer/Material/SVN/flys-artifacts/branches/facets-slt
........
r2127 | ingo | 2011-06-16 09:50:56 +0200 (Do, 16 Jun 2011) | 1 line
Added a compute() method to WINFOArtifact which acts as a dispatcher for different computations. It triggers a calculation based on ComputeCallbacks that are generated by the current states.
........
r2128 | ingo | 2011-06-16 10:25:06 +0200 (Do, 16 Jun 2011) | 1 line
Moved Waterlevel state into the correct package.
........
r2129 | ingo | 2011-06-16 10:43:58 +0200 (Do, 16 Jun 2011) | 1 line
Added two more compute() methods to ComputeCallback to distinguish between different phases of the artifact.
........
r2130 | ingo | 2011-06-16 10:57:05 +0200 (Do, 16 Jun 2011) | 1 line
Use enums to dispatch computeFeed() and computeAdvance().
........
r2131 | ingo | 2011-06-16 11:04:59 +0200 (Do, 16 Jun 2011) | 1 line
Store facets for each state.
........
r2132 | ingo | 2011-06-16 12:05:44 +0200 (Do, 16 Jun 2011) | 1 line
Generated facets for each output aspect.
........
r2133 | ingo | 2011-06-16 15:24:00 +0200 (Do, 16 Jun 2011) | 1 line
Write computed facets into artifacts describe document.
........
r2136 | ingo | 2011-06-16 16:10:49 +0200 (Do, 16 Jun 2011) | 1 line
Add index and description of facets to collections describe document.
........
r2137 | ingo | 2011-06-16 16:31:41 +0200 (Do, 16 Jun 2011) | 1 line
OutGenerators doOut() takes a facet object now instead of just its name.
........
r2140 | ingo | 2011-06-17 11:19:43 +0200 (Fr, 17 Jun 2011) | 1 line
OutGenerators use now facets to fetch necessary data.
........
r2143 | teichmann | 2011-06-17 12:40:54 +0200 (Fr, 17 Jun 2011) | 1 line
Removed ComputeCallback because this was thought too complicated. Fixed issue with facets not be re-generated if same state is entered again.
........
r2144 | teichmann | 2011-06-17 13:08:31 +0200 (Fr, 17 Jun 2011) | 1 line
make getGauges() more robust
........
r2146 | teichmann | 2011-06-17 13:23:57 +0200 (Fr, 17 Jun 2011) | 1 line
mico opt: inter cmps are faster than str cmps.
........
r2150 | teichmann | 2011-06-17 15:10:20 +0200 (Fr, 17 Jun 2011) | 1 line
call computeAdvance() if we want to advance.
........
r2151 | teichmann | 2011-06-17 15:45:50 +0200 (Fr, 17 Jun 2011) | 1 line
Base WST/CSV exports on facets. TODO: generate the facets.
........
r2153 | teichmann | 2011-06-17 16:03:29 +0200 (Fr, 17 Jun 2011) | 1 line
Add facet to access raw computed data.
........
r2154 | teichmann | 2011-06-17 16:37:09 +0200 (Fr, 17 Jun 2011) | 1 line
Generate data facets for the computed states.
........
flys-artifacts/trunk@2156 c6561f87-3c4e-4783-a992-168aeb5c3f6f
author | Sascha L. Teichmann <sascha.teichmann@intevation.de> |
---|---|
date | Fri, 17 Jun 2011 16:17:03 +0000 |
parents | af3b5d9e91a4 |
children | 853dceead0f4 |
comparison
equal
deleted
inserted
replaced
685:d45c3ddaed1b | 704:eab5e5089d77 |
---|---|
1 package de.intevation.flys.artifacts.states; | |
2 | |
3 import java.util.List; | |
4 | |
5 import org.apache.log4j.Logger; | |
6 | |
7 import org.w3c.dom.Element; | |
8 | |
9 import de.intevation.artifacts.Artifact; | |
10 import de.intevation.artifacts.CallContext; | |
11 | |
12 import de.intevation.artifacts.common.utils.XMLUtils; | |
13 | |
14 import de.intevation.artifactdatabase.state.Facet; | |
15 | |
16 import de.intevation.flys.artifacts.FLYSArtifact; | |
17 import de.intevation.flys.artifacts.WINFOArtifact; | |
18 import de.intevation.flys.artifacts.model.FacetTypes; | |
19 import de.intevation.flys.artifacts.model.WaterlevelFacet; | |
20 import de.intevation.flys.artifacts.model.WQKms; | |
21 | |
22 import de.intevation.flys.artifacts.model.DataFacet; | |
23 | |
24 | |
25 public class WaterlevelState | |
26 extends DefaultState | |
27 implements FacetTypes | |
28 { | |
29 /** The logger that is used in this state.*/ | |
30 private static Logger logger = Logger.getLogger(WaterlevelState.class); | |
31 | |
32 | |
33 protected Element[] createItems( | |
34 XMLUtils.ElementCreator cr, | |
35 Artifact artifact, | |
36 String name, | |
37 CallContext context) | |
38 { | |
39 logger.debug("WaterlevelState.createItems"); | |
40 return null; | |
41 } | |
42 | |
43 | |
44 @Override | |
45 public Object computeAdvance( | |
46 FLYSArtifact artifact, | |
47 String hash, | |
48 CallContext context, | |
49 List<Facet> facets, | |
50 Object old | |
51 ) { | |
52 WINFOArtifact winfo = (WINFOArtifact)artifact; | |
53 | |
54 WQKms [] res; | |
55 | |
56 if (old instanceof WQKms []) { | |
57 res = (WQKms [])old; | |
58 } | |
59 else { | |
60 res = winfo.getWaterlevelData(); | |
61 if (res == null) { | |
62 logger.debug("No results given."); | |
63 return null; | |
64 } | |
65 } | |
66 | |
67 for (int i = 0; i < res.length; i++) { | |
68 String nameW = null; | |
69 String nameQ = null; | |
70 | |
71 if (winfo.isQ()) { | |
72 nameQ = res[i].getName(); | |
73 nameW = "W(" + nameQ + ")"; | |
74 } | |
75 else { | |
76 nameW = res[i].getName(); | |
77 nameQ = "Q(" + nameQ + ")"; | |
78 } | |
79 | |
80 logger.debug("Create facet: " + nameW); | |
81 logger.debug("Create facet: " + nameQ); | |
82 | |
83 Facet w = new WaterlevelFacet(i, LONGITUDINAL_W, nameW); | |
84 Facet q = new WaterlevelFacet(i, LONGITUDINAL_Q, nameQ); | |
85 | |
86 facets.add(w); | |
87 facets.add(q); | |
88 } | |
89 | |
90 if (res.length > 0) { | |
91 Facet wst = new DataFacet(WST, "WST data"); | |
92 Facet csv = new DataFacet(CSV, "CSV data"); | |
93 | |
94 facets.add(wst); | |
95 facets.add(csv); | |
96 } | |
97 | |
98 return res; | |
99 } | |
100 } | |
101 // vim:set ts=4 sw=4 si et sta sts=4 fenc=utf-8 : |