75 Fatal(
"Ctor",
"Invalid number of vertices %i", nvert);
110 for (ic=0; ic<
fNvert; ic++) {
112 j =
fInd[(ic+1)%fNvert];
113 area += 0.5*(
fX[i]*
fY[j]-
fX[j]*
fY[i]);
129 for (i=0; i<nd; i++) {
151 point[1] =
fY[fInd[k]];
189 Int_t indnext, indback;
194 if (nskip<0) nskip+=
fNvert;
204 indback = fIndc[indnext]-1;
205 if (indback < 0) indback+=
fNvert;
206 while (indback != fIndc[indconv]) {
209 if (indback < 0) indback+=
fNvert;
234 y[ic] =
fY[fIndc[ic]];
244 (point[1]-
fY[ind1])*(
fX[ind2]-
fX[ind1]);
246 if (dot<-1.
E-10)
return kFALSE;
255 if (i2<0) i2=(i1+1)%
fNvert;
258 if (i==i1 || i==i2)
continue;
260 point[1] =
fY[fInd[i]];
278 if (i==0 && j==(fNvert-1))
continue;
285 x4 =
fX[(j+1)%fNvert];
286 y4 =
fY[(j+1)%fNvert];
288 Error(
"IsIllegalCheck",
"Illegal crossing of segment %d vs. segment %d", i,j);
309 if (iseg+2 >
fNvert)
break;
332 if (ivnew<iseg)
break;
337 Fatal(
"OutscribedConvex",
"cannot build outscribed convex");
352 Double_t lsq, ssq, dx, dy, dpx, dpy, u;
355 for (i1=0; i1<
fNvert; i1++) {
368 dpx = point[0] - p1[0];
369 dpy = point[1] - p1[1];
373 ssq = dpx*dpx + dpy*dpy;
380 u = (dpx*dx + dpy*dy)/lsq;
382 dpx = point[0]-p2[0];
383 dpy = point[1]-p2[1];
390 ssq = dpx*dpx + dpy*dpy;
414 Error(
"SetNextIndex",
"all indices already set");
419 if (!
fX || !
fY)
return;
443 for (i=0; i<nd; i++) {
445 if (poly) poly->
SetXY(x,y);
Double_t Area() const
Computes area of the polygon in [length^2].
Bool_t IsRightSided(const Double_t *point, Int_t ind1, Int_t ind2) const
Check if POINT is right-sided with respect to the segment defined by IND1 and IND2.
virtual void Draw(Option_t *option="")
Draw the polygon.
ClassImp(TGeoPolygon) TGeoPolygon
Dummy constructor.
void SetNextIndex(Int_t index=-1)
Sets the next polygone index.
virtual void Delete(Option_t *option="")
Remove all objects from the array AND delete all heap based objects.
void ConvexCheck()
Check polygon convexity.
void GetVertices(Double_t *x, Double_t *y) const
Fill list of vertices into provided arrays.
Bool_t IsSegConvex(Int_t i1, Int_t i2=-1) const
Check if a segment [0..fNvert-1] belongs to the outscribed convex pgon.
Int_t GetEntriesFast() const
static Bool_t IsSameWithinTolerance(Double_t a, Double_t b)
Check if two numbers differ with less than a tolerance.
void SetBit(UInt_t f, Bool_t set)
Set or unset the user status bits as specified in f.
virtual void Fatal(const char *method, const char *msgfmt,...) const
Issue fatal error message.
Bool_t IsIllegalCheck() const
Check for illegal crossings between non-consecutive segments.
static const double x2[5]
Double_t dot(const TVector2 &v1, const TVector2 &v2)
static double p2(double t, double a, double b, double c)
static const double x4[22]
virtual void Error(const char *method, const char *msgfmt,...) const
Issue error message.
void GetConvexVertices(Double_t *x, Double_t *y) const
Fill list of vertices of the convex outscribed polygon into provided arrays.
TObject * UncheckedAt(Int_t i) const
static Bool_t IsSegCrossing(Double_t x1, Double_t y1, Double_t x2, Double_t y2, Double_t x3, Double_t y3, Double_t x4, Double_t y4)
Check if segments (A,B) and (C,D) are crossing, where: A(x1,y1), B(x2,y2), C(x3,y3), D(x4,y4)
void SetXY(Double_t *x, Double_t *y)
Set X/Y array pointer for the polygon and daughters.
static double p1(double t, double a, double b)
void SetConvex(Bool_t flag=kTRUE)
void OutscribedConvex()
Compute indices for the outscribed convex polygon.
static const double x1[5]
R__EXTERN TGeoManager * gGeoManager
Double_t Safety(const Double_t *point, Int_t &isegment) const
Compute minimum distance from POINT to any segment. Returns segment index.
Double_t * fY
pointer to list of current X coordinates of vertices
void FinishPolygon()
Decompose polygon in a convex outscribed part and a list of daughter polygons that have to be substra...
Bool_t IsClockwise() const
virtual void DrawPolygon(const TGeoPolygon *poly)=0
TObjArray * fDaughters
pointer to list of current Y coordinates of vertices
Bool_t Contains(const Double_t *point) const
Check if a point given by X = point[0], Y = point[1] is inside the polygon.
Double_t Sqrt(Double_t x)
TObject * At(Int_t idx) const
virtual ~TGeoPolygon()
Destructor.
TVirtualGeoPainter * GetGeomPainter()
Make a default painter if none present. Returns pointer to it.
static const double x3[11]