Mercurial > dive4elements > river
annotate artifacts/src/main/java/org/dive4elements/river/artifacts/states/minfo/BedQualityPeriodsSelect.java @ 8625:362abb64e897
Add default value to BedQuality period selection
author | Andre Heinecke <andre.heinecke@intevation.de> |
---|---|
date | Thu, 26 Mar 2015 11:51:47 +0100 |
parents | e4606eae8ea5 |
children | 5a5331dd3e8d |
rev | line source |
---|---|
5863
4897a58c8746
River artifacts: Added new copyright headers.
Sascha L. Teichmann <teichmann@intevation.de>
parents:
5838
diff
changeset
|
1 /* Copyright (C) 2011, 2012, 2013 by Bundesanstalt für Gewässerkunde |
4897a58c8746
River artifacts: Added new copyright headers.
Sascha L. Teichmann <teichmann@intevation.de>
parents:
5838
diff
changeset
|
2 * Software engineering by Intevation GmbH |
4897a58c8746
River artifacts: Added new copyright headers.
Sascha L. Teichmann <teichmann@intevation.de>
parents:
5838
diff
changeset
|
3 * |
5994
af13ceeba52a
Removed trailing whitespace.
Sascha L. Teichmann <teichmann@intevation.de>
parents:
5863
diff
changeset
|
4 * This file is Free Software under the GNU AGPL (>=v3) |
5863
4897a58c8746
River artifacts: Added new copyright headers.
Sascha L. Teichmann <teichmann@intevation.de>
parents:
5838
diff
changeset
|
5 * and comes with ABSOLUTELY NO WARRANTY! Check out the |
5994
af13ceeba52a
Removed trailing whitespace.
Sascha L. Teichmann <teichmann@intevation.de>
parents:
5863
diff
changeset
|
6 * documentation coming with Dive4Elements River for details. |
5863
4897a58c8746
River artifacts: Added new copyright headers.
Sascha L. Teichmann <teichmann@intevation.de>
parents:
5838
diff
changeset
|
7 */ |
4897a58c8746
River artifacts: Added new copyright headers.
Sascha L. Teichmann <teichmann@intevation.de>
parents:
5838
diff
changeset
|
8 |
5831
bd047b71ab37
Repaired internal references
Sascha L. Teichmann <teichmann@intevation.de>
parents:
3751
diff
changeset
|
9 package org.dive4elements.river.artifacts.states.minfo; |
3751
ae598cf50682
Added new services to render overview charts in minfo bed quality calculation
Raimund Renkert <raimund.renkert@intevation.de>
parents:
diff
changeset
|
10 |
8625
362abb64e897
Add default value to BedQuality period selection
Andre Heinecke <andre.heinecke@intevation.de>
parents:
8202
diff
changeset
|
11 import java.util.List; |
362abb64e897
Add default value to BedQuality period selection
Andre Heinecke <andre.heinecke@intevation.de>
parents:
8202
diff
changeset
|
12 import java.util.Date; |
362abb64e897
Add default value to BedQuality period selection
Andre Heinecke <andre.heinecke@intevation.de>
parents:
8202
diff
changeset
|
13 import java.util.TreeSet; |
362abb64e897
Add default value to BedQuality period selection
Andre Heinecke <andre.heinecke@intevation.de>
parents:
8202
diff
changeset
|
14 |
3751
ae598cf50682
Added new services to render overview charts in minfo bed quality calculation
Raimund Renkert <raimund.renkert@intevation.de>
parents:
diff
changeset
|
15 import org.apache.log4j.Logger; |
ae598cf50682
Added new services to render overview charts in minfo bed quality calculation
Raimund Renkert <raimund.renkert@intevation.de>
parents:
diff
changeset
|
16 |
5831
bd047b71ab37
Repaired internal references
Sascha L. Teichmann <teichmann@intevation.de>
parents:
3751
diff
changeset
|
17 import org.dive4elements.river.artifacts.states.DefaultState; |
3751
ae598cf50682
Added new services to render overview charts in minfo bed quality calculation
Raimund Renkert <raimund.renkert@intevation.de>
parents:
diff
changeset
|
18 |
8625
362abb64e897
Add default value to BedQuality period selection
Andre Heinecke <andre.heinecke@intevation.de>
parents:
8202
diff
changeset
|
19 import org.w3c.dom.Element; |
362abb64e897
Add default value to BedQuality period selection
Andre Heinecke <andre.heinecke@intevation.de>
parents:
8202
diff
changeset
|
20 |
362abb64e897
Add default value to BedQuality period selection
Andre Heinecke <andre.heinecke@intevation.de>
parents:
8202
diff
changeset
|
21 import org.dive4elements.river.artifacts.access.RangeAccess; |
362abb64e897
Add default value to BedQuality period selection
Andre Heinecke <andre.heinecke@intevation.de>
parents:
8202
diff
changeset
|
22 import org.dive4elements.river.artifacts.D4EArtifact; |
362abb64e897
Add default value to BedQuality period selection
Andre Heinecke <andre.heinecke@intevation.de>
parents:
8202
diff
changeset
|
23 import org.dive4elements.river.artifacts.model.minfo.BedOverview; |
362abb64e897
Add default value to BedQuality period selection
Andre Heinecke <andre.heinecke@intevation.de>
parents:
8202
diff
changeset
|
24 import org.dive4elements.river.artifacts.model.minfo.BedOverviewFactory; |
362abb64e897
Add default value to BedQuality period selection
Andre Heinecke <andre.heinecke@intevation.de>
parents:
8202
diff
changeset
|
25 import org.dive4elements.river.artifacts.model.minfo.BedloadOverview; |
362abb64e897
Add default value to BedQuality period selection
Andre Heinecke <andre.heinecke@intevation.de>
parents:
8202
diff
changeset
|
26 import org.dive4elements.river.artifacts.model.minfo.BedloadOverviewFactory; |
362abb64e897
Add default value to BedQuality period selection
Andre Heinecke <andre.heinecke@intevation.de>
parents:
8202
diff
changeset
|
27 |
362abb64e897
Add default value to BedQuality period selection
Andre Heinecke <andre.heinecke@intevation.de>
parents:
8202
diff
changeset
|
28 import org.dive4elements.river.utils.KMIndex; |
362abb64e897
Add default value to BedQuality period selection
Andre Heinecke <andre.heinecke@intevation.de>
parents:
8202
diff
changeset
|
29 |
362abb64e897
Add default value to BedQuality period selection
Andre Heinecke <andre.heinecke@intevation.de>
parents:
8202
diff
changeset
|
30 import org.dive4elements.artifacts.common.utils.XMLUtils; |
362abb64e897
Add default value to BedQuality period selection
Andre Heinecke <andre.heinecke@intevation.de>
parents:
8202
diff
changeset
|
31 import org.dive4elements.artifacts.Artifact; |
362abb64e897
Add default value to BedQuality period selection
Andre Heinecke <andre.heinecke@intevation.de>
parents:
8202
diff
changeset
|
32 import org.dive4elements.artifacts.CallContext; |
362abb64e897
Add default value to BedQuality period selection
Andre Heinecke <andre.heinecke@intevation.de>
parents:
8202
diff
changeset
|
33 |
362abb64e897
Add default value to BedQuality period selection
Andre Heinecke <andre.heinecke@intevation.de>
parents:
8202
diff
changeset
|
34 import org.dive4elements.artifactdatabase.data.StateData; |
362abb64e897
Add default value to BedQuality period selection
Andre Heinecke <andre.heinecke@intevation.de>
parents:
8202
diff
changeset
|
35 |
362abb64e897
Add default value to BedQuality period selection
Andre Heinecke <andre.heinecke@intevation.de>
parents:
8202
diff
changeset
|
36 |
3751
ae598cf50682
Added new services to render overview charts in minfo bed quality calculation
Raimund Renkert <raimund.renkert@intevation.de>
parents:
diff
changeset
|
37 public class BedQualityPeriodsSelect extends DefaultState { |
ae598cf50682
Added new services to render overview charts in minfo bed quality calculation
Raimund Renkert <raimund.renkert@intevation.de>
parents:
diff
changeset
|
38 |
8202
e4606eae8ea5
sed src/**/*.java 's/logger/log/g'
Sascha L. Teichmann <teichmann@intevation.de>
parents:
5994
diff
changeset
|
39 /** The log used in this class. */ |
e4606eae8ea5
sed src/**/*.java 's/logger/log/g'
Sascha L. Teichmann <teichmann@intevation.de>
parents:
5994
diff
changeset
|
40 private static Logger log = Logger.getLogger(BedQualityPeriodsSelect.class); |
3751
ae598cf50682
Added new services to render overview charts in minfo bed quality calculation
Raimund Renkert <raimund.renkert@intevation.de>
parents:
diff
changeset
|
41 |
ae598cf50682
Added new services to render overview charts in minfo bed quality calculation
Raimund Renkert <raimund.renkert@intevation.de>
parents:
diff
changeset
|
42 |
ae598cf50682
Added new services to render overview charts in minfo bed quality calculation
Raimund Renkert <raimund.renkert@intevation.de>
parents:
diff
changeset
|
43 /** |
ae598cf50682
Added new services to render overview charts in minfo bed quality calculation
Raimund Renkert <raimund.renkert@intevation.de>
parents:
diff
changeset
|
44 * The default constructor that initializes an empty State object. |
ae598cf50682
Added new services to render overview charts in minfo bed quality calculation
Raimund Renkert <raimund.renkert@intevation.de>
parents:
diff
changeset
|
45 */ |
ae598cf50682
Added new services to render overview charts in minfo bed quality calculation
Raimund Renkert <raimund.renkert@intevation.de>
parents:
diff
changeset
|
46 public BedQualityPeriodsSelect() { |
ae598cf50682
Added new services to render overview charts in minfo bed quality calculation
Raimund Renkert <raimund.renkert@intevation.de>
parents:
diff
changeset
|
47 } |
ae598cf50682
Added new services to render overview charts in minfo bed quality calculation
Raimund Renkert <raimund.renkert@intevation.de>
parents:
diff
changeset
|
48 |
8625
362abb64e897
Add default value to BedQuality period selection
Andre Heinecke <andre.heinecke@intevation.de>
parents:
8202
diff
changeset
|
49 /** Get either the start and end date of the data at the current position. */ |
362abb64e897
Add default value to BedQuality period selection
Andre Heinecke <andre.heinecke@intevation.de>
parents:
8202
diff
changeset
|
50 protected Long[] getDataMinMaxDate(Artifact artifact) { |
362abb64e897
Add default value to BedQuality period selection
Andre Heinecke <andre.heinecke@intevation.de>
parents:
8202
diff
changeset
|
51 D4EArtifact arti = (D4EArtifact) artifact; |
362abb64e897
Add default value to BedQuality period selection
Andre Heinecke <andre.heinecke@intevation.de>
parents:
8202
diff
changeset
|
52 RangeAccess access = new RangeAccess(arti); |
362abb64e897
Add default value to BedQuality period selection
Andre Heinecke <andre.heinecke@intevation.de>
parents:
8202
diff
changeset
|
53 double a = access.getFrom(); |
362abb64e897
Add default value to BedQuality period selection
Andre Heinecke <andre.heinecke@intevation.de>
parents:
8202
diff
changeset
|
54 double b = access.getTo(); |
362abb64e897
Add default value to BedQuality period selection
Andre Heinecke <andre.heinecke@intevation.de>
parents:
8202
diff
changeset
|
55 |
362abb64e897
Add default value to BedQuality period selection
Andre Heinecke <andre.heinecke@intevation.de>
parents:
8202
diff
changeset
|
56 if (a > b) { |
362abb64e897
Add default value to BedQuality period selection
Andre Heinecke <andre.heinecke@intevation.de>
parents:
8202
diff
changeset
|
57 double buf = a; |
362abb64e897
Add default value to BedQuality period selection
Andre Heinecke <andre.heinecke@intevation.de>
parents:
8202
diff
changeset
|
58 a = b; |
362abb64e897
Add default value to BedQuality period selection
Andre Heinecke <andre.heinecke@intevation.de>
parents:
8202
diff
changeset
|
59 b = buf; |
362abb64e897
Add default value to BedQuality period selection
Andre Heinecke <andre.heinecke@intevation.de>
parents:
8202
diff
changeset
|
60 } |
362abb64e897
Add default value to BedQuality period selection
Andre Heinecke <andre.heinecke@intevation.de>
parents:
8202
diff
changeset
|
61 |
362abb64e897
Add default value to BedQuality period selection
Andre Heinecke <andre.heinecke@intevation.de>
parents:
8202
diff
changeset
|
62 BedOverview overview = BedOverviewFactory.getOverview(access.getRiverName()); |
362abb64e897
Add default value to BedQuality period selection
Andre Heinecke <andre.heinecke@intevation.de>
parents:
8202
diff
changeset
|
63 BedloadOverview overview2 = BedloadOverviewFactory.getOverview(access.getRiverName()); |
362abb64e897
Add default value to BedQuality period selection
Andre Heinecke <andre.heinecke@intevation.de>
parents:
8202
diff
changeset
|
64 |
362abb64e897
Add default value to BedQuality period selection
Andre Heinecke <andre.heinecke@intevation.de>
parents:
8202
diff
changeset
|
65 /* Filter is not implemented and only checks if a complete |
362abb64e897
Add default value to BedQuality period selection
Andre Heinecke <andre.heinecke@intevation.de>
parents:
8202
diff
changeset
|
66 * KMIndex list is acceptable or not. So KMFiltering wont work */ |
362abb64e897
Add default value to BedQuality period selection
Andre Heinecke <andre.heinecke@intevation.de>
parents:
8202
diff
changeset
|
67 KMIndex<List<Date>> entries = overview.filter(BedOverview.ACCEPT); |
362abb64e897
Add default value to BedQuality period selection
Andre Heinecke <andre.heinecke@intevation.de>
parents:
8202
diff
changeset
|
68 KMIndex<List<Date>> loads = overview2.filter(BedloadOverview.ACCEPT); |
362abb64e897
Add default value to BedQuality period selection
Andre Heinecke <andre.heinecke@intevation.de>
parents:
8202
diff
changeset
|
69 TreeSet<Date> allDates = new TreeSet<Date>(); |
362abb64e897
Add default value to BedQuality period selection
Andre Heinecke <andre.heinecke@intevation.de>
parents:
8202
diff
changeset
|
70 |
362abb64e897
Add default value to BedQuality period selection
Andre Heinecke <andre.heinecke@intevation.de>
parents:
8202
diff
changeset
|
71 for (int i = 0; i < entries.size(); i++) { |
362abb64e897
Add default value to BedQuality period selection
Andre Heinecke <andre.heinecke@intevation.de>
parents:
8202
diff
changeset
|
72 if (entries.get(i).getKm() >= a && entries.get(i).getKm() <= b) { |
362abb64e897
Add default value to BedQuality period selection
Andre Heinecke <andre.heinecke@intevation.de>
parents:
8202
diff
changeset
|
73 allDates.addAll(entries.get(i).getValue()); |
362abb64e897
Add default value to BedQuality period selection
Andre Heinecke <andre.heinecke@intevation.de>
parents:
8202
diff
changeset
|
74 } |
362abb64e897
Add default value to BedQuality period selection
Andre Heinecke <andre.heinecke@intevation.de>
parents:
8202
diff
changeset
|
75 } |
362abb64e897
Add default value to BedQuality period selection
Andre Heinecke <andre.heinecke@intevation.de>
parents:
8202
diff
changeset
|
76 for (int i = 0; i < loads.size(); i++) { |
362abb64e897
Add default value to BedQuality period selection
Andre Heinecke <andre.heinecke@intevation.de>
parents:
8202
diff
changeset
|
77 if (loads.get(i).getKm() >= a && loads.get(i).getKm() <= b) { |
362abb64e897
Add default value to BedQuality period selection
Andre Heinecke <andre.heinecke@intevation.de>
parents:
8202
diff
changeset
|
78 allDates.addAll(loads.get(i).getValue()); |
362abb64e897
Add default value to BedQuality period selection
Andre Heinecke <andre.heinecke@intevation.de>
parents:
8202
diff
changeset
|
79 } |
362abb64e897
Add default value to BedQuality period selection
Andre Heinecke <andre.heinecke@intevation.de>
parents:
8202
diff
changeset
|
80 } |
362abb64e897
Add default value to BedQuality period selection
Andre Heinecke <andre.heinecke@intevation.de>
parents:
8202
diff
changeset
|
81 if (allDates.size() < 2) { |
362abb64e897
Add default value to BedQuality period selection
Andre Heinecke <andre.heinecke@intevation.de>
parents:
8202
diff
changeset
|
82 return null; |
362abb64e897
Add default value to BedQuality period selection
Andre Heinecke <andre.heinecke@intevation.de>
parents:
8202
diff
changeset
|
83 } |
362abb64e897
Add default value to BedQuality period selection
Andre Heinecke <andre.heinecke@intevation.de>
parents:
8202
diff
changeset
|
84 |
362abb64e897
Add default value to BedQuality period selection
Andre Heinecke <andre.heinecke@intevation.de>
parents:
8202
diff
changeset
|
85 return new Long[] {allDates.first().getTime(), |
362abb64e897
Add default value to BedQuality period selection
Andre Heinecke <andre.heinecke@intevation.de>
parents:
8202
diff
changeset
|
86 allDates.last().getTime()}; |
362abb64e897
Add default value to BedQuality period selection
Andre Heinecke <andre.heinecke@intevation.de>
parents:
8202
diff
changeset
|
87 } |
362abb64e897
Add default value to BedQuality period selection
Andre Heinecke <andre.heinecke@intevation.de>
parents:
8202
diff
changeset
|
88 |
362abb64e897
Add default value to BedQuality period selection
Andre Heinecke <andre.heinecke@intevation.de>
parents:
8202
diff
changeset
|
89 @Override |
362abb64e897
Add default value to BedQuality period selection
Andre Heinecke <andre.heinecke@intevation.de>
parents:
8202
diff
changeset
|
90 protected Element[] createItems( |
362abb64e897
Add default value to BedQuality period selection
Andre Heinecke <andre.heinecke@intevation.de>
parents:
8202
diff
changeset
|
91 XMLUtils.ElementCreator cr, |
362abb64e897
Add default value to BedQuality period selection
Andre Heinecke <andre.heinecke@intevation.de>
parents:
8202
diff
changeset
|
92 Artifact artifact, |
362abb64e897
Add default value to BedQuality period selection
Andre Heinecke <andre.heinecke@intevation.de>
parents:
8202
diff
changeset
|
93 String name, |
362abb64e897
Add default value to BedQuality period selection
Andre Heinecke <andre.heinecke@intevation.de>
parents:
8202
diff
changeset
|
94 CallContext context) |
362abb64e897
Add default value to BedQuality period selection
Andre Heinecke <andre.heinecke@intevation.de>
parents:
8202
diff
changeset
|
95 { |
362abb64e897
Add default value to BedQuality period selection
Andre Heinecke <andre.heinecke@intevation.de>
parents:
8202
diff
changeset
|
96 if (!name.equals("periods")) { |
362abb64e897
Add default value to BedQuality period selection
Andre Heinecke <andre.heinecke@intevation.de>
parents:
8202
diff
changeset
|
97 return null; |
362abb64e897
Add default value to BedQuality period selection
Andre Heinecke <andre.heinecke@intevation.de>
parents:
8202
diff
changeset
|
98 } |
362abb64e897
Add default value to BedQuality period selection
Andre Heinecke <andre.heinecke@intevation.de>
parents:
8202
diff
changeset
|
99 Long[] values = getDataMinMaxDate(artifact); |
362abb64e897
Add default value to BedQuality period selection
Andre Heinecke <andre.heinecke@intevation.de>
parents:
8202
diff
changeset
|
100 if (values == null) { |
362abb64e897
Add default value to BedQuality period selection
Andre Heinecke <andre.heinecke@intevation.de>
parents:
8202
diff
changeset
|
101 return null; |
362abb64e897
Add default value to BedQuality period selection
Andre Heinecke <andre.heinecke@intevation.de>
parents:
8202
diff
changeset
|
102 } |
362abb64e897
Add default value to BedQuality period selection
Andre Heinecke <andre.heinecke@intevation.de>
parents:
8202
diff
changeset
|
103 Element def = createItem( |
362abb64e897
Add default value to BedQuality period selection
Andre Heinecke <andre.heinecke@intevation.de>
parents:
8202
diff
changeset
|
104 cr, |
362abb64e897
Add default value to BedQuality period selection
Andre Heinecke <andre.heinecke@intevation.de>
parents:
8202
diff
changeset
|
105 new String[] {"default", values[0].toString() + "," + values[1].toString()}); |
362abb64e897
Add default value to BedQuality period selection
Andre Heinecke <andre.heinecke@intevation.de>
parents:
8202
diff
changeset
|
106 |
362abb64e897
Add default value to BedQuality period selection
Andre Heinecke <andre.heinecke@intevation.de>
parents:
8202
diff
changeset
|
107 return new Element[] { def }; |
362abb64e897
Add default value to BedQuality period selection
Andre Heinecke <andre.heinecke@intevation.de>
parents:
8202
diff
changeset
|
108 } |
362abb64e897
Add default value to BedQuality period selection
Andre Heinecke <andre.heinecke@intevation.de>
parents:
8202
diff
changeset
|
109 |
3751
ae598cf50682
Added new services to render overview charts in minfo bed quality calculation
Raimund Renkert <raimund.renkert@intevation.de>
parents:
diff
changeset
|
110 @Override |
ae598cf50682
Added new services to render overview charts in minfo bed quality calculation
Raimund Renkert <raimund.renkert@intevation.de>
parents:
diff
changeset
|
111 protected String getUIProvider() { |
ae598cf50682
Added new services to render overview charts in minfo bed quality calculation
Raimund Renkert <raimund.renkert@intevation.de>
parents:
diff
changeset
|
112 return "bedquality_periods_select"; |
ae598cf50682
Added new services to render overview charts in minfo bed quality calculation
Raimund Renkert <raimund.renkert@intevation.de>
parents:
diff
changeset
|
113 } |
ae598cf50682
Added new services to render overview charts in minfo bed quality calculation
Raimund Renkert <raimund.renkert@intevation.de>
parents:
diff
changeset
|
114 |
ae598cf50682
Added new services to render overview charts in minfo bed quality calculation
Raimund Renkert <raimund.renkert@intevation.de>
parents:
diff
changeset
|
115 } |