<p dir="ltr">Hi Martin,</p>
<p dir="ltr">I think the OSM plugin has to be improved, and it's a good news if you have started a new architecture.</p>
<p dir="ltr">Can the plugin be extracted from the core?</p>
<p dir="ltr">For the edit purpose, I think it's an important feature because gis user don't want to use an other software than the one they use for gis data. ArcGIS users are happy to have an OSM plugin to update data.<br>
But if the new OSM plugin can be regularly updated, it can start without.</p>
<p dir="ltr">Cheers,<br>
René-Luc</p>
<div class="gmail_quote">Le 1 févr. 2013 01:26, "Martin Dobias" <<a href="mailto:wonder.sk@gmail.com">wonder.sk@gmail.com</a>> a écrit :<br type="attribution"><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex">
Hi<br>
<br>
recently I have started to think about the future of the OpenStreetMap<br>
plugin we currently ship with QGIS. The plugin (~2K lines of c++ and<br>
~6K lines of python) supports downloading, viewing, editing and<br>
uploading OSM data. My concern is that it has received little to no<br>
updates from the time we have imported it to QGIS tree back in<br>
mid-2009. Given that it is not being maintained and the issue tracker<br>
reveals several major bugs, I have started to wonder how useful it<br>
actually is in its current form and what could we do about it.<br>
<br>
There are few other things apart from lack of maintenance that need fixing:<br>
- it has a special provider because data are stored in custom sqlite3 DB<br>
- data access logic is spread through either provider and plugin<br>
- working with tags (aka attributes) is VERY inefficient<br>
- there's no API that could be used for scripting / analyses<br>
- it mixes topology with simple features<br>
- using custom hardcoded old symbology renderer<br>
- some hacks here and there (e.g. messaging from long-running XML<br>
import in provider, "all tags" attribute)<br>
<br>
Currently my thoughts are that we should simply remove the plugin<br>
because fixing its problems would need huge amount of time. In<br>
meanwhile I have started to play with an idea of fixing the<br>
architecture with the following ideas:<br>
1. import from XML to database should only import the topological<br>
structure and tags (and relations), without post-processing that would<br>
create simple features representations.<br>
2. instead of having a special provider, we could reuse an existing<br>
provider for viewing OSM layers - SpatiaLite seems to be the most<br>
viable candidate. Once data is imported from XML into a database, it<br>
should be possible to create one or more views (SpatiaLite tables) of<br>
the database (e.g. all polygons or linestrings with "highway" tag)<br>
3. OSM-related code should be in analysis library. providing<br>
c++/python API. In this way, other plugins/scripts could do automatic<br>
processing without having to deal directly with OSM XML or some<br>
database calls. Extraction of data should require just few lines of<br>
code.<br>
<br>
I have a working proof of concept (<1K lines of code) and it looks<br>
good - it's fairly simple and fast. For example, import of Essex<br>
county data (2135K nodes, 203K ways, XML size 420MB), including<br>
creation of SpatiaLite layers took less than 3 minutes, the subsequent<br>
map viewing was as fast as any other SpatiaLite data. There's just one<br>
catch (there always is, right?) - it does not support editing and I am<br>
not even considering adding it myself. OSM editor would be a big<br>
project and it would take ages to get at least close to the editing<br>
experience of specialized editors such as Potlatch or JOSM. And<br>
frankly, is there anyone using QGIS OSM plugin for editing?<br>
<br>
What are your thoughts and wishes on QGIS - OpenStreetMap integration?<br>
<br>
Regards<br>
Martin<br>
_______________________________________________<br>
Qgis-developer mailing list<br>
<a href="mailto:Qgis-developer@lists.osgeo.org">Qgis-developer@lists.osgeo.org</a><br>
<a href="http://lists.osgeo.org/mailman/listinfo/qgis-developer" target="_blank">http://lists.osgeo.org/mailman/listinfo/qgis-developer</a><br>
</blockquote></div>