[fdo-internals] RE: FDO RFC 48 - Polygon Vertex Order is ready
for review.
Leaf Li
leaf.li at autodesk.com
Sun Jul 11 21:53:58 EDT 2010
Hi Traian,
Thanks for you question. I answer them in lines.
Thanks,
Leaf Li
Date: Thu, 8 Jul 2010 21:55:35 -0700
From: Traian Stanev <traian.stanev at autodesk.com>
Subject: RE: [fdo-internals] FDO RFC 48 - Polygon Vertex Order is
ready for review.
To: "'fdo-internals at lists.osgeo.org'" <fdo-internals at lists.osgeo.org>
Message-ID:
<D20FC5C02CA4AB41891CFE76D91C57A970718D0962 at ADSK-NAMSG-02.MGDADSK.autodesk.com>
Content-Type: text/plain; charset="us-ascii"
Hi
I have some concerns with the class capabilities part of the RFC.
The class capabilities will introduce the vertex order hint and the strictness setting. Introducing the vertex order hint will result in many existing SDF files (for example) having the "wrong" vertex order, since there are many SDF files which started life as SHP files.
[Leaf] I agree that the vertex order is a hint if the strictness isn't enforced. However. the "wrong" vertex order isn't caused by introducing the vertex order. They are wrong because they polygon geometry doesn't follow the vertex order rule defined by feature source. Because the vertex order is a hint, whether the vertex order is "wrong" or "correct" is a hint too if the strictness isn't enforced. If you want, you can keep FDO geometry as is. Vertex order rule defined in the class capabilities will not force you do anything.
The above means that having the vertex order hint is not useful for many SDF files (and also many SHP files written out by applications which don't enforce winding order, and also other formats), and the consuming application will have to fix the vertex order if it really cares. MapGuide for example does not care - it can render polygons with any winding you give it. So the vertex order hint seems like it will only add confusion. An application which does care will have to ignore the vertex order capability, since it is not really true (as described above). Hence the vertex order setting is not useful for both applications which do care about vertex order and for applications which don't care about it.
[Leaf] Solution proposed in this RFC isn't to provide a tool to fix the vertex order "error" of a feature. I already mentioned in RFC that we are not going to change the current strategy of FDO Provider to fix polygon vertex order error automatically by FDO Provider. However, users can create a tool to fix the polygon order errors based on vertex order and strictness rule defined in the class capabilities and two utility methods provided in class FdoSpatialUtility.
So my answer to your question is that you create a simple method to fix the polygon vertex order error based on RFC 48 if you care about the vertex order. If not, RFC 48 doesn't change your application at all and just ignore it.
The strictness hint is also problematic. Most providers will use the "not enforced" setting, which means that you can still store any kind of polygon in them. In fact only one data source (and not in all cases) requires strict vertex order - SQL Server. All other cases would mean per-provider coding of strictness enforcement in case we want "enforced" vertex order.
[Leaf] Hard-coding vertex order rule and strictness rule at FDO client application is doable. If the client application handle one kind of data source, it isn't too bad. However, it is a bad idea if the client application handle many types of data source. FDO API should have capability to tell user what the current FDO provider's vertex order and strictness rule are.
Yes. Currently we found SQL Server Spatial is really enforced only. However, we may find more enforced feature source in the future when introducing more and more FDO provider. So how to handle it at that time for the FDO client application? Hard-coded again?
Moreover, I am thinking changing SHP enforced we get lots of complain from users about the wrong vertex order in SHP file. Actually FME SHP FDO Provider is a strict feature source because it corrects the vertex order of polygons when inserting and modifying a feature.
Currently, my suggestions for their capabilities are as follows.
Provider Vertex Order Strictness
WFS CCW Not enforced
SQLite CCW Not enforced
SHP CW Enforced
SDF CCW Not enforced
ArcSDE CCW Not enforced
ODBC None Not enforced
MySQL CCW Not enforced
PostGIS CCW Not enforced
Oracle CCW Not enforced
SQLSpatial
Geometry CCW Not enforced
Geography CCW Enforced
OGR
SHP CW Enforced
Others CCW Not enforced
So, if the capability provides no correct information about vertex order and no meaningful enforcement of vertex order, is it needed at all?
[Leaf] They are meaningful. Please see my comments above.
Traian
From: fdo-internals-bounces at lists.osgeo.org [mailto:fdo-internals-bounces at lists.osgeo.org] On Behalf Of Leaf Li
Sent: Tuesday, July 06, 2010 6:15 AM
To: fdo-internals at lists.osgeo.org
Subject: [fdo-internals] FDO RFC 48 - Polygon Vertex Order is ready for review.
All,
FDO RFC 48 - Polygon Vertex Order is ready for review. Can you review it?
http://trac.osgeo.org/fdo/wiki/FDORfc48
Thanks,
Leaf Li
More information about the fdo-internals
mailing list