39 std::vector<Double_t> fXs1;
40 std::vector<Double_t> fYs1;
43 std::vector<Double_t> fXs2;
44 std::vector<Double_t> fYs2;
49 :
TNamed(
"polygon_compression_test2",
"polygon_compression_test2")
55 assert(
gPad !=
nullptr &&
"PolyTest2, gPad is null");
57 assert(
gRandom !=
nullptr &&
"PolyTest2, gRandom is null");
59 Double_t xMin = 0., xMax = 0., yMin = 0., yMax = 0.;
60 gPad->GetRange(xMin, yMin, xMax, yMax);
61 assert(xMax - xMin > 0 && yMax - yMin > 0 &&
"PolyTest2, invalid canvas' ranges");
70 const unsigned nVertices = 3 + kNSawPoints;
74 fXs1.resize(nVertices);
75 fYs1.resize(nVertices);
80 const Double_t w1 = 0.2 * (xMax - xMin);
81 const Double_t saw1ToothSize = 0.1 * w1;
82 const Double_t yStep = (yMax - yMin) / (kNSawPoints - 1);
84 for (
unsigned i = 1; i <= kNSawPoints; ++i) {
86 fYs1[i] = yMin + yStep * (i - 1);
89 fXs1[nVertices - 2] = 0.;
90 fYs1[nVertices - 2] = yMax;
92 fXs1[nVertices - 1] = fXs1[0];
93 fYs1[nVertices - 1] = fYs1[0];
100 const Double_t x2Min = xMin + 0.25 * (xMax - xMin);
103 const Double_t xStep = (xMax - x2Min) / (kNSawPoints - 1);
105 fXs2.resize(nVertices);
106 fYs2.resize(nVertices);
111 for (
unsigned i = 1; i <= kNSawPoints; ++i) {
112 fXs2[i] = x2Min + xStep * i;
116 fXs2[nVertices - 2] = xMax;
117 fYs2[nVertices - 2] = 0.;
118 fXs2[nVertices - 1] = fXs2[0];
119 fYs2[nVertices - 1] = fYs2[0];
124void PolyTest2::Paint(
const Option_t * )
126 assert(
gPad !=
nullptr &&
"Paint, gPad is null");
130 gPad->PaintFillArea((
Int_t)fXs1.size(), &fXs1[0], &fYs1[0]);
134 gPad->PaintPolyLine((
Int_t)fXs1.size(), &fXs1[0], &fYs1[0]);
138 gPad->PaintFillArea((
Int_t)fXs2.size(), &fXs2[0], &fYs2[0]);
142 gPad->PaintPolyLine((
Int_t)fXs2.size(), &fXs2[0], &fYs2[0]);
150 PolyTest2 * polygon =
new PolyTest2;
Option_t Option_t SetLineColor
Option_t Option_t SetFillColor
R__EXTERN TRandom * gRandom
Fill Area Attributes class.
virtual void Modify()
Change current fill area attributes if necessary.
virtual void Modify()
Change current line attributes if necessary.
TVirtualPad * cd(Int_t subpadnumber=0) override
Set current canvas & pad.
The TNamed class is the base class for all named ROOT classes.
virtual void Paint(Option_t *option="")
This method must be overridden if a class wants to paint itself.
Double_t Rndm() override
Machine independent random number generator.