Frage zur Library JTS

Hi,

sind hier irgendwelche JTS-Gurus?

JTS Topology Suite - Wikipedia, the free encyclopedia

Ich benötige für meine Berechnungen einen Merge eines LineStrings mit einer Koordinate (also einem einzelnen Punkt). Mein Problem ist, daß ich zwar aus einer mehrelementigen und einer einelementen Liste an Koordinaten einen gemeinsamen LineString bilden kann, doch der zusätzliche Punkt ist dann in der Liste nicht sortiert und bildet vom Endpunkt des alten LineString eine zusätzliche Strecke zu dem zusätzlichen Punkt, der sich aber genau auf der Strecke des alten LineString befindet.

Leider hab ich bisher keine Funktion gefunden, die mir eben aus einem LineString und einer Koordinate (einem Punkt) einen fusionierten LineString bildet, bei dem die Koordinaten sortiert sind.

Vielen Dank
 

knilch

Bekanntes Mitglied
Hi,
...bei dem die Koordinaten sortiert sind.
Bei Collections (List, Map, Set (und deren Implementierungen wie ArrayList, HashMap etc.) kannst du die Elemente sortieren. Dabei gibt es eine Möglichkeit, indem du eine Klasse erstellst, die das Comparator- oder das Comparable- Interface implementiert. In dieser Klasse wird dann die Methode überschrieben welche die Sortierung nach deinem Wunsch durchführt.
Comparator- Interface:
Java:
compare(Object o1, Object o2) { ... }

Comparable- Interface:
Java:
compareTo(Object o){...}
In diesen Mehtoden kannst du defnieren, wie die Elemente der Liste, Set oder Map sortiert werden sollen.
In der Klasse, in der dann die Liste benötigt wird, wird bevor die Elmente benutzt werden, die Liste sortiert und dabei die Klasse, die das Comparator- Interface implementiert, als "Sortier-Kriterium" mitgegeben:
Java:
....
// die liste wird gefüllt.
...
// die liste wird sortiert.
Collections.sort(liste, new ListComparator());
...
// nun ist die Liste sortiert und kann weiterbenutzt werden.

Hier ist ein Link in dem beschrieben ist, wie es gemacht werden kann.
 
Zuletzt bearbeitet:

turtle

Top Contributor
JTS, wow damit habe ich mal vor x-Jahren was gemacht. Daher alles, was ich sage, mit Vorsicht zu "geniessen";)
einem LineString und einer Koordinate (einem Punkt) einen fusionierten LineString bildet, bei dem die Koordinaten sortiert sind.
Das kommt mir komisch vor. Natürlich kann es keinen LineString geben, bei denen die Koordinaten sortiert sind. Denn eine Line ist doch eine Abfolge von Linienelementen (Stückchen) die zusammen einen gesamten Linienzug ausmachen. Da ist natürlich die Reihenfolge der Geradenstückchen absolut entscheidend.

Daher kommt mir auch eine Linie zusammen mit einem Punkt komisch vor. Denn der Punkt alleine, ist ja noch kein "Geradenstückchen".

Ich meine mich zu erinneren, das mein GIS verschiedene Grafik-Layer hatte, die zusammen ein Bild darstellen, aber aus Elementen eines Typs bestanden. Also gab es beispielsweise einen Autobahn-Layer, der die Autobahnen in Deutschland darstellte. Dies war ein Layer dessen Elemente auf LineStrings (Line-Layer) basiert. Daneben gab es einen Layer mit Sehenswürdigkeiten, dessen Elemente Punkte, also ein Punkt-Layer waren. Und es gab einen Flächenlayer, um beispielsweise ein Bundesland darzustellen und ich meine als Polygon-Layer.

Die verfügbaren Geometrien kannst du hier nachlesen.

PS: Ich habe gerade nachgeprüft und lege dir das JTS Test Builder Tool nahe, mit dem ich (und hoffentlich auch du) wichtige geografische Operationen, wie beispielsweise Intersection von zwei LineStrings im Screenshot ausgeführt werden können, OHNE programmieren zu müssen. Input von Geometrien erfolgen im WKT-Format (Well-known-Text)
 

Anhänge

  • jts.PNG
    jts.PNG
    81,6 KB · Aufrufe: 34
Zuletzt bearbeitet:
JTS, wow damit habe ich mal vor x-Jahren was gemacht. Daher alles, was ich sage, mit Vorsicht zu "geniessen";)

Das kommt mir komisch vor. Natürlich kann es keinen LineString geben, bei denen die Koordinaten sortiert sind. Denn eine Line ist doch eine Abfolge von Linienelementen (Stückchen) die zusammen einen gesamten Linienzug ausmachen. Da ist natürlich die Reihenfolge der Geradenstückchen absolut entscheidend.

Daher kommt mir auch eine Linie zusammen mit einem Punkt komisch vor. Denn der Punkt alleine, ist ja noch kein "Geradenstückchen".

Ich meine mich zu erinneren, das mein GIS verschiedene Grafik-Layer hatte, die zusammen ein Bild darstellen, aber aus Elementen eines Typs bestanden. Also gab es beispielsweise einen Autobahn-Layer, der die Autobahnen in Deutschland darstellte. Dies war ein Layer dessen Elemente auf LineStrings (Line-Layer) basiert. Daneben gab es einen Layer mit Sehenswürdigkeiten, dessen Elemente Punkte, also ein Punkt-Layer waren. Und es gab einen Flächenlayer, um beispielsweise ein Bundesland darzustellen und ich meine als Polygon-Layer.

Die verfügbaren Geometrien kannst du hier nachlesen.

PS: Ich habe gerade nachgeprüft und lege dir das JTS Test Builder Tool nahe, mit dem ich (und hoffentlich auch du) wichtige geografische Operationen, wie beispielsweise Intersection von zwei LineStrings im Screenshot ausgeführt werden können, OHNE programmieren zu müssen. Input von Geometrien erfolgen im WKT-Format (Well-known-Text)

Hi,

vielen Dank für Deine Ausführungen. Das Problem ist, daß ich Koordinaten (Typ Coordinate) auf einer Strecke habe, die aber aus zwei unterschiedlichen Listen kommen, wobei die eine Liste nur eine einzige Koordinate enthält. Daraus muss ich einen LineString bilden. Die Koordinate aus der einen, 1-elementigen Liste muss irgendwo in die Liste eingebaut werden. Aktuell habe ich das Problem, wenn ich die Koordinate wahllos am Ende einfüge und sich die Koordinate zwischen Koordinaten aus der anderen, mehrelementigen Liste befindet, wird eine zusätzliche Strecke bei der Distanzberechnung mit einbezogen.

MfG Friedenstaube
 

turtle

Top Contributor
Es macht aber auch geografisch einen Unterschied, ob du einen Punkt "einfach" am Ende oder in der Mitte einfügst.

Nehmen wir den einfachen LineString mit drei Punkten
LINESTRING (60 280, 240 280, 400 280)
ergibt Länge=340.0

Nun haben wir einen Punkt
POINT (140 240)

Diesen am Anfang als 1. Punkt eingefügt:
LINESTRING (140 240, 60 280, 240 280, 400 280)
ergibt Länge=429.44271909999156

In der "Mitte" als 2. Punkt eingefügt
LINESTRING (60 280, 140 240, 240 280, 400 280)
ergibt Länge=357.14601524268164

In der "Mitte" als 3. Punkt eingefügt
LINESTRING (60 280, 240 280, 140 240, 400 280)
ergibt Länge=550.7622249020083

Diesen am Ende als 4. Punkt eingefügt:
LINESTRING (60 280, 240 280, 400 280, 140 240)
ergibt Länge=603.0589287593182

Das sind alles gültige Geometrien und welche davon richtig ist, kannst nur du beurteilen;)

Naiv würde ich annehmen, das der Punkt eingefügt werden sollte, der den minimalsten Abstand zu den Koordinaten des LineStrings hat (2. Punkt).

Es gibt die Methode distance bei Geometry, mit der du es berechnen kannst.

Aber, wie gesagt, naiv und du musst beurteilen

PS: Mit folgendem Code kannst du dir einen neuen LineString aus Koordinaten basteln
Java:
Coordinate[] coordinates = new Coordinate[] {
new Coordinate(60, 280), new Coordinate(240, 280), 
new Coordinate(400, 280) };
Geometry g1 = new GeometryFactory().createLineString(coordinates);
 
Zuletzt bearbeitet:

turtle

Top Contributor
Ich habe mal das Beispiel umgesetzt und meine,wie ich bereits anmerkte, das es wenig Sinn macht, EINEN Linestring zu bauen.

Ich glaube, das du hier ZWEI Geometrien hast, die nichts miteinander zu tun haben. Also solltest du auch beide getrennt handhaben.
Java:
    public static void main(String[] args) throws IOException {
	Coordinate[] coordinates = new Coordinate[] { new Coordinate(60, 280), new Coordinate(240, 280), new Coordinate(400, 280) };
	GeometryFactory geometryFactory = new GeometryFactory();
	Geometry g1 = geometryFactory.createLineString(coordinates);
	Geometry g2 = geometryFactory.createPoint(new Coordinate(140, 240));
	GeometryCollection collection = new GeometryCollection(new Geometry[] { g1, g2 }, geometryFactory);
	WKTWriter wktWriter = new WKTWriter();
	Writer writer = new OutputStreamWriter(System.out);
	wktWriter.writeFormatted(collection, writer);
	// GEOMETRYCOLLECTION (LINESTRING (60 280, 240 280, 400 280), POINT (140
	// 240))
	writer.close();
    }
Länge bleibt 340 und das ist auch richtig, da ein Punkt keine Ausdehnung hat... (siehe Screenshot)
 

Anhänge

  • jts.PNG
    jts.PNG
    49,8 KB · Aufrufe: 27
Zuletzt bearbeitet:
Ähnliche Java Themen
  Titel Forum Antworten Datum
KonradN Mal eine Frage zu Binary Serialization Allgemeine Java-Themen 15
8u3631984 Frage zu Java Streams min / max Allgemeine Java-Themen 17
8u3631984 Frage Performance bei Linked List und Array List Allgemeine Java-Themen 5
H Frage regex greater than less than Allgemeine Java-Themen 7
berserkerdq2 Frage zu IntelliJ und JavaFX Allgemeine Java-Themen 1
W Timer Konzept-Frage Allgemeine Java-Themen 16
T Eine Frage des Designs Allgemeine Java-Themen 2
C Frage zu eigenem TableCellRenderer Allgemeine Java-Themen 11
C Programmvorstellung & Frage zum Thema Geschäftsform Allgemeine Java-Themen 51
J Frage zu System.getproperties. Allgemeine Java-Themen 60
molat100 wie kann man die Frage beantworten Allgemeine Java-Themen 1
pkm Frage zur Präzision von Calendar.WEEK_OF_YEAR Allgemeine Java-Themen 12
J Eine Frage zu den Threads und Task Allgemeine Java-Themen 1
pkm Frage nach eventuellem syntaktischen Zucker bei der Konkatenation von ArrayLists Allgemeine Java-Themen 4
M Frage-Antwortspiel wie Wer wird Millionär Allgemeine Java-Themen 1
F Frage zu System.in Allgemeine Java-Themen 3
marcooooo Frage zum Beispiel im Anhang Allgemeine Java-Themen 16
T Meine Frage lautet wie ich 2 CSV Dateien miteinander in Java verbinde und Spalten die zueinander gehören durch den gleichen Key zusammen ausgebe? Allgemeine Java-Themen 5
S Noch eine Design-Frage zu Setter Allgemeine Java-Themen 6
B For-Loop Frage Allgemeine Java-Themen 21
L Java frage Allgemeine Java-Themen 3
bueseb84 Frage zu Mock und UpperBound Allgemeine Java-Themen 2
M Frage zum Konstruktor Allgemeine Java-Themen 2
W Best Practice Frage zur Umsetzung MVC Allgemeine Java-Themen 9
P String-Verschlüsselung - Frage zur Sicherheit Allgemeine Java-Themen 21
B Frage zu Unit-Tests Allgemeine Java-Themen 6
T Allgemeine Frage: GUI für 3D-Visualisierung Allgemeine Java-Themen 5
R Allgemeine Frage zu RMI bei MVC Allgemeine Java-Themen 2
O Frage zum Runtimeverhalten von Java ... Allgemeine Java-Themen 2
H Rundreise frage (Algorithmus) Allgemeine Java-Themen 18
B Generelle Frage bei einer Webanwendung / Reduzierung von DB Abfragen Allgemeine Java-Themen 1
D Frage zu Vererbung Allgemeine Java-Themen 5
J Frage zu regulärem Ausdruck Allgemeine Java-Themen 2
M Allgemeine Frage: Wie lernt man Java / Programmieren von Grund auf? Allgemeine Java-Themen 7
rentasad Design-Frage - Interfaces, Klassen, statische Methoden Allgemeine Java-Themen 3
S Frage zur JLS Allgemeine Java-Themen 0
J Verständnis Frage zur Instanz, Objekte, Instanzierung, Referenz Allgemeine Java-Themen 14
A Methoden Allgemeine Java Frage Allgemeine Java-Themen 3
E String Frage Allgemeine Java-Themen 9
I bin neu bei GitHub, Frage zur Sicherheit Allgemeine Java-Themen 14
C J2V8 NodeJs Java Bride Problem und Frage!?!? Allgemeine Java-Themen 1
C KeyListener Frage Allgemeine Java-Themen 3
T Frage zu UML in Java programmieren Allgemeine Java-Themen 1
R Konstanten initialisieren - FRAGE Allgemeine Java-Themen 3
MTJ004 FTP Frage zu FTP Speicherung Java-Android-FTP Allgemeine Java-Themen 5
J Frage zum Entwurf / json-Datenmodell Allgemeine Java-Themen 8
A Frage zu meinem Code Allgemeine Java-Themen 2
RalleYTN Classpath Nur ne kleine Frage zur MANIFEST.MF Allgemeine Java-Themen 4
T Frage zu Access Modifiers Allgemeine Java-Themen 6
W Input/Output Frage zu pdfbox und FileUtils Allgemeine Java-Themen 2
O Frage zur Implementierungsweise Allgemeine Java-Themen 4
B Frage zu Bitshift Allgemeine Java-Themen 3
J Java Zufallsgenerator (6 aus 49) Frage Allgemeine Java-Themen 7
L Frage zu RIA und GWT Allgemeine Java-Themen 0
P Concurrency Frage Allgemeine Java-Themen 8
M Frage zu Enumerations Allgemeine Java-Themen 2
F Unlimited Strength Policy. Frage Verbreitung der Anwendung Allgemeine Java-Themen 1
S Java Design Frage Allgemeine Java-Themen 10
E Reflection? Frage Allgemeine Java-Themen 4
C FileInputStream frage Allgemeine Java-Themen 6
G Polymorphie Programmdesign Frage Allgemeine Java-Themen 20
Uzi21 Frage zu NetBeans ( Console) Allgemeine Java-Themen 11
D Classpath Frage zum Java Resource Loading Allgemeine Java-Themen 2
G Frage zu JPA Allgemeine Java-Themen 1
S Methoden Frage Allgemeine Java-Themen 2
P MVC - Frage zu Model Allgemeine Java-Themen 4
K Frage zu Locks Allgemeine Java-Themen 1
S Frage zu abstract Allgemeine Java-Themen 5
M ArrayList<String> Frage Allgemeine Java-Themen 7
M OOP Design Frage Allgemeine Java-Themen 2
N Frage zur while-Schleife Allgemeine Java-Themen 18
T Best Practice Auslesen von Zeichenketten (Frage, Antworten, usw) Allgemeine Java-Themen 4
C Eine Frage zur Bearbeitungszeit Allgemeine Java-Themen 8
H Frage wegen Heap-Speicher Allgemeine Java-Themen 2
T Garbage Collection Frage Allgemeine Java-Themen 15
P Kurze Frage: aus einer File die Zeilenanzahl auslesen Allgemeine Java-Themen 9
D Frage zu Java und Umlauten / charsets Allgemeine Java-Themen 2
B Frage zu Java und OpenGL? Allgemeine Java-Themen 3
Q Kapselung Allgemeine Design- Frage Allgemeine Java-Themen 8
A eine test thread.join() frage Allgemeine Java-Themen 2
DStrohma LayoutManager Frage zum GridBagLayout Allgemeine Java-Themen 4
F Frage zu Regex möglich Allgemeine Java-Themen 4
H XML-File mit Java erzeugt Frage Allgemeine Java-Themen 10
D Frage und Antwort Programm, Problem bei Methodenaufruf Allgemeine Java-Themen 3
J NetBeans Frage bezüglich der Scanner-Klasse Allgemeine Java-Themen 6
H Java Vector Frage Allgemeine Java-Themen 9
W Frage... Allgemeine Java-Themen 29
R Frage zur topologischen Sortierung Allgemeine Java-Themen 2
H Frage zu weka.core.Instance Allgemeine Java-Themen 3
Y Kleine Frage zu String.split Allgemeine Java-Themen 3
T Frage zu Klassendesing Allgemeine Java-Themen 3
W Frage zu Refactoring statischer Methoden Allgemeine Java-Themen 4
C Eclipse Wichtige frage Allgemeine Java-Themen 5
H Frage zu java.weka.core.Instances Allgemeine Java-Themen 3
S Frage zu Format Modifiers in Log4j Allgemeine Java-Themen 11
H Frage zu clone() Allgemeine Java-Themen 5
4 Simple(?) Frage zu Threads Allgemeine Java-Themen 14
H2SO3- SCJP Chapter 3 Frage 10. Falsche Antwort? Allgemeine Java-Themen 15
H Frage sinnvolle Datenspeicherung und -verarbeitung Allgemeine Java-Themen 3
EnHancEd[] kurze enum-Frage Allgemeine Java-Themen 4

Ähnliche Java Themen

Neue Themen


Oben