Mercurial > dive4elements > river
annotate artifacts/src/main/java/org/dive4elements/river/artifacts/uinfo/vegetationzones/VegetationZoneServerClientXChange.java @ 9509:6146358c4842
Fixed: f2 sign corrected in vegetation zone height calculation, vegetation zone limit handling changed in the importer
author | mschaefer |
---|---|
date | Mon, 01 Oct 2018 09:53:36 +0200 |
parents | 515643b2c49a |
children | d421c2bf0195 |
rev | line source |
---|---|
9071 | 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 package org.dive4elements.river.artifacts.uinfo.vegetationzones; | |
11 | |
12 import java.util.ArrayList; | |
13 import java.util.List; | |
9260 | 14 import java.util.TreeSet; |
9071 | 15 |
9402
e511eb935ccd
Changed hard coded standard vegetation zone table to fetching it from the database, i18n for the standard zone names
mschaefer
parents:
9260
diff
changeset
|
16 import org.dive4elements.artifacts.CallContext; |
e511eb935ccd
Changed hard coded standard vegetation zone table to fetching it from the database, i18n for the standard zone names
mschaefer
parents:
9260
diff
changeset
|
17 import org.dive4elements.river.artifacts.resources.Resources; |
e511eb935ccd
Changed hard coded standard vegetation zone table to fetching it from the database, i18n for the standard zone names
mschaefer
parents:
9260
diff
changeset
|
18 import org.dive4elements.river.model.River; |
9443
515643b2c49a
Added computation of uinfo salix line vegetation zone height (not yet connected to the cross section facet)
mschaefer
parents:
9403
diff
changeset
|
19 import org.dive4elements.river.model.uinfo.VegetationType; |
515643b2c49a
Added computation of uinfo salix line vegetation zone height (not yet connected to the cross section facet)
mschaefer
parents:
9403
diff
changeset
|
20 import org.dive4elements.river.model.uinfo.VegetationZone; |
9402
e511eb935ccd
Changed hard coded standard vegetation zone table to fetching it from the database, i18n for the standard zone names
mschaefer
parents:
9260
diff
changeset
|
21 |
9071 | 22 /** |
23 * @author Domenico Nardi Tironi | |
24 * | |
25 */ | |
9403 | 26 public class VegetationZoneServerClientXChange implements Comparable<VegetationZoneServerClientXChange> { |
9118
431f1c269be5
Veg-Zone Table improved, State change data recovery;
gernotbelger
parents:
9071
diff
changeset
|
27 |
9403 | 28 // IMMER ABGLEICHEN MIT VegetationZoneServerClientXChange.class Server und Client |
9260 | 29 public static final boolean HAS_COLORS_EDITABLE = false; |
30 | |
9071 | 31 private static final String TABLE_CELL_SEPARATOR = "TABLE_CELL_SEPARATOR"; |
32 private static final String TABLE_ROW_SEPARATOR = "TABLE_ROW_SEPARATOR"; | |
33 private final String zoneName; | |
34 private final int min_day_overflow; | |
35 private final int max_day_overflow; | |
9260 | 36 private final String hexColor; |
9071 | 37 |
9403 | 38 public static List<VegetationZoneServerClientXChange> parse(final String zonesRaw) { |
39 final List<VegetationZoneServerClientXChange> resultList = new ArrayList<>(); | |
9071 | 40 |
41 final List<String[]> results = new ArrayList<>(); | |
42 if (zonesRaw.contains(TABLE_ROW_SEPARATOR)) { | |
43 final String[] rows = zonesRaw.split(TABLE_ROW_SEPARATOR); | |
44 for (final String row : rows) { | |
45 if (row.contains(TABLE_CELL_SEPARATOR)) { | |
46 final String[] result = row.split(TABLE_CELL_SEPARATOR); | |
47 results.add(result); | |
48 } | |
49 } | |
50 } | |
51 for (final String[] zone : results) { | |
52 | |
9403 | 53 final VegetationZoneServerClientXChange helper = new VegetationZoneServerClientXChange(zone[0], Integer.valueOf(zone[1]), Integer.valueOf(zone[2]), zone[3]); |
9071 | 54 resultList.add(helper); |
55 } | |
56 | |
57 return resultList; | |
58 } | |
59 | |
9403 | 60 public static VegetationZoneServerClientXChange createFromTableEntry(final String zone, final String min_day_overflow, final String max_day_overflow, final String hexColor) { |
61 return new VegetationZoneServerClientXChange(zone, Integer.valueOf(min_day_overflow), Integer.valueOf(max_day_overflow), hexColor); // Error-Handling? | |
9118
431f1c269be5
Veg-Zone Table improved, State change data recovery;
gernotbelger
parents:
9071
diff
changeset
|
62 } |
431f1c269be5
Veg-Zone Table improved, State change data recovery;
gernotbelger
parents:
9071
diff
changeset
|
63 |
9403 | 64 private VegetationZoneServerClientXChange(final String zone, final Integer min_day_overflow, final Integer max_day_overflow, final String hexColor) { |
9071 | 65 this.zoneName = zone; |
66 this.min_day_overflow = min_day_overflow; | |
67 this.max_day_overflow = max_day_overflow; | |
9260 | 68 this.hexColor = hexColor; |
9071 | 69 } |
70 | |
71 public int getMax_day_overflow() { | |
72 return this.max_day_overflow; | |
73 } | |
74 | |
75 public String getZoneName() { | |
9260 | 76 if (this.zoneName == null || this.zoneName.equals("")) { |
77 return "---"; | |
78 } | |
9071 | 79 return this.zoneName; |
80 } | |
81 | |
9260 | 82 public String getHexColor() { |
83 try { | |
84 final int test = Integer.decode(this.hexColor); | |
85 return this.hexColor; | |
86 } | |
87 catch (final NumberFormatException e) { | |
88 return "#ffffff"; | |
89 } | |
90 } | |
91 | |
9071 | 92 public int getMin_day_overflow() { |
93 return this.min_day_overflow; | |
94 } | |
9118
431f1c269be5
Veg-Zone Table improved, State change data recovery;
gernotbelger
parents:
9071
diff
changeset
|
95 |
9443
515643b2c49a
Added computation of uinfo salix line vegetation zone height (not yet connected to the cross section facet)
mschaefer
parents:
9403
diff
changeset
|
96 public static String getLocalizedVegetationTypeName(final CallContext context, final VegetationType zonetype) { |
515643b2c49a
Added computation of uinfo salix line vegetation zone height (not yet connected to the cross section facet)
mschaefer
parents:
9403
diff
changeset
|
97 return Resources.getMsg(context.getMeta(), "uinfo_vegetation_type_" + zonetype.getId().toString()); |
515643b2c49a
Added computation of uinfo salix line vegetation zone height (not yet connected to the cross section facet)
mschaefer
parents:
9403
diff
changeset
|
98 } |
515643b2c49a
Added computation of uinfo salix line vegetation zone height (not yet connected to the cross section facet)
mschaefer
parents:
9403
diff
changeset
|
99 |
9403 | 100 public static final List<VegetationZoneServerClientXChange> getStandardList(final River river, final CallContext context) { |
9118
431f1c269be5
Veg-Zone Table improved, State change data recovery;
gernotbelger
parents:
9071
diff
changeset
|
101 |
9403 | 102 final List<VegetationZoneServerClientXChange> list = new ArrayList<>(); |
9443
515643b2c49a
Added computation of uinfo salix line vegetation zone height (not yet connected to the cross section facet)
mschaefer
parents:
9403
diff
changeset
|
103 for (final VegetationZone vz : VegetationZone.getValues(river)) { |
515643b2c49a
Added computation of uinfo salix line vegetation zone height (not yet connected to the cross section facet)
mschaefer
parents:
9403
diff
changeset
|
104 final String zn = getLocalizedVegetationTypeName(context, vz.getVegetationType()); |
9403 | 105 list.add(new VegetationZoneServerClientXChange(zn, vz.getMin_overflow_days(), vz.getMax_overflow_days(), vz.getColor())); |
9402
e511eb935ccd
Changed hard coded standard vegetation zone table to fetching it from the database, i18n for the standard zone names
mschaefer
parents:
9260
diff
changeset
|
106 } |
9118
431f1c269be5
Veg-Zone Table improved, State change data recovery;
gernotbelger
parents:
9071
diff
changeset
|
107 return list; |
431f1c269be5
Veg-Zone Table improved, State change data recovery;
gernotbelger
parents:
9071
diff
changeset
|
108 } |
431f1c269be5
Veg-Zone Table improved, State change data recovery;
gernotbelger
parents:
9071
diff
changeset
|
109 |
9403 | 110 public static final String parseListToDataString(final List<VegetationZoneServerClientXChange> list) { |
9118
431f1c269be5
Veg-Zone Table improved, State change data recovery;
gernotbelger
parents:
9071
diff
changeset
|
111 |
431f1c269be5
Veg-Zone Table improved, State change data recovery;
gernotbelger
parents:
9071
diff
changeset
|
112 java.util.Collections.sort(list); |
431f1c269be5
Veg-Zone Table improved, State change data recovery;
gernotbelger
parents:
9071
diff
changeset
|
113 final StringBuilder builder = new StringBuilder(); |
9403 | 114 for (final VegetationZoneServerClientXChange zone : list) { |
9118
431f1c269be5
Veg-Zone Table improved, State change data recovery;
gernotbelger
parents:
9071
diff
changeset
|
115 builder.append(zone.getZoneName()); |
431f1c269be5
Veg-Zone Table improved, State change data recovery;
gernotbelger
parents:
9071
diff
changeset
|
116 builder.append(TABLE_CELL_SEPARATOR); |
431f1c269be5
Veg-Zone Table improved, State change data recovery;
gernotbelger
parents:
9071
diff
changeset
|
117 builder.append(zone.getMin_day_overflow()); |
431f1c269be5
Veg-Zone Table improved, State change data recovery;
gernotbelger
parents:
9071
diff
changeset
|
118 builder.append(TABLE_CELL_SEPARATOR); |
431f1c269be5
Veg-Zone Table improved, State change data recovery;
gernotbelger
parents:
9071
diff
changeset
|
119 builder.append(zone.getMax_day_overflow()); |
9260 | 120 builder.append(TABLE_CELL_SEPARATOR); |
121 builder.append(zone.getHexColor()); | |
9118
431f1c269be5
Veg-Zone Table improved, State change data recovery;
gernotbelger
parents:
9071
diff
changeset
|
122 builder.append(TABLE_ROW_SEPARATOR); |
431f1c269be5
Veg-Zone Table improved, State change data recovery;
gernotbelger
parents:
9071
diff
changeset
|
123 } |
431f1c269be5
Veg-Zone Table improved, State change data recovery;
gernotbelger
parents:
9071
diff
changeset
|
124 return builder.toString(); |
431f1c269be5
Veg-Zone Table improved, State change data recovery;
gernotbelger
parents:
9071
diff
changeset
|
125 |
431f1c269be5
Veg-Zone Table improved, State change data recovery;
gernotbelger
parents:
9071
diff
changeset
|
126 } |
431f1c269be5
Veg-Zone Table improved, State change data recovery;
gernotbelger
parents:
9071
diff
changeset
|
127 |
431f1c269be5
Veg-Zone Table improved, State change data recovery;
gernotbelger
parents:
9071
diff
changeset
|
128 @Override |
9403 | 129 public int compareTo(final VegetationZoneServerClientXChange o) { |
9118
431f1c269be5
Veg-Zone Table improved, State change data recovery;
gernotbelger
parents:
9071
diff
changeset
|
130 final int basicCompare = Integer.valueOf(this.getMin_day_overflow()).compareTo(o.getMin_day_overflow()); |
431f1c269be5
Veg-Zone Table improved, State change data recovery;
gernotbelger
parents:
9071
diff
changeset
|
131 if (basicCompare == 0) |
9260 | 132 return Integer.valueOf(this.getMax_day_overflow()).compareTo(o.getMax_day_overflow()); // wenn min==min && max==max, alphabetisch sortieren? |
133 | |
134 if (basicCompare == 0) { | |
135 return 1; // for treeSet | |
136 } | |
137 | |
9118
431f1c269be5
Veg-Zone Table improved, State change data recovery;
gernotbelger
parents:
9071
diff
changeset
|
138 return basicCompare; |
431f1c269be5
Veg-Zone Table improved, State change data recovery;
gernotbelger
parents:
9071
diff
changeset
|
139 } |
431f1c269be5
Veg-Zone Table improved, State change data recovery;
gernotbelger
parents:
9071
diff
changeset
|
140 |
9403 | 141 public static final boolean zonesAreOverlapping(final List<VegetationZoneServerClientXChange> list) { |
142 for (final VegetationZoneServerClientXChange zone : list) { | |
143 for (final VegetationZoneServerClientXChange zoneOther : list) { | |
9260 | 144 if (zone != zoneOther) { |
145 final boolean overlaps = zone.overlaps(zoneOther); | |
146 if (overlaps) { | |
147 return overlaps; // cancel. only one zone has to overlap | |
148 } | |
149 } | |
150 } | |
151 } | |
152 | |
153 return false; | |
154 } | |
155 | |
9403 | 156 public static final boolean hasGaps(final List<VegetationZoneServerClientXChange> list, final int lower, final int upper) { |
9260 | 157 |
158 if ((upper - lower) == 0) | |
159 return true; | |
160 | |
9403 | 161 final TreeSet<VegetationZoneServerClientXChange> treeList = new TreeSet<>(); |
9260 | 162 treeList.addAll(list); |
163 int lowerCompare = lower; | |
9403 | 164 for (final VegetationZoneServerClientXChange zone : treeList) { |
9260 | 165 if (zone.getLowerFromTo() > (lowerCompare + 1)) { // nicht inklusiv |
166 return true; | |
167 } | |
168 lowerCompare = zone.getUpperFromTo(); | |
169 } | |
170 if ((lowerCompare) < upper) | |
171 return true; // am Ende nicht geschlossen | |
172 | |
173 return false; | |
174 } | |
175 | |
9403 | 176 private boolean overlaps(final VegetationZoneServerClientXChange otherZone) { |
9260 | 177 final int otherLower = otherZone.getLowerFromTo(); |
178 final int otherUpper = otherZone.getUpperFromTo(); | |
179 | |
180 final int upper = getUpperFromTo(); | |
181 final int lower = getLowerFromTo(); | |
182 final int otherSchwerpunkt = (otherLower + otherUpper) / 2; | |
183 if ((otherUpper <= upper && otherUpper >= lower)) { | |
184 return true; | |
185 } else if (otherLower >= lower && otherLower <= upper) { | |
186 return true; | |
187 } else if (otherSchwerpunkt >= (lower) && otherSchwerpunkt <= (upper)) { | |
188 return true; | |
189 } | |
190 return false; | |
191 } | |
192 | |
193 public Integer getLowerFromTo() { | |
194 return this.min_day_overflow < this.max_day_overflow ? this.min_day_overflow : this.max_day_overflow; // Math. is forbidden :-( | |
195 } | |
196 | |
197 public Integer getUpperFromTo() { | |
198 return this.min_day_overflow > this.max_day_overflow ? this.min_day_overflow : this.max_day_overflow;// Math. is forbidden :-( | |
199 } | |
200 | |
9071 | 201 } |