double HHomMat2D.AffineTransPoint2d(double px, double py, out double qy)
Beschreibung
affine_trans_point_2daffine_trans_point_2dAffineTransPoint2dAffineTransPoint2dAffineTransPoint2d wendet eine beliebige affine 2D-Transformation
(Skalierung, Drehung, Verschiebung, Scherung) auf die Eingabepunkte
(PxPxPxPxpx,PyPyPyPypy) an und liefert die Ergebnispunkte in
(QxQxQxQxqx,QyQyQyQyqy) zurück. Die Transformation wird durch eine homogene
Transformationsmatrix beschrieben, die in HomMat2DHomMat2DHomMat2DHomMat2DhomMat2D übergeben wird.
Dies entspricht der folgenden Gleichung (Ein- und Ausgabepunkte als homogene
Vektoren dargestellt):
Falls die zu transformierenden Punkte in Standard-Bildkoordinaten vorliegen,
müssen die Zeilen-Koordinaten der Punkte in PxPxPxPxpx und die
Spalten-Koordinaten in PyPyPyPypy übergeben werden. Dies ist
notwendig, um für das Bild ein rechtshändiges Koordinatensystem zu erhalten.
Insbesondere werden dadurch Rotationen im korrekten Drehsinn ausgeführt. Die
Koordinatenreihenfolge (x,y) der Matrizen entspricht dann der üblichen
Koordinatenreihenfolge (Zeile,Spalte) der Bilder.
Falls zum Beispiel HomMat2DHomMat2DHomMat2DHomMat2DhomMat2D eine starre Transformation ist,
also aus Rotation und Translation besteht, werden die Punkte
folgendermaßen transformiert:
Ausführungsinformationen
Multithreading-Typ: reentrant (läuft parallel zu nicht-exklusiven Operatoren).
Multithreading-Bereich: global (kann von jedem Thread aufgerufen werden).
Falls die Matrix HomMat2DHomMat2DHomMat2DHomMat2DhomMat2D eine affine Abbildung darstellt
(d.h. keine projektive Abbildung), liefert
affine_trans_point_2daffine_trans_point_2dAffineTransPoint2dAffineTransPoint2dAffineTransPoint2d den Wert 2 (H_MSG_TRUE) zurück. Ansonsten wird
eine Ausnahmebehandlung durchgeführt.