Ignore:
Timestamp:
2014-02-14T19:48:40+01:00 (11 years ago)
Author:
malcolmh
Message:

save

File:
1 edited

Legend:

Unmodified
Added
Removed
  • applications/editors/josm/plugins/smed2/js57toosm/src/js57toosm/Js57toosm.java

    r30269 r30279  
    1111
    1212import java.io.*;
     13import java.util.Iterator;
    1314import java.util.Map;
    1415
     16import s57.S57map.Prim;
    1517import s57.S57obj;
    1618import s57.S57att;
     
    4749                int pos;
    4850                boolean inFeature = false;
    49                
     51
    5052                double comf = 1;
    5153                double somf = 1;
     
    155157                                                S57dat.setField(record, fields + pos, S57field.VRPT, len);
    156158                                                do {
    157                                                         name = (Long) S57dat.getSubf(S57subf.NAME) << 16;
     159                                                        long conn = (Long) S57dat.getSubf(S57subf.NAME) << 16;
    158160                                                        int topi = ((Long) S57dat.getSubf(S57subf.TOPI)).intValue();
    159                                                         map.addConn(name, topi);
     161                                                        map.addConn(conn, topi);
    160162                                                        S57dat.getSubf(S57subf.MASK);
    161163                                                } while (S57dat.more());
     
    208210                map.endFile();
    209211                in.close();
    210                
     212
    211213                out.println("<?xml version='1.0' encoding='UTF-8'?>");
    212214                out.println("<osm version='0.6' generator='js57toosm'>");
    213                 out.println("<bounds minlat='" + minlat +"' minlon='" + minlon + "' maxlat='" + maxlat + "' maxlon='" + maxlon + "'/>");
    214                
     215                out.println("<bounds minlat='" + minlat + "' minlon='" + minlon + "' maxlat='" + maxlat + "' maxlon='" + maxlon + "'/>");
     216
    215217                for (long id : map.index.keySet()) {
    216218                        Feature feature = map.index.get(id);
     
    236238                        }
    237239                }
    238                
    239 //int i = 256;
    240240                for (long id : map.index.keySet()) {
    241 //if (i-- == 0) break;
    242241                        Feature feature = map.index.get(id);
    243242                        String type = S57obj.stringType(feature.type);
    244243                        if (!type.isEmpty()) {
    245244                                if (feature.reln == Rflag.MASTER) {
    246                                         if ((feature.geom.prim == Pflag.LINE) || ((feature.geom.prim == Pflag.AREA) && (feature.geom.outers == 1) && (feature.geom.inners == 0))) {
     245                                        if (feature.geom.prim == Pflag.LINE) {
    247246                                                GeomIterator git = map.new GeomIterator(feature.geom);
    248                                                 while (git.hasMore()) {
    249                                                         git.getMore();
    250                                                         while (git.hasNext()) {
    251                                                                 long ref = git.nextRef();
    252                                                                 Snode node = map.nodes.get(ref);
    253                                                                 if (node != null) {
    254                                                                         out.format("  <node id='%d' lat='%.8f' lon='%.8f' version='1'/>%n", -ref, Math.toDegrees(node.lat), Math.toDegrees(node.lon));
    255                                                                         map.nodes.remove(ref);
     247                                                while (git.hasComp()) {
     248                                                        git.nextComp();
     249                                                        while (git.hasEdge()) {
     250                                                                git.nextEdge();
     251                                                                while (git.hasNode()) {
     252                                                                        long ref = git.nextRef();
     253                                                                        Snode node = map.nodes.get(ref);
     254                                                                        if (node != null) {
     255                                                                                out.format("  <node id='%d' lat='%.8f' lon='%.8f' version='1'/>%n", -ref, Math.toDegrees(node.lat), Math.toDegrees(node.lon));
     256                                                                                map.nodes.remove(ref);
     257                                                                        }
    256258                                                                }
    257259                                                        }
    258260                                                }
    259261                                                git = map.new GeomIterator(feature.geom);
    260                                                 while (git.hasMore()) {
    261                                                         long way = git.getMore();
     262                                                while (git.hasComp()) {
     263                                                        long way = git.nextComp();
    262264                                                        out.format("  <way id='%d' version='1'>%n", -way);
    263                                                         while (git.hasNext()) {
    264                                                                 long ref = git.nextRef();
    265                                                                 out.format("    <nd ref='%d'/>%n", -ref);
    266                                                         }
    267                                                         out.format("    <tag k='seamark:type' v=\"%s\"/>%n", type);
    268                                                         writeAtts(feature, type);
     265                                                        while (git.hasEdge()) {
     266                                                                git.nextEdge();
     267                                                                while (git.hasNode()) {
     268                                                                        long ref = git.nextRef();
     269                                                                        out.format("    <nd ref='%d'/>%n", -ref);
     270                                                                }
     271                                                                out.format("    <tag k='seamark:type' v=\"%s\"/>%n", type);
     272                                                                writeAtts(feature, type);
     273                                                        }
    269274                                                        out.format("  </way>%n");
    270275                                                }
    271276                                        } else if (feature.geom.prim == Pflag.AREA) {
    272 
     277                                                GeomIterator git = map.new GeomIterator(feature.geom);
     278                                                while (git.hasComp()) {
     279                                                        git.nextComp();
     280                                                        while (git.hasEdge()) {
     281                                                                git.nextEdge();
     282                                                                while (git.hasNode()) {
     283                                                                        long ref = git.nextRef();
     284                                                                        Snode node = map.nodes.get(ref);
     285                                                                        if (node != null) {
     286                                                                                out.format("  <node id='%d' lat='%.8f' lon='%.8f' version='1'/>%n", -ref, Math.toDegrees(node.lat), Math.toDegrees(node.lon));
     287                                                                                map.nodes.remove(ref);
     288                                                                        }
     289                                                                }
     290                                                        }
     291                                                }
     292                                                git = map.new GeomIterator(feature.geom);
     293                                                while (git.hasComp()) {
     294                                                        long way = git.nextComp();
     295                                                        out.format("  <way id='%d' version='1'>%n", -way);
     296                                                        while (git.hasEdge()) {
     297                                                                git.nextEdge();
     298                                                                while (git.hasNode()) {
     299                                                                        long ref = git.nextRef();
     300                                                                        out.format("    <nd ref='%d'/>%n", -ref);
     301                                                                }
     302                                                        }
     303                                                        out.format("  </way>%n");
     304                                                }
     305                                                out.format("  <relation id='%d' version='1'>%n", -map.ref++);
     306                                                out.format("    <tag k='type' v='multipolygon'/>%n");
     307                                                int i = 0;
     308                                                for (Comp comp : feature.geom.refs) {
     309                                                        if (i++ < feature.geom.outers) {
     310                                                                out.format("    <member type='way' ref='%d' role='outer'/>%n", -comp.ref);
     311                                                        } else {
     312                                                                out.format("    <member type='way' ref='%d' role='inner'/>%n", -comp.ref);
     313                                                        }
     314                                                }
     315                                                out.format("    <tag k='seamark:type' v=\"%s\"/>%n", type);
     316                                                writeAtts(feature, type);
     317                                                out.format("  </relation>%n");
    273318                                        }
    274319                                }
Note: See TracChangeset for help on using the changeset viewer.