![]() |
AW: Rectangle finden, daß von 2 Punkten aufgespannt wird
Hä? Das ist doch überhaupt keine zusätzliche Information, egal welcher von beiden gemeint ist. Der Winkel ergibt sich ja allein schon aus den Positionen der beiden bekannten Eckpunkte. die beiden anderen können immer noch überall sein...
|
AW: Rectangle finden, daß von 2 Punkten aufgespannt wird
Ach komm, es ist Freitag Abend :-D
Da sind die grauen Zellen aufgebraucht. |
AW: Rectangle finden, daß von 2 Punkten aufgespannt wird
Zitat:
|
AW: Rectangle finden, daß von 2 Punkten aufgespannt wird
Zitat:
|
AW: Rectangle finden, daß von 2 Punkten aufgespannt wird
Liste der Anhänge anzeigen (Anzahl: 1)
-> Skizze
|
AW: Rectangle finden, daß von 2 Punkten aufgespannt wird
Zitat:
Aber aus deiner Skizze geht hervor, dass du den Winkel zwischen der horizontalen und der oberen Seite meinst. dann passt's. Ich würde das Koordinatensystem um den Winkel drehen. Danach suchst du das achsparallele Rechteck und dreht die neuen zwei Punkte wieder zurück. Die Formel kannst du dann auch in eine Zeile schreiben und schreiben "ist ja anschaulich korrekt" :stupid: Ich poste hier mal frech den MATLAB-Quellcode:
Code:
Du siehst (vielleicht) dass ich die gegebenen Punkte P1 und P3 getauft habe. P2 errechnet sich dann nach R' * (xx(R*P1); yy(R*P2))
for phi = 0:0.01:2
P1 = [1;4]; P3 = [3;2]; %phi = 0.5; R = [cos(phi), -sin(phi); sin(phi), cos(phi)]; NewP = R * [P1,P3]; P2 = R' * NewP([1; 4]); P4 = R' * NewP([3; 2]); plot([P1(1), P2(1), P3(1), P4(1), P1(1)], [P1(2), P2(2), P3(2), P4(2), P1(2)], 'o-'); daspect([1 1 1]) xlim([-1 6]); ylim([-1 6]) drawnow; pause(0.01) end wobei xx(k) bedeuten soll "x-Komponente des Vektors k" und yy analog. R' ist die transponierte von R. P4 = R' * (xx(R*P3); yy(R*P1)) |
AW: Rectangle finden, daß von 2 Punkten aufgespannt wird
Liste der Anhänge anzeigen (Anzahl: 1)
Dank Dir. Damit kann ich allerdings nix anfangen? Man braucht doch nur beta und gamma und alles ist gut (- > Skizze).
|
AW: Rectangle finden, daß von 2 Punkten aufgespannt wird
Aus der Gerade P1P2 kann man den Winkel gegen die Horizontale berechnen. Diesen minus Alpha ist der Innenwinkel des Thaleskreisdreiecks P1 P3 P2 bei P1.
Aus Width^2 + Height^2 = (P1P2)^2 und Height / Width = tan(dieser Winkel) kann man W und H bestimmen. Damit hat man dann ein Rect und das bei P1 um Alpha gedreht ist das gesuchte Rect. Oh man.. |
AW: Rectangle finden, daß von 2 Punkten aufgespannt wird
Oder so:
Es geht eine Gerade K1=ax+b durch P1. a=ATN(Alpha) Die zweite Gerade K2= durch P1 ist (-1/a)x + c Ich kann nun b und c direkt ausrechnen (ich habe ja P1=(x1,y1)). Damit habe ich die Geradengleichungen der beiden Kanten, die von P1 ausgehen. K1 und K2 (K1 sei die Kante, die im Winkel Alpha zur Horizontalen steht) Den gleichen Schmunz mache ich mit P2 und bekomme K3 und K4 (wobei K4 die Kante ist, die im Winkel Alpha zur Horizontalen steht). Na, K3 schneidet K1 und K2 schneidet K4. Das ist ja wohl nicht so schwer, das dann auszurechnen. Somit habe ich die fehlenden Punkte P3 und P4, also nun alle Punkte des Rechteckes. |
AW: Rectangle finden, daß von 2 Punkten aufgespannt wird
Äh, ja man kann sich auch wieder mit Geradengleichungen und Steigungen herumärgern. (Und Sonderfälle für senkrechte Gerade einführen)
Ich habe mal die Formel oben einmal eingesetzt für den einen der zwei fehlenden Punkte. Mit c=cos(phi) und s=sin(phi) ergibt das: P3x = c^2 P1x - c*s P1y + s^2 P2x + c*s P2y P3y = -c*s P1x + s^2 P1y + c*s P2x + c^2 P2y Man sieht: Es ändert sich eigentlich nur die Reihenfolge der Koeffizienten. Ich habe den Winkel jetzt (immernoch) phi genannt, in deiner Skizze ist es alpha. Der Tangens hat übrigens auch eine Unstetigkeitsstelle, da kann also auch NaN herauskommen. Ich glaube meine Lösung ist bisher die robustete. |
Alle Zeitangaben in WEZ +1. Es ist jetzt 01:57 Uhr. |
Powered by vBulletin® Copyright ©2000 - 2025, Jelsoft Enterprises Ltd.
LinkBacks Enabled by vBSEO © 2011, Crawlability, Inc.
Delphi-PRAXiS (c) 2002 - 2023 by Daniel R. Wolf, 2024-2025 by Thomas Breitkreuz