source: osm/applications/editors/josm/plugins/smed2/src/seamap/Rules.java@ 29199

Last change on this file since 29199 was 29199, checked in by malcolmh, 13 years ago

save

File size: 20.6 KB
Line 
1/* Copyright 2013 Malcolm Herring
2 *
3 * This is free software: you can redistribute it and/or modify
4 * it under the terms of the GNU General Public License as published by
5 * the Free Software Foundation, version 3 of the License.
6 *
7 * For a copy of the GNU General Public License, see <http://www.gnu.org/licenses/>.
8 */
9
10package seamap;
11
12import java.awt.BasicStroke;
13import java.awt.Color;
14import java.awt.Font;
15import java.awt.geom.AffineTransform;
16import java.util.ArrayList;
17
18import s57.S57val.*;
19import s57.S57att.*;
20import s57.S57obj.*;
21
22import seamap.SeaMap.*;
23import symbols.*;
24import symbols.Symbols.*;
25
26public class Rules {
27
28 static SeaMap map;
29 static int zoom;
30
31 public static void rules (SeaMap m, int z) {
32 map = m;
33 zoom = z;
34 ArrayList<Feature> objects;
35 if ((objects = map.features.get(Obj.SLCONS)) != null) for (Feature feature : objects) shoreline(feature);
36 if ((objects = map.features.get(Obj.SLCONS)) != null) for (Feature feature : objects) shoreline(feature);;
37 if ((objects = map.features.get(Obj.PIPSOL)) != null) for (Feature feature : objects) pipelines(feature);
38 if ((objects = map.features.get(Obj.CBLSUB)) != null) for (Feature feature : objects) cables(feature);
39 if ((objects = map.features.get(Obj.PIPOHD)) != null) for (Feature feature : objects) pipelines(feature);
40 if ((objects = map.features.get(Obj.CBLOHD)) != null) for (Feature feature : objects) cables(feature);
41 if ((objects = map.features.get(Obj.TSEZNE)) != null) for (Feature feature : objects) separation(feature);
42 if ((objects = map.features.get(Obj.TSSCRS)) != null) for (Feature feature : objects) separation(feature);
43 if ((objects = map.features.get(Obj.TSSRON)) != null) for (Feature feature : objects) separation(feature);
44 if ((objects = map.features.get(Obj.TSELNE)) != null) for (Feature feature : objects) separation(feature);
45 if ((objects = map.features.get(Obj.TSSLPT)) != null) for (Feature feature : objects) separation(feature);
46 if ((objects = map.features.get(Obj.TSSBND)) != null) for (Feature feature : objects) separation(feature);
47 if ((objects = map.features.get(Obj.SNDWAV)) != null) for (Feature feature : objects) areas(feature);
48 if ((objects = map.features.get(Obj.OSPARE)) != null) for (Feature feature : objects) areas(feature);
49 if ((objects = map.features.get(Obj.FAIRWY)) != null) for (Feature feature : objects) areas(feature);
50 if ((objects = map.features.get(Obj.DRGARE)) != null) for (Feature feature : objects) areas(feature);
51 if ((objects = map.features.get(Obj.RESARE)) != null) for (Feature feature : objects) areas(feature);
52 if ((objects = map.features.get(Obj.SPLARE)) != null) for (Feature feature : objects) areas(feature);
53 if ((objects = map.features.get(Obj.SEAARE)) != null) for (Feature feature : objects) areas(feature);
54 if ((objects = map.features.get(Obj.OBSTRN)) != null) for (Feature feature : objects) obstructions(feature);
55 if ((objects = map.features.get(Obj.UWTROC)) != null) for (Feature feature : objects) obstructions(feature);
56 if ((objects = map.features.get(Obj.MARCUL)) != null) for (Feature feature : objects) areas(feature);
57 if ((objects = map.features.get(Obj.WTWAXS)) != null) for (Feature feature : objects) waterways(feature);
58 if ((objects = map.features.get(Obj.RECTRC)) != null) for (Feature feature : objects) transits(feature);
59 if ((objects = map.features.get(Obj.NAVLNE)) != null) for (Feature feature : objects) transits(feature);
60 if ((objects = map.features.get(Obj.HRBFAC)) != null) for (Feature feature : objects) harbours(feature);
61 if ((objects = map.features.get(Obj.ACHARE)) != null) for (Feature feature : objects) harbours(feature);
62 if ((objects = map.features.get(Obj.ACHBRT)) != null) for (Feature feature : objects) harbours(feature);
63 if ((objects = map.features.get(Obj.LOKBSN)) != null) for (Feature feature : objects) locks(feature);
64 if ((objects = map.features.get(Obj.LKBSPT)) != null) for (Feature feature : objects) locks(feature);
65 if ((objects = map.features.get(Obj.GATCON)) != null) for (Feature feature : objects) locks(feature);
66 if ((objects = map.features.get(Obj.DISMAR)) != null) for (Feature feature : objects) distances(feature);
67 if ((objects = map.features.get(Obj.HULKES)) != null) for (Feature feature : objects) ports(feature);
68 if ((objects = map.features.get(Obj.CRANES)) != null) for (Feature feature : objects) ports(feature);
69 if ((objects = map.features.get(Obj.LNDMRK)) != null) for (Feature feature : objects) landmarks(feature);
70 if ((objects = map.features.get(Obj.MORFAC)) != null) for (Feature feature : objects) moorings(feature);
71 if ((objects = map.features.get(Obj.NOTMRK)) != null) for (Feature feature : objects) notices(feature);
72 if ((objects = map.features.get(Obj.SMCFAC)) != null) for (Feature feature : objects) marinas(feature);
73 if ((objects = map.features.get(Obj.BRIDGE)) != null) for (Feature feature : objects) bridges(feature);
74 if ((objects = map.features.get(Obj.LITMAJ)) != null) for (Feature feature : objects) lights(feature);
75 if ((objects = map.features.get(Obj.LITMIN)) != null) for (Feature feature : objects) lights(feature);
76 if ((objects = map.features.get(Obj.LIGHTS)) != null) for (Feature feature : objects) lights(feature);
77 if ((objects = map.features.get(Obj.SISTAT)) != null) for (Feature feature : objects) signals(feature);
78 if ((objects = map.features.get(Obj.SISTAW)) != null) for (Feature feature : objects) signals(feature);
79 if ((objects = map.features.get(Obj.CGUSTA)) != null) for (Feature feature : objects) signals(feature);
80 if ((objects = map.features.get(Obj.RDOSTA)) != null) for (Feature feature : objects) signals(feature);
81 if ((objects = map.features.get(Obj.RADSTA)) != null) for (Feature feature : objects) signals(feature);
82 if ((objects = map.features.get(Obj.RSCSTA)) != null) for (Feature feature : objects) signals(feature);
83 if ((objects = map.features.get(Obj.PILBOP)) != null) for (Feature feature : objects) signals(feature);
84 if ((objects = map.features.get(Obj.WTWGAG)) != null) for (Feature feature : objects) gauges(feature);
85 if ((objects = map.features.get(Obj.OFSPLF)) != null) for (Feature feature : objects) platforms(feature);
86 if ((objects = map.features.get(Obj.WRECKS)) != null) for (Feature feature : objects) wrecks(feature);
87 if ((objects = map.features.get(Obj.LITVES)) != null) for (Feature feature : objects) floats(feature);
88 if ((objects = map.features.get(Obj.LITFLT)) != null) for (Feature feature : objects) floats(feature);
89 if ((objects = map.features.get(Obj.BOYINB)) != null) for (Feature feature : objects) floats(feature);
90 if ((objects = map.features.get(Obj.BOYLAT)) != null) for (Feature feature : objects) buoys(feature);
91 if ((objects = map.features.get(Obj.BOYCAR)) != null) for (Feature feature : objects) buoys(feature);
92 if ((objects = map.features.get(Obj.BOYISD)) != null) for (Feature feature : objects) buoys(feature);
93 if ((objects = map.features.get(Obj.BOYSAW)) != null) for (Feature feature : objects) buoys(feature);
94 if ((objects = map.features.get(Obj.BOYSPP)) != null) for (Feature feature : objects) buoys(feature);
95 if ((objects = map.features.get(Obj.BOYWTW)) != null) for (Feature feature : objects) buoys(feature);
96 if ((objects = map.features.get(Obj.BCNLAT)) != null) for (Feature feature : objects) beacons(feature);
97 if ((objects = map.features.get(Obj.BCNCAR)) != null) for (Feature feature : objects) beacons(feature);
98 if ((objects = map.features.get(Obj.BCNISD)) != null) for (Feature feature : objects) beacons(feature);
99 if ((objects = map.features.get(Obj.BCNSAW)) != null) for (Feature feature : objects) beacons(feature);
100 if ((objects = map.features.get(Obj.BCNSPP)) != null) for (Feature feature : objects) beacons(feature);
101 if ((objects = map.features.get(Obj.BCNWTW)) != null) for (Feature feature : objects) beacons(feature);
102 }
103
104 private static void shoreline(Feature feature) {
105 CatSLC cat = (CatSLC) Renderer.getAttVal(feature, feature.type, 0, Att.CATSLC);
106 if (zoom >= 12) {
107 switch (cat) {
108 case SLC_TWAL:
109 WatLEV lev = (WatLEV) Renderer.getAttVal(feature, feature.type, 0, Att.WATLEV);
110 if (lev == WatLEV.LEV_CVRS) {
111 Renderer.lineVector(feature, new LineStyle(Color.black, 10, new float[] { 40, 40 }, null));
112 if (zoom >= 15)
113 Renderer.lineText(feature, "(covers)", new TextStyle(new Font("Arial", Font.PLAIN, 80)), 0.5, new Delta(Handle.TC, AffineTransform.getTranslateInstance(0, 20)));
114 } else {
115 Renderer.lineVector(feature, new LineStyle(Color.black, 10, null, null));
116 }
117 if (zoom >= 15)
118 Renderer.lineText(feature, "Training Wall", new TextStyle(new Font("Arial", Font.PLAIN, 80)), 0.5, new Delta(Handle.BC, AffineTransform.getTranslateInstance(0, -20)));
119 }
120 }
121 }
122 private static void pipelines(Feature feature) {
123 if (zoom >= 14) {
124 if (feature.type == Obj.PIPSOL) {
125 Renderer.lineSymbols(feature, Areas.Pipeline, 1.0, null, 0);
126 } else if (feature.type == Obj.PIPOHD) {
127
128 }
129 }
130 }
131 private static void cables(Feature feature) {
132 if (zoom >= 14) {
133 if (feature.type == Obj.CBLSUB) {
134 Renderer.lineSymbols(feature, Areas.Cable, 0.0, null, 0);
135 } else if (feature.type == Obj.CBLOHD) {
136
137 }
138 }
139 }
140 private static void separation(Feature feature) {
141 switch (feature.type) {
142 case TSEZNE:
143 case TSSCRS:
144 case TSSRON:
145 if (zoom <= 15)
146 Renderer.lineVector(feature, new LineStyle(null, 0, null, new Color(0x80c480ff, true)));
147 else
148 Renderer.lineVector(feature, new LineStyle(new Color(0x80c480ff, true), 20, null, null));
149 AttItem name = feature.atts.get(Att.OBJNAM);
150 if ((zoom >= 10) && (name != null))
151 Renderer.labelText(feature, (String) name.val, new TextStyle(new Font("Arial", Font.BOLD, 150)), null);
152 break;
153 case TSELNE:
154 Renderer.lineVector(feature, new LineStyle(new Color(0x80c480ff, true), 20, null, null));
155 break;
156 case TSSLPT:
157 Renderer.lineSymbols(feature, Areas.LaneArrow, 0.5, null, 0);
158 break;
159 case TSSBND:
160 Renderer.lineVector(feature, new LineStyle(new Color(0x80c480ff, true), 20, new float[] { 40, 40 }, null));
161 break;
162 }
163 }
164 private static void areas(Feature feature) {
165 AttItem name = feature.atts.get(Att.OBJNAM);
166 switch (feature.type) {
167 case SPLARE:
168 if (zoom >= 12) {
169 Renderer.symbol(feature, Areas.Plane, Obj.SPLARE, null);
170 Renderer.lineSymbols(feature, Areas.Restricted, 0.5, Areas.LinePlane, 10);
171 }
172 if ((zoom >= 15) && (name != null))
173 Renderer.labelText(feature, (String) name.val, new TextStyle(new Font("Arial", Font.BOLD, 80)), new Delta(Handle.BC, AffineTransform.getTranslateInstance(0, -90)));
174 break;
175 case MARCUL:
176 if (zoom >= 14)
177 Renderer.symbol(feature, Areas.MarineFarm, Obj.MARCUL, null);
178 if (zoom >= 16)
179 Renderer.lineVector(feature, new LineStyle( Color.black, 4, new float[] { 10, 10 }, null));
180 break;
181 case FAIRWY:
182 if (Renderer.calcArea(feature) > 2.0) {
183 if (zoom < 16)
184 Renderer.lineVector(feature, new LineStyle(new Color(0xc480ff), 8, new float[] { 50, 50 }, new Color(0x40ffffff, true)));
185 else
186 Renderer.lineVector(feature, new LineStyle(new Color(0xc480ff), 8, new float[] { 50, 50 }, null));
187 } else {
188 if (zoom >= 14)
189 Renderer.lineVector(feature, new LineStyle(new Color(0x40ffffff, true), 0, null, null));
190 }
191 break;
192 case DRGARE:
193 if (zoom < 16)
194 Renderer.lineVector(feature, new LineStyle(Color.black, 8, new float[] { 25, 25 }, new Color(0x40ffffff, true)));
195 else
196 Renderer.lineVector(feature, new LineStyle(Color.black, 8, new float[] { 25, 25 }, null));
197 if ((zoom >= 12) && (name != null))
198 Renderer.labelText(feature, (String) name.val, new TextStyle(new Font("Arial", Font.PLAIN, 100)), new Delta(Handle.BC, AffineTransform.getTranslateInstance(0, 0)));
199 break;
200 case RESARE:
201 if (zoom >= 12) {
202 Renderer.lineSymbols(feature, Areas.Restricted, 1.0, null, 0);
203 if ((CatREA)Renderer.getAttVal(feature, feature.type, 0, Att.CATREA) == CatREA.REA_NWAK)
204 Renderer.symbol(feature, Areas.NoWake, Obj.RESARE, null);
205 }
206 break;
207 case OSPARE:
208 if ((CatPRA)Renderer.getAttVal(feature, feature.type, 0, Att.CATPRA) == CatPRA.PRA_WFRM) {
209 Renderer.symbol(feature, Areas.WindFarm, Obj.OSPARE, null);
210 Renderer.lineVector(feature, new LineStyle(Color.black, 20, new float[] { 40, 40 }, null));
211 if ((zoom >= 15) && (name != null))
212 Renderer.labelText(feature, (String) name.val, new TextStyle(new Font("Arial", Font.BOLD, 80)), new Delta(Handle.TC, AffineTransform.getTranslateInstance(0, 10)));
213 }
214 break;
215 case SEAARE:
216 break;
217 case SNDWAV:
218// if (zoom>=12)) area("fill:url(#sandwaves)");
219 break;
220 }
221/*
222 if (is_type("sea_area")) {
223 if (has_attribute("category")) {
224 make_string("");
225 attribute_switch("category")
226 attribute_case("reach") { if (zoom >= 10) add_string("font-family:Arial;font-weight:normal;font-style:italic;font-size:150;text-anchor:middle") }
227 attribute_case("bay") { if (zoom >= 12) add_string("font-family:Arial;font-weight:normal;font-style:italic;font-size:150;text-anchor:middle") }
228 attribute_case("shoal") { if (zoom >= 14) {
229 if (is_area) {
230 area("stroke:#c480ff;stroke-width:4;stroke-dasharray:25,25;fill:none");
231 if (has_item_attribute("name")) text(item_attribute("name"), "font-family:Arial;font-weight:normal;font-style:italic;font-size:75;text-anchor:middle", 0, -40);
232 text("(Shoal)", "font-family:Arial;font-weight:normal;font-size:60;text-anchor:middle", 0, 0);
233 } else if (is_line) {
234 if (has_item_attribute("name")) way_text(item_attribute("name"), "font-family:Arial;font-weight:normal;font-style:italic;font-size:75;text-anchor:middle", 0.5, -40, line("stroke:none;fill:none"));
235 way_text("(Shoal)", "font-family:Arial;font-weight:normal;font-size:60;text-anchor:middle", 0.5, 0, line("stroke:none;fill:none"));
236 } else {
237 if (has_item_attribute("name")) text(item_attribute("name"), "font-family:Arial;font-weight:normal;font-style:italic;font-size:75;text-anchor:middle", 0, -40);
238 text("(Shoal)", "font-family:Arial;font-weight:normal;font-size:60;text-anchor:middle", 0, 0);
239 }
240 }
241 }
242 attribute_case("gat|narrows") { if (zoom >= 12) add_string("font-family:Arial;font-weight:normal;font-style:italic;font-size:100;text-anchor:middle") }
243 end_switch
244 if ((strlen(string) > 0) && !attribute_test("category", "shoal")) {
245 int ref = line("stroke:none;fill:none");
246 if (ref != 0) {
247 if (has_item_attribute("name")) way_text(item_attribute("name"), string, 0.5, 0, ref);
248 } else {
249 if (has_item_attribute("name")) text(item_attribute("name"), string, 0, 0);
250 }
251 }
252 free_string
253 }
254 }
255 */
256 }
257
258 private static void obstructions(Feature feature) {
259 if ((zoom >= 14) && (feature.type == Obj.UWTROC)) {
260 WatLEV lvl = (WatLEV) Renderer.getAttVal(feature, feature.type, 0, Att.WATLEV);
261 switch (lvl) {
262 case LEV_CVRS:
263 Renderer.symbol(feature, Areas.RockC, null, null);
264 break;
265 case LEV_AWSH:
266 Renderer.symbol(feature, Areas.RockA, null, null);
267 break;
268 default:
269 Renderer.symbol(feature, Areas.Rock, null, null);
270 }
271 } else {
272 Renderer.symbol(feature, Areas.Rock, null, null);
273 }
274 }
275 private static void waterways(Feature feature) {
276 if ((zoom >= 14) && (feature.atts.get(Att.OBJNAM) != null)) {
277 // lineText(item_attribute("name"), "font-family:Arial;font-weight:bold;font-size:80;text-anchor:middle", 0.5, 15, line("stroke:none;fill:none"));
278 }
279 }
280 private static void transits(Feature feature) {
281 }
282 private static void harbours(Feature feature) {
283 }
284 private static void locks(Feature feature) {
285 }
286 private static void distances(Feature feature) {
287 }
288 private static void ports(Feature feature) {
289 }
290 private static void landmarks(Feature feature) {
291 ArrayList<CatLMK> cats = (ArrayList<CatLMK>) Renderer.getAttVal(feature, feature.type, 0, Att.CATLMK);
292 Symbol catSym = Landmarks.Shapes.get(cats.get(0));
293 ArrayList<FncFNC> fncs = (ArrayList<FncFNC>) Renderer.getAttVal(feature, feature.type, 0, Att.FUNCTN);
294 Symbol fncSym = Landmarks.Funcs.get(fncs.get(0));
295 if ((fncs.get(0) == FncFNC.FNC_CHCH) && (cats.get(0) == CatLMK.LMK_TOWR))
296 catSym = Landmarks.ChurchTower;
297 if ((cats.get(0) == CatLMK.LMK_UNKN) && (fncs.get(0) == FncFNC.FNC_UNKN) && (feature.objs.get(Obj.LIGHTS) != null))
298 catSym = Beacons.LightMajor;
299 if (cats.get(0) == CatLMK.LMK_RADR)
300 fncSym = Landmarks.RadioTV;
301 Renderer.symbol(feature, catSym, null, null);
302 Renderer.symbol(feature, fncSym, null, null);
303 }
304 private static void moorings(Feature feature) {
305 CatMOR cat = (CatMOR) Renderer.getAttVal(feature, feature.type, 0, Att.CATMOR);
306 switch (cat) {
307 case MOR_DLPN:
308 Renderer.symbol(feature, Harbours.Dolphin, null, null);
309 break;
310 case MOR_DDPN:
311 Renderer.symbol(feature, Harbours.DeviationDolphin, null, null);
312 break;
313 case MOR_BLRD:
314 case MOR_POST:
315 Renderer.symbol(feature, Harbours.Bollard, null, null);
316 break;
317 case MOR_BUOY:
318 BoySHP shape = (BoySHP) Renderer.getAttVal(feature, feature.type, 0, Att.BOYSHP);
319 if (shape == BoySHP.BOY_UNKN)
320 shape = BoySHP.BOY_SPHR;
321 Renderer.symbol(feature, Buoys.Shapes.get(shape), feature.type, null);
322 break;
323 }
324 }
325 private static void notices(Feature feature) {
326 }
327 private static void marinas(Feature feature) {
328 }
329 private static void bridges(Feature feature) {
330 }
331 private static void wrecks(Feature feature) {
332 if (zoom >= 14) {
333 CatWRK cat = (CatWRK) Renderer.getAttVal(feature, feature.type, 0, Att.CATWRK);
334 switch (cat) {
335 case WRK_DNGR:
336 case WRK_MSTS:
337 Renderer.symbol(feature, Areas.WreckD, null, null);
338 break;
339 case WRK_HULS:
340 Renderer.symbol(feature, Areas.WreckS, null, null);
341 break;
342 default:
343 Renderer.symbol(feature, Areas.WreckND, null, null);
344 }
345 } else {
346 Renderer.symbol(feature, Areas.WreckND, null, null);
347 }
348 }
349 private static void gauges(Feature feature) {
350 }
351 private static void lights(Feature feature) {
352 switch (feature.type) {
353 case LITMAJ:
354 Renderer.symbol(feature, Beacons.LightMajor, null, null);
355 break;
356 case LITMIN:
357 case LIGHTS:
358 Renderer.symbol(feature, Beacons.LightMinor, null, null);
359 break;
360 }
361 }
362 private static void signals(Feature feature) {
363 switch (feature.type) {
364 case SISTAT:
365 case SISTAW:
366 Renderer.symbol(feature, Harbours.SignalStation, null, null);
367 break;
368 case RDOSTA:
369 Renderer.symbol(feature, Harbours.SignalStation, null, null);
370 break;
371 case RADSTA:
372 Renderer.symbol(feature, Harbours.SignalStation, null, null);
373 Renderer.symbol(feature, Beacons.RadarStation, null, null);
374 break;
375 case PILBOP:
376 Renderer.symbol(feature, Harbours.Pilot, null, null);
377 break;
378 case CGUSTA:
379 Renderer.symbol(feature, Harbours.SignalStation, null, null);
380 break;
381 case RSCSTA:
382 Renderer.symbol(feature, Harbours.Rescue, null, null);
383 break;
384 }
385 }
386 private static void floats(Feature feature) {
387 switch (feature.type) {
388 case LITVES:
389 Renderer.symbol(feature, Buoys.Super, feature.type, null);
390 break;
391 case LITFLT:
392 Renderer.symbol(feature, Buoys.Float, feature.type, null);
393 break;
394 case BOYINB:
395 Renderer.symbol(feature, Buoys.Storage, feature.type, null);
396 break;
397 }
398 if (feature.objs.get(Obj.TOPMAR) != null)
399 Renderer.symbol(feature, Topmarks.Shapes.get(feature.objs.get(Obj.TOPMAR).get(0).get(Att.TOPSHP).val), Obj.TOPMAR, Topmarks.Floats);
400 }
401 private static void platforms(Feature feature) {
402 Renderer.symbol(feature, Landmarks.Platform, null, null);
403 }
404 private static void buoys(Feature feature) {
405 BoySHP shape = (BoySHP) Renderer.getAttVal(feature, feature.type, 0, Att.BOYSHP);
406 Renderer.symbol(feature, Buoys.Shapes.get(shape), feature.type, null);
407 if (feature.objs.get(Obj.TOPMAR) != null) {
408 Renderer.symbol(feature, Topmarks.Shapes.get(feature.objs.get(Obj.TOPMAR).get(0).get(Att.TOPSHP).val), Obj.TOPMAR, Topmarks.Buoys.get(shape));
409 }
410 }
411 private static void beacons(Feature feature) {
412 BcnSHP shape = (BcnSHP) Renderer.getAttVal(feature, feature.type, 0, Att.BCNSHP);
413 if (((shape == BcnSHP.BCN_PRCH) || (shape == BcnSHP.BCN_WTHY)) && (feature.type == Obj.BCNLAT)) {
414 CatLAM cat = (CatLAM) Renderer.getAttVal(feature, feature.type, 0, Att.CATLAM);
415 switch (cat) {
416 case LAM_PORT:
417 if (shape == BcnSHP.BCN_PRCH)
418 Renderer.symbol(feature, Beacons.PerchPort, null, null);
419 else
420 Renderer.symbol(feature, Beacons.WithyPort, null, null);
421 break;
422 case LAM_STBD:
423 if (shape == BcnSHP.BCN_PRCH)
424 Renderer.symbol(feature, Beacons.PerchStarboard, null, null);
425 else
426 Renderer.symbol(feature, Beacons.WithyStarboard, null, null);
427 break;
428 default:
429 Renderer.symbol(feature, Beacons.Stake, feature.type, null);
430 }
431 } else {
432 Renderer.symbol(feature, Beacons.Shapes.get(shape), feature.type, null);
433 if (feature.objs.get(Obj.TOPMAR) != null)
434 Renderer.symbol(feature, Topmarks.Shapes.get(feature.objs.get(Obj.TOPMAR).get(0).get(Att.TOPSHP).val), Obj.TOPMAR, Topmarks.Beacons);
435 }
436 }
437}
Note: See TracBrowser for help on using the repository browser.