AGB  ·  Datenschutz  ·  Impressum  







Anmelden
Nützliche Links
Registrieren
Thema durchsuchen
Ansicht
Themen-Optionen

Außenkontur erkennen

Ein Thema von MechMac666 · begonnen am 7. Dez 2011 · letzter Beitrag vom 8. Dez 2011
Antwort Antwort
MechMac666

Registriert seit: 9. Nov 2008
95 Beiträge
 
#1

Außenkontur erkennen

  Alt 7. Dez 2011, 21:25
Hallo,

ich habe ein Array of Pointlist. Jede Pointlist beinhaltet die Koordinaten für z.B. eine Polylinie.

Das Ganze könnte z.B. so aussehen:
poly.jpg

Nun möchte ich gerne die Außenkontur als eine einzelne Polylinie erhalten. Der Hintergrund ist der, das ich dieses "Outline"-Polygon als Region in der GDI verwenden möchte. Dazu dürfen es aber keine einzelnen Linien sein, sondern es muss ein "Objekt" sein.

Nur wie kann ich ermitteln, was zur Außenkontur gehört und was zur Innenkontur? Man bräuchte quasi ein "Im Uhrzeigersinn abfahren und immer links halten" Algo.

Gruß, Andreas
  Mit Zitat antworten Zitat
BenjaminH

Registriert seit: 14. Okt 2004
Ort: Freiburg im Breisgau
713 Beiträge
 
Turbo Delphi für Win32
 
#2

AW: Außenkontur erkennen

  Alt 7. Dez 2011, 21:33
Hi,
du kannst ja für jeden Punkt prüfen, ob er im Polygon, das die restlichen Punkte aufspannen enthalten ist. Wenn ja, dann lässt du den Punkt weg.
Dabei wird dir das helfen:
http://paulbourke.net/geometry/insidepoly/

Viele Grüße,
Benjamin

[Edit]Übersichtlichere Seite gefunden.
Benjamin
  Mit Zitat antworten Zitat
MechMac666

Registriert seit: 9. Nov 2008
95 Beiträge
 
#3

AW: Außenkontur erkennen

  Alt 7. Dez 2011, 22:05
Hm. Und was wäre mit der Rot markierten Linie? Deren beiden Punkte liegen exakt auf Punkten der sich darüber und darunter befindlichen Linien.
poly.jpg


Gruß, Andreas
  Mit Zitat antworten Zitat
Benutzerbild von Uwe Raabe
Uwe Raabe

Registriert seit: 20. Jan 2006
Ort: Lübbecke
11.447 Beiträge
 
Delphi 12 Athens
 
#4

AW: Außenkontur erkennen

  Alt 7. Dez 2011, 22:16
In diesem Fall empfehle ich eine passende Aneinanderreihung der Funktionen CreatePolyPolygonRgn und CombineRgn.
Uwe Raabe
Certified Delphi Master Developer
Embarcadero MVP
Blog: The Art of Delphi Programming
  Mit Zitat antworten Zitat
Benutzerbild von jfheins
jfheins

Registriert seit: 10. Jun 2004
Ort: Garching (TUM)
4.579 Beiträge
 
#5

AW: Außenkontur erkennen

  Alt 8. Dez 2011, 08:40
Du suchst die konvexe Hülle der Punkte. Algorithmen gibt's auf Wikipedia: http://de.wikipedia.org/wiki/Konvexe_Hülle

wobei... die Hülle ist dann konvex, in deinem Beispiel hat sie also zwei schräge linien... stört das?

Geändert von jfheins ( 8. Dez 2011 um 08:42 Uhr)
  Mit Zitat antworten Zitat
Benutzerbild von Uwe Raabe
Uwe Raabe

Registriert seit: 20. Jan 2006
Ort: Lübbecke
11.447 Beiträge
 
Delphi 12 Athens
 
#6

AW: Außenkontur erkennen

  Alt 8. Dez 2011, 09:15
Du suchst die konvexe Hülle der Punkte. Algorithmen gibt's auf Wikipedia: http://de.wikipedia.org/wiki/Konvexe_Hülle

wobei... die Hülle ist dann konvex, in deinem Beispiel hat sie also zwei schräge linien... stört das?
Wobei "Im Uhrzeigersinn abfahren und immer links halten" aber etwas anderes ergeben würde.
Uwe Raabe
Certified Delphi Master Developer
Embarcadero MVP
Blog: The Art of Delphi Programming
  Mit Zitat antworten Zitat
Medium

Registriert seit: 23. Jan 2008
3.686 Beiträge
 
Delphi 2007 Enterprise
 
#7

AW: Außenkontur erkennen

  Alt 8. Dez 2011, 09:51
Man könnte so Dinge tun, wie prüfen, ob die 2 Kanten an einem Punkt jeweils auf der einen Seite innerhalb, auf der anderen ausserhalb eines Polygons darstellen, was aber bei manch engen Situationen eher mäh sein kann (Point-In-Poly Prüfung von Punkten knapp neben den Kanten in Normalenrichtung - ist der Offset zu groß, kann man Lücken übersehen, ist er zu klein, haut einem die Genauigkeit vors Knie).
Das praktikabelste wird hier wirklich Uwes Lösung sein. Alternativ kannst du deine Polys auch einfarbig auf ein Bitmap zeichnen, und mit diesem als Maske eine Region erzeugen, was aber so ziemlich das gleiche sein dürfte, wie das was Windows mit Uwes Weg intern eh täte
"When one person suffers from a delusion, it is called insanity. When a million people suffer from a delusion, it is called religion." (Richard Dawkins)
  Mit Zitat antworten Zitat
Antwort Antwort


Forumregeln

Es ist dir nicht erlaubt, neue Themen zu verfassen.
Es ist dir nicht erlaubt, auf Beiträge zu antworten.
Es ist dir nicht erlaubt, Anhänge hochzuladen.
Es ist dir nicht erlaubt, deine Beiträge zu bearbeiten.

BB-Code ist an.
Smileys sind an.
[IMG] Code ist an.
HTML-Code ist aus.
Trackbacks are an
Pingbacks are an
Refbacks are aus

Gehe zu:

Impressum · AGB · Datenschutz · Nach oben
Alle Zeitangaben in WEZ +1. Es ist jetzt 23:26 Uhr.
Powered by vBulletin® Copyright ©2000 - 2024, Jelsoft Enterprises Ltd.
LinkBacks Enabled by vBSEO © 2011, Crawlability, Inc.
Delphi-PRAXiS (c) 2002 - 2023 by Daniel R. Wolf, 2024 by Thomas Breitkreuz