ODK geoshape/geotrace/geopoint to WKT

After kml export by @Xiphware and geojson export by @detrygeoffroy, I simply adapted @Xiphware example forms to generate wkt (point, linestring, polygon) from geopoint, geotrace and geoshape odk fields.
In opposition to geojson and kml, WKT does only describes the geometry, it does not contains any attribute value.

So you can collect data and open exported CSV within QGIS with "delimited text layer" tool, choose the column which store wkt, select the projection (4326) and show you data on the map.

Here are the example forms :
geoshape2wkt.xls (8 KB) geopoint2wkt.xls (7 KB) geotrace2wkt.xls (8 KB)

Thanks a lot @Xiphware & @detrygeoffroy for your work.

I only had to make some search / replace and adapt concat() function :slight_smile:

7 Likes

Another alternative is this QGIS plugin that has been developed to deal with this issue.

1 Like

Follow Up Question:
The "geoshape2wkt.xls" code shared works very well. Thank you.
However, when testing on a larger area (1 hour perimeter walk generating around 300 GPS points) we have found difficulty in 'saving' the data on the tablet. The tablet requires us to 'swipe left' for each GPS point recorded, which can take a very long time for large areas.
Q: Is there a way to avoid having to swipe left for each and every coordinate recorded?
Thank you,

Hi @davidbaines,
could you share you form on the forum ?

Hi, @mathieubossaert I'm also facing a similar issue. My form recorded a geo shape successfully which is linked to my Postgres database, When I connect it to Q-GIS it sees it at a database table. How can I see it as polygons on Q-GIS.
Thanks

Hi @Senyo_Aborgah ,
I am quite busy for the next few days so I'll take a look later about why "swipe" is needed :frowning:
About showing WKT as geometry into QGIS, as far as I know it is only possible with "delimited text" data sources.
If you are using (PostGIS) you should create a view to show a geom column using ST_GeomFromText() function https://postgis.net/docs/ST_GeomFromText.html

Hi @davidbaines,
the problem is due to the note widget that displays current edge's coordinates :wink:
I forgot to drop it...
Simply drop it and it will be ok.

1 Like

Hello Mathieu,
That's great. It works much better now.
Thank you for your help, it is very much appreciated.
With very best wishes,
David Baines

1 Like

:wink: I do think so !

You're welcome.

1 Like

Hello Mathieu,
I trust you are well. (France played well yesterday!)
Attached is the most recent version of our generic Land Use Survey in ODK format. It currently automatically calculates the surface area of the Geoshape recorded in the form.
Q: Could you advise on the ODK code we should use to add an automated calculation for the 'perimeter' of the same geoshape?
C1.Land_Use_Survey_Generic_v7.xlsx (48.8 KB)

Merci Mathieu,

1 Like

See distance() function:

Returns the distance, in meters, of either:

    a nodeset of geopoints
    *the perimeter of a geoshape*
    the length of a geotrace value

It takes into account the circumference of the Earth around the Equator and does not take altitude into account.
1 Like

Thanks @davidbaines for sharing your form.
@Xiphware was faster :slight_smile:

Thanks so much. It worked perfectly.
So sorry for the late reply.

1 Like

Hello Mathieu,
Trust you are well.
I recently posted another question on the ODK forum - thought you might be interested:

Hi David,

I am fine thank you ! Hope you too.
I will spend some time tomorrow during a train trip on ODK (Central french translation to complete) I will try to understand the origin of the problem.
Could you provide some raw string data for both working and not working polygons ? I will see if we could automatically clean it or at least use it.

Thanks to @Xiphware explanations here :

I had a test to handle cases when geo strings contains '; ' as separator instead of the only semicolon.
This problem occurs sometimes and @davidbaines faced it here :

In such cases, point can be considered as a space-separated list of values with one more space and one more column index.
geoshape2wkt.xls (8 KB)

1 Like

What I'd like to do is be able to collect 1 to many geotraces or geoshapes, and wrap those up as MULTILINESTRING / MULTIPOLYGON outputs (and then at the end combine all point/trace/shape to a GEOMETRYCOLLECTION)

I started with @mathieubossaert's example, adding a repeat to allow multiple traces, but when I try to calculate the string inside the trace repeat, it uses all line vertices from every line, (so if line 1 = A to B to B and line 2 = line D to E, then it returns line 1 = A to B to C to D to E and line 2 = A to B to C to D to E)

I think the solution lies in how to refer to / constrain particular repeat elements (i.e. only take child repeat coordinates if their parent repeat instance = this instance) unless there's a simpler approach to the problem altogether?

Combining points to MULTIPOINT was simpler, and combining the MULTIPOINT with a LINESTRING etc to a GEOMETRYCOLLECTION is also simple.

This is the example, but incorrect form:
multiline_example.xlsx (20.3 KB)

Form output for 4 points and 2x 2 point lines becomes 4x points and 2x identical 4 point lines:

GEOMETRYCOLLECTION(MULTIPOINT Z ((-65.442744 9.232249 0),(-79.483427 -7.111795 0),(-34.553242 -7.340675 0),(-68.952915 -54.489187 0)), MULTILINESTRING Z((-16.300355 14.317615 0,48.261695 8.809082 0,6.866771 35.038992 0,22.322431 -34.152727 0),(-16.300355 14.317615 0,48.261695 8.809082 0,6.866771 35.038992 0,22.322431 -34.152727 0)))

Hi @ahblake,
I would like to well understand your need ? Note sure to be able to achieve it...

You want to merge the objects from each repeat into one single "MULTIxxx" ?
And at the end of the form get a "GEOMETRYCOLLECTION" with the MULTIxxx ?

Yes, what I'd like to do is have repeats for each geotype (point/line/shape) so the enumerator can add as many as required (eg place a point for all corrosion hole anomalies, trace a line along each affected pipe section, draw a shape around all affected areas).

Then bundle each type into a MULTIxxx, and bundle those into a collection, such that the parent submission has all the geo elements wrapped up in a single string. This means I can handle having any number of each geotype finding and won't have to pull the child repeat elements to get the details (unless they also have additional fields associated with them) as they're in GEOMETRYCOLLECTION in the parent form.

The part I'm stuck on is how to create the MULTILINESTRING and MULTIPOLYGON by referring to the particular repeat instances. I have already done the MULTIPOINT and GEOMETRYCOLLECTION steps.

From the above example, the correct output for the MULTILINESTRING would be:

MULTILINESTRING Z((-16.300355 14.317615 0,48.261695 8.809082 0) ,( 6.866771 35.038992 0,22.322431 -34.152727 0))

Hi @mathieubossaert
geoshape2wkt.xlsx (10.1 KB)
,
I am also looking for a solution. if you see the attached form. the output I am receiving from two repeated geoshape form is as Multipolygon((A B, C D, E F, A B, I J, K L, M N, I J)).
where A,B,C etc are longitude and latitude.
problem: I cannot group the output of a single repeated loop.

What I want:- Multipolygon(((A B, C D, E F, A B)), ((I J, K L, M N, I J))).
your help would be great for me.