intersection_circle_contour_xldintersection_circle_contour_xldIntersectionCircleContourXldIntersectionCircleContourXld (Operator)
Name
intersection_circle_contour_xldintersection_circle_contour_xldIntersectionCircleContourXldIntersectionCircleContourXld
— Berechnet die Schnittpunkte von einem Kreis oder Kreisbogen
und einer XLD-Kontur
Signatur
Herror intersection_circle_contour_xld(const Hobject Contour, double CircleRow, double CircleColumn, double CircleRadius, double CircleStartPhi, double CircleEndPhi, const char* CirclePointOrder, double* Row, double* Column)
Herror T_intersection_circle_contour_xld(const Hobject Contour, const Htuple CircleRow, const Htuple CircleColumn, const Htuple CircleRadius, const Htuple CircleStartPhi, const Htuple CircleEndPhi, const Htuple CirclePointOrder, Htuple* Row, Htuple* Column)
Beschreibung
intersection_circle_contour_xldintersection_circle_contour_xldIntersectionCircleContourXldIntersectionCircleContourXldIntersectionCircleContourXld
berechnet die Schnittpunkte
von einem Kreis oder Kreisbogen und einer XLD-Kontur ContourContourContourContourcontour
.
Der Kreis wird über dessen Mittelpunkt
(CircleRowCircleRowCircleRowCircleRowcircleRow
,CircleColumnCircleColumnCircleColumnCircleColumncircleColumn
) und Radius
CircleRadiusCircleRadiusCircleRadiusCircleRadiuscircleRadius
definiert. Ein Kreisbogen wird zusätzlich durch den
Anfangs- und Endwinkel CircleStartPhiCircleStartPhiCircleStartPhiCircleStartPhicircleStartPhi
und CircleEndPhiCircleEndPhiCircleEndPhiCircleEndPhicircleEndPhi
des Start- bzw. Endpunktes, sowie durch dessen Umlaufsinn
CirclePointOrderCirclePointOrderCirclePointOrderCirclePointOrdercirclePointOrder
charakterisiert.
CirclePointOrderCirclePointOrderCirclePointOrderCirclePointOrdercirclePointOrder
= 'positive'"positive""positive""positive""positive" definiert den Kreisbogen
gegen den Uhrzeigersinn.
CirclePointOrderCirclePointOrderCirclePointOrderCirclePointOrdercirclePointOrder
= 'negative'"negative""negative""negative""negative" definiert den Kreisbogen
im Uhrzeigersinn.
Die Schnittpunkte, falls vorhanden, werden in (RowRowRowRowrow
,ColumnColumnColumnColumncolumn
)
zurückgegeben.
Ausführungsinformationen
- Multithreading-Typ: reentrant (läuft parallel zu nicht-exklusiven Operatoren).
- Multithreading-Bereich: global (kann von jedem Thread aufgerufen werden).
- Wird ohne Parallelisierung verarbeitet.
Parameter
ContourContourContourContourcontour
(input_object) xld_cont →
objectHXLDContHXLDContHobject
XLD-Kontur.
CircleRowCircleRowCircleRowCircleRowcircleRow
(input_control) circle.center.y →
HTupleHTupleHtuple (real / integer) (double / int / long) (double / Hlong) (double / Hlong)
Zeilenkoordinate des Kreismittelpunktes.
CircleColumnCircleColumnCircleColumnCircleColumncircleColumn
(input_control) circle.center.x →
HTupleHTupleHtuple (real / integer) (double / int / long) (double / Hlong) (double / Hlong)
Spaltenkoordiante des Kreismittelpunktes.
CircleRadiusCircleRadiusCircleRadiusCircleRadiuscircleRadius
(input_control) circle.radius →
HTupleHTupleHtuple (real / integer) (double / int / long) (double / Hlong) (double / Hlong)
Radius des Kreises.
CircleStartPhiCircleStartPhiCircleStartPhiCircleStartPhicircleStartPhi
(input_control) angle.rad →
HTupleHTupleHtuple (real) (double) (double) (double)
Winkel des Startpunktes des Kreises
oder Kreisbogens [rad].
Defaultwert: 0.0
CircleEndPhiCircleEndPhiCircleEndPhiCircleEndPhicircleEndPhi
(input_control) angle.rad →
HTupleHTupleHtuple (real) (double) (double) (double)
Winkel des Endpunktes des Kreises
oder Kreisbogens [rad].
Defaultwert: 6.28318
CirclePointOrderCirclePointOrderCirclePointOrderCirclePointOrdercirclePointOrder
(input_control) string →
HTupleHTupleHtuple (string) (string) (HString) (char*)
Mathematischer Umlaufsinn des Kreises oder Kreisbogens.
Defaultwert:
'positive'
"positive"
"positive"
"positive"
"positive"
Werteliste: 'negative'"negative""negative""negative""negative", 'positive'"positive""positive""positive""positive"
RowRowRowRowrow
(output_control) point.y(-array) →
HTupleHTupleHtuple (real) (double) (double) (double)
Zeilenkoordinate der Schnittpunkte.
ColumnColumnColumnColumncolumn
(output_control) point.x(-array) →
HTupleHTupleHtuple (real) (double) (double) (double)
Spaltenkoordinate der Schnittpunkte.
Ergebnis
Sind die Parameterwerte korrekt, dann liefert
intersection_circle_contour_xldintersection_circle_contour_xldIntersectionCircleContourXldIntersectionCircleContourXldIntersectionCircleContourXld
den Wert 2 (H_MSG_TRUE).
Alternativen
intersection_segment_circleintersection_segment_circleIntersectionSegmentCircleIntersectionSegmentCircleIntersectionSegmentCircle
Siehe auch
intersection_line_circleintersection_line_circleIntersectionLineCircleIntersectionLineCircleIntersectionLineCircle
Modul
Foundation