[mkgmap-dev] Multipolygons and disappearing coastlines
From WanMil wmgcnfg at web.de on Sun Dec 27 14:29:36 GMT 2009
> > Hi Chris, > >> Mark Burton schrieb: >> >>> So, is putting the coastline into a multipolygon a reasonable OSM >>> thing? >> >> A coastline is often also a boundary and boundaries are >> multipolygons in OSM. >> >>> If so, should mkgmap be breaking the coastline by removing its >>> tags? If not, how do we fix that? >> >> My guess is, that the multipolygon handling in mkgmap is not working >> perfectly. >> >> See an older thread on this list where I suggest a >> workaround. (I check if the MP has no inner elements >> and change the type=multipolygon to type=boundarypolygon >> if this is the case). >> >> Chris > > OK, that's understood. > > But why do we have to trash the original ways when we make a > multipolygon from them? Would it not be better to give the relation a > duplicate of the way to trash so that the original way can go on to > serve its original purpose. Perhaps we should do this: > > diff --git a/src/uk/me/parabola/mkgmap/reader/osm/xml/Osm5XmlHandler.java b/src/uk/me/parabola/mkgmap/reader/osm/xml/Osm5XmlHandler.java > index acc5cf9..fbb1d57 100644 > --- a/src/uk/me/parabola/mkgmap/reader/osm/xml/Osm5XmlHandler.java > +++ b/src/uk/me/parabola/mkgmap/reader/osm/xml/Osm5XmlHandler.java > @@ -266,10 +266,12 @@ class Osm5XmlHandler extends DefaultHandler { > private void startInRelation(String qName, Attributes attributes) { > if (qName.equals("member")) { > long id = idVal(attributes.getValue("ref")); > - Element el; > + Element el = null; > String type = attributes.getValue("type"); > - if ("way".equals(type)){ > - el = wayMap.get(id); > + if ("way".equals(type)) { > + Way way = wayMap.get(id); > + if(way != null) > + el = way.duplicate(); > } else if ("node".equals(type)) { > el = nodeMap.get(id); > if(el == null) { > > I just tried this patch and (just like magic) the coastline reappears. > > Cheers, > > Mark Hi Mark, I didn't try your patch but the idea is good. It is also more compliant to the rules described in the OSM wiki (http://wiki.openstreetmap.org/wiki/Multipolygon#Tagging) than the current implementation. Mulitpolygon code should be reimplemented soon. As far as I am quite new to mkgmap I will need some time to do this. At the moment I see the following things to do: 1. Only simple polygons are supported. Lots of options described in http://wiki.openstreetmap.org/wiki/Multipolygon#Advanced_multipolygons are not implemented. I think the algorithm in the OSM wiki (http://wiki.openstreetmap.org/wiki/Relation:multipolygon/Algorithm) is a good starting point to make mkgmap implementation compatible. Some rules about tagging are also described there. 2. The PolygonSplitter destroys the polygons created by the current multipolygon code. Up to now I do not fully understand if thats a problem or not. But I would feel better if someone could replace the usage of the java.awt.Area class with some code that does not remove the mulitpolygon connections between outer and inner rings. 3. Up to now the MultiPolygonRelation class does support one outer ring only. This must be changed so that the MultiPolygonRelation class can create multiple polygons in the garmin format. I do not fully understand how the Garmin map is assembled from the mkgmap map format, so any hint is appreciated. WanMil
- Previous message: [mkgmap-dev] Multipolygons and disappearing coastlines
- Next message: [mkgmap-dev] Multipolygons and disappearing coastlines
- Messages sorted by: [ date ] [ thread ] [ subject ] [ author ]
More information about the mkgmap-dev mailing list