133 fPadPointer =
nullptr;
134 fPrimitives =
nullptr;
149 fPadView3D =
nullptr;
179 fFixedAspectRatio =
kFALSE;
182 fNumPaletteColor = 0;
183 fNextPaletteColor = 0;
184 fCollideGrid =
nullptr;
198 fUxmin = fUymin = fUxmax = fUymax = 0;
247 :
TVirtualPad(
name,title,xlow,ylow,xup,yup,color,bordersize,bordermode)
331 Error(
"TPad",
"You must create a TCanvas before creating a TPad");
338 if ((xlow < 0) || (xlow > 1) || (ylow < 0) || (ylow > 1)) {
339 Error(
"TPad",
"illegal bottom left position: x=%f, y=%f", xlow, ylow);
342 if ((xup < 0) || (xup > 1) || (yup < 0) || (yup > 1)) {
343 Error(
"TPad",
"illegal top right position: x=%f, y=%f", xup, yup);
347 Error(
"TPad",
"illegal width: %f", xup-xlow);
351 Error(
"TPad",
"illegal height: %f", yup-ylow);
362 SetPad(
name, title, xlow, ylow, xup, yup, color, bordersize, bordermode);
463 while ((exec = (
TExec*)next())) {
504 const char* title,
Option_t *option)
513 while( (o=next()) ) {
519 mes = ((
TNamed *)o)->GetTitle();
524 if (strlen(option)) {
535 TIter nextgraph(grlist);
538 while ((obj = nextgraph())) {
543 if (strlen(option)) opt = option;
545 leg->AddEntry( obj, mes.
Data(), opt );
550 TIter nexthist(hlist);
553 while ((obj = nexthist())) {
558 if (strlen(option)) opt = option;
560 leg->AddEntry( obj, mes.
Data(), opt );
571 Info(
"BuildLegend(void)",
"No object to build a TLegend.");
615 while ((obj = next())) {
618 if (
n == subpadnumber) {
619 return ((
TPad*)obj)->
cd();
688 for (
Int_t i=0;i<2;i++) {
701 while(code1 + code2) {
712 if (ic == 0) ic = code2;
714 yt =
y[0] + (
y[1]-
y[0])*(xclipl-
x[0])/(
x[1]-
x[0]);
718 yt =
y[0] + (
y[1]-
y[0])*(xclipr-
x[0])/(
x[1]-
x[0]);
722 xt =
x[0] + (
x[1]-
x[0])*(yclipb-
y[0])/(
y[1]-
y[0]);
726 xt =
x[0] + (
x[1]-
x[0])*(yclipt-
y[0])/(
y[1]-
y[0]);
732 code1 =
ClippingCode(xt,yt,xclipl,yclipb,xclipr,yclipt);
736 code2 =
ClippingCode(xt,yt,xclipl,yclipb,xclipr,yclipt);
759 for (
Int_t i=0;i<2;i++) {
768 if (
x[0] < xclipl) code1 = code1 | 0x1;
769 if (
x[0] > xclipr) code1 = code1 | 0x2;
770 if (
y[0] < yclipb) code1 = code1 | 0x4;
771 if (
y[0] > yclipt) code1 = code1 | 0x8;
773 if (
x[1] < xclipl) code2 = code2 | 0x1;
774 if (
x[1] > xclipr) code2 = code2 | 0x2;
775 if (
y[1] < yclipb) code2 = code2 | 0x4;
776 if (
y[1] > yclipt) code2 = code2 | 0x8;
780 while(code1 + code2) {
791 if (ic == 0) ic = code2;
793 yt =
y[0] + (
y[1]-
y[0])*(xclipl-
x[0])/(
x[1]-
x[0]);
797 yt =
y[0] + (
y[1]-
y[0])*(xclipr-
x[0])/(
x[1]-
x[0]);
801 xt =
x[0] + (
x[1]-
x[0])*(yclipb-
y[0])/(
y[1]-
y[0]);
805 xt =
x[0] + (
x[1]-
x[0])*(yclipt-
y[0])/(
y[1]-
y[0]);
811 code1 =
ClippingCode(xt,yt,xclipl,yclipb,xclipr,yclipt);
815 code2 =
ClippingCode(xt,yt,xclipl,yclipb,xclipr,yclipt);
828 if (
x < xcl1) code = code | 0x1;
829 if (
x > xcl2) code = code | 0x2;
830 if (
y < ycl1) code = code | 0x4;
831 if (
y > ycl2) code = code | 0x8;
886 for (i=0; i<
n; i++) {
887 x2 =
x[i]; y2 =
y[i];
891 slope = (y2-y1)/(
x2-
x1);
895 xc2[nc2] = xclipl; yc2[nc2++] = slope*(xclipl-
x1)+y1;
897 xc2[nc2] =
x2; yc2[nc2++] = y2;
901 xc2[nc2] = xclipl; yc2[nc2++] = slope*(xclipl-
x1)+y1;
902 xc2[nc2] =
x2; yc2[nc2++] = y2;
909 x1 = xc2[nc2-1]; y1 = yc2[nc2-1];
911 for (i=0; i<nc2; i++) {
912 x2 = xc2[i]; y2 = yc2[i];
916 slope = (
x2-
x1)/(y2-y1);
920 xc[nc] =
x1+(yclipt-y1)*slope; yc[nc++] = yclipt;
922 xc[nc] =
x2; yc[nc++] = y2;
926 xc[nc] =
x1+(yclipt-y1)*slope; yc[nc++] = yclipt;
927 xc[nc] =
x2; yc[nc++] = y2;
936 x1 = xc[nc-1]; y1 = yc[nc-1];
938 for (i=0; i<nc; i++) {
939 x2 = xc[i]; y2 = yc[i];
943 slope = (y2-y1)/(
x2-
x1);
947 xc2[nc2] = xclipr; yc2[nc2++] = slope*(xclipr-
x1)+y1;
949 xc2[nc2] =
x2; yc2[nc2++] = y2;
953 xc2[nc2] = xclipr; yc2[nc2++] = slope*(xclipr-
x1)+y1;
954 xc2[nc2] =
x2; yc2[nc2++] = y2;
961 x1 = xc2[nc2-1]; y1 = yc2[nc2-1];
963 for (i=0; i<nc2; i++) {
964 x2 = xc2[i]; y2 = yc2[i];
968 slope = (
x2-
x1)/(y2-y1);
972 xc[nc] =
x1+(yclipb-y1)*slope; yc[nc++] = yclipb;
974 xc[nc] =
x2; yc[nc++] = y2;
978 xc[nc] =
x1+(yclipb-y1)*slope; yc[nc++] = yclipb;
979 xc[nc] =
x2; yc[nc++] = y2;
1016 if (IsA() != TCanvas::Class())
1026 if (!
gROOT->GetListOfCanvases())
return;
1028 gROOT->GetListOfCanvases()->Remove(
this);
1050 if (
gROOT->GetSelectedPad() ==
this)
gROOT->SetSelectedPad(
nullptr);
1075 while ((obj = next())) {
1077 ((
TPad*)obj)->CopyPixmap();
1078 ((
TPad*)obj)->CopyPixmaps();
1104 Int_t pxl, pyl, pxt, pyt;
1109 if (px1 < px2) {pxl = px1; pxt = px2;}
1110 else {pxl = px2; pxt = px1;}
1111 if (py1 < py2) {pyl = py1; pyt = py2;}
1112 else {pyl = py2; pyt = py1;}
1116 if ( (px > pxl && px < pxt) && (py > pyl && py < pyt) ) {
1123 if (py < pyl) dxl += pyl - py;
1124 if (py > pyt) dxl += py - pyt;
1126 if (py < pyl) dxt += pyl - py;
1127 if (py > pyt) dxt += py - pyt;
1129 if (px < pxl) dyl += pxl - px;
1130 if (px > pxt) dyl += px - pxt;
1132 if (px < pxl) dyt += pxl - px;
1133 if (px > pxt) dyt += px - pxt;
1135 Int_t distance = dxl;
1136 if (dxt < distance) distance = dxt;
1137 if (dyl < distance) distance = dyl;
1138 if (dyt < distance) distance = dyt;
1184 arr[1] =
this; arr[2] = (
void*)&nx;arr[3] = (
void*)& ny;
1185 arr[4] = (
void*)&xmargin; arr[5] = (
void *)& ymargin; arr[6] = (
void *)&color;
1186 if ((*
gThreadXAR)(
"PDCD", 7, arr, 0))
return;
1191 if (nx <= 0) nx = 1;
1192 if (ny <= 0) ny = 1;
1199 char *
name =
new char [nchname];
1200 char *title =
new char [nchtitle];
1203 if (xmargin > 0 && ymargin > 0) {
1207 for (iy=0;iy<ny;iy++) {
1208 y2 = 1 - iy*dy - ymargin;
1209 y1 = y2 - dy + 2*ymargin;
1211 if (y1 > y2)
continue;
1212 for (ix=0;ix<nx;ix++) {
1213 x1 = ix*dx + xmargin;
1214 x2 =
x1 +dx -2*xmargin;
1215 if (
x1 >
x2)
continue;
1240 for (
Int_t i=0;i<nx;i++) {
1244 if (i == nx-1)
x2 = 1-xr;
1245 for (
Int_t j=0;j<ny;j++) {
1246 number = j*nx + i +1;
1249 if (j == 0) y2 = 1-yt;
1250 if (j == ny-1) y1 = 0;
1269 if (padsav) padsav->
cd();
1280 Error(
"DivideSquare",
"No canvas associated with this pad.");
1293 Divide( w,
h, xmargin, ymargin, color);
1303 gROOT->MakeDefCanvas();
1335 if (!classobj)
return;
1343 Int_t nd,nf,nc,nkd,nkf,i,j;
1356 Range(0,0,xpad,ypad);
1361 clevel[nlevel] = obj;
1370 if (nlevel >= maxlev-1)
break;
1374 Int_t ilevel, nelem;
1375 for (ilevel=nlevel;ilevel>=0;ilevel--) {
1376 cl = clevel[ilevel];
1378 if (nelem > maxelem) maxelem = nelem;
1379 nc = (nelem/50) + 1;
1389 if (dx < 1.3) dx = 1.3;
1390 tsizcm = tsizcm - 0.03*
Double_t(ncdraw-5);
1391 if (tsizcm < 0.27) tsizcm = 0.27;
1396 for (ilevel=nlevel;ilevel>=0;ilevel--) {
1397 cl = clevel[ilevel];
1399 if (nelem > maxelem) maxelem = nelem;
1400 nc = (nelem/50) + 1;
1402 if (ilevel < nlevel)
x1 =
x2 + 0.5;
1446 if (i >= nkd) { i = 1;
y = y1 - 0.5*dy;
x += 1/
Double_t(nc); }
1447 else { i++;
y -= dy; }
1451 Int_t dim =
d->GetArrayDim();
1455 while (indx < dim ){
1456 ldname = strlen(dname);
1457 snprintf(&dname[ldname],256-ldname,
"[%d]",
d->GetMaxIndex(indx));
1478 while ((
m = (
TMethod *) nextm())) {
1480 !strcmp(
m->GetName(),
"Dictionary" ) ||
1481 !strcmp(
m->GetName(),
"Class_Version" ) ||
1482 !strcmp(
m->GetName(),
"DeclFileName" ) ||
1483 !strcmp(
m->GetName(),
"DeclFileLine" ) ||
1484 !strcmp(
m->GetName(),
"ImplFileName" ) ||
1485 !strcmp(
m->GetName(),
"ImplFileLine" )
1488 if (fcount > nf)
break;
1489 if (i >= nkf) { i = 1;
y = ysep - 0.5*dy;
x += 1/
Double_t(nc); }
1490 else { i++;
y -= dy; }
1495 for (j=ilevel-1;j>=0;j--) {
1496 if (cl == clevel[ilevel]) {
1497 if (clevel[j]->GetMethodAny((
char*)
m->GetName())) {
1544 Int_t pxmin,pxmax,pymin,pymax,pxold,pyold,px,py;
1556 pxmax = canvas->
GetWw();
1558 pymax = cpad->
GetWh();
1562 if(pxold)
gVirtualX->DrawLine(pxold,pymin,pxold,pymax);
1563 if(pyold)
gVirtualX->DrawLine(pxmin,pyold,pxmax,pyold);
1610 if (
this != padsav) {
1611 Warning(
"DrawFrame",
"Must be called for the current pad only");
1618 if (hframe)
delete hframe;
1628 for (
Int_t i=1;i<=nbins;i++) {
1631 hframe =
new TH1F(
"hframe",title,nbins,xbins);
1644 if (padsav) padsav->
cd();
1660 gPad->SetFillColor(0);
1674 for (i=0;i<10;i++) {
1681 box->SetFillStyle(1001);
1682 box->SetFillColor(color);
1683 box->DrawBox(xlow, ylow, xup, yup);
1684 box->SetFillStyle(0);
1685 box->SetLineColor(1);
1686 box->DrawBox(xlow, ylow, xup, yup);
1716 const Int_t kMaxDiff = 5;
1717 const Int_t kMinSize = 20;
1718 static Int_t pxorg, pyorg;
1719 static Int_t px1, px2, py1, py2, pxl, pyl, pxt, pyt, pxold, pyold;
1720 static Int_t px1p, px2p, py1p, py2p, pxlp, pylp, pxtp, pytp;
1721 static Bool_t pA, pB, pC, pD, pTop, pL, pR, pBot, pINSIDE;
1744 pA = pB = pC = pD = pTop = pL = pR = pBot = pINSIDE =
kFALSE;
1788 if (newcode)
return;
1855 pA = pB = pC = pD = pTop = pL = pR = pBot = pINSIDE =
kFALSE;
1859 pxold = pxl; pyold = pyl; pA =
kTRUE;
1864 pxold = pxt; pyold = pyl; pB =
kTRUE;
1869 pxold = pxt; pyold = pyt; pC =
kTRUE;
1874 pxold = pxl; pyold = pyt; pD =
kTRUE;
1878 if ((px > pxl+kMaxDiff && px < pxt-kMaxDiff) &&
1880 pxold = pxl; pyold = pyl; pTop =
kTRUE;
1884 if ((px > pxl+kMaxDiff && px < pxt-kMaxDiff) &&
1886 pxold = pxt; pyold = pyt; pBot =
kTRUE;
1890 if ((py > pyl+kMaxDiff && py < pyt-kMaxDiff) &&
1892 pxold = pxl; pyold = pyl; pL =
kTRUE;
1896 if ((py > pyl+kMaxDiff && py < pyt-kMaxDiff) &&
1898 pxold = pxt; pyold = pyt; pR =
kTRUE;
1902 if ((px > pxl+kMaxDiff && px < pxt-kMaxDiff) &&
1903 (py > pyl+kMaxDiff && py < pyt-kMaxDiff)) {
1904 pxold = px; pyold = py; pINSIDE =
kTRUE;
1912 if (pA || pB || pC || pD || pTop || pL || pR || pBot)
1915 if (!pA && !pB && !pC && !pD && !pTop && !pL && !pR && !pBot && !pINSIDE)
1928 if (px > pxt-kMinSize) { px = pxt-kMinSize; wx = px; }
1929 if (py > pyt-kMinSize) { py = pyt-kMinSize; wy = py; }
1930 if (px < pxlp) { px = pxlp; wx = px; }
1931 if (py < pylp) { py = pylp; wy = py; }
1949 if (px < pxl+kMinSize) { px = pxl+kMinSize; wx = px; }
1950 if (py > pyt-kMinSize) { py = pyt-kMinSize; wy = py; }
1951 if (px > pxtp) { px = pxtp; wx = px; }
1952 if (py < pylp) { py = pylp; wy = py; }
1970 if (px < pxl+kMinSize) { px = pxl+kMinSize; wx = px; }
1971 if (py < pyl+kMinSize) { py = pyl+kMinSize; wy = py; }
1972 if (px > pxtp) { px = pxtp; wx = px; }
1973 if (py > pytp) { py = pytp; wy = py; }
1991 if (px > pxt-kMinSize) { px = pxt-kMinSize; wx = px; }
1992 if (py < pyl+kMinSize) { py = pyl+kMinSize; wy = py; }
1993 if (px < pxlp) { px = pxlp; wx = px; }
1994 if (py > pytp) { py = pytp; wy = py; }
2013 if (py2 > py1-kMinSize) { py2 = py1-kMinSize; wy = py2; }
2014 if (py2 < py2p) { py2 = py2p; wy = py2; }
2029 if (py1 < py2+kMinSize) { py1 = py2+kMinSize; wy = py1; }
2030 if (py1 > py1p) { py1 = py1p; wy = py1; }
2045 if (px1 > px2-kMinSize) { px1 = px2-kMinSize; wx = px1; }
2046 if (px1 < px1p) { px1 = px1p; wx = px1; }
2062 if (px2 < px1+kMinSize) { px2 = px1+kMinSize; wx = px2; }
2063 if (px2 > px2p) { px2 = px2p; wx = px2; }
2078 Int_t dx = px - pxold;
2079 Int_t dy = py - pyold;
2080 px1 += dx; py1 += dy; px2 += dx; py2 += dy;
2081 if (px1 < px1p) { dx = px1p - px1; px1 += dx; px2 += dx; wx = px+dx; }
2082 if (px2 > px2p) { dx = px2 - px2p; px1 -= dx; px2 -= dx; wx = px-dx; }
2083 if (py1 > py1p) { dy = py1 - py1p; py1 -= dy; py2 -= dy; wy = py-dy; }
2084 if (py2 < py2p) { dy = py2p - py2; py1 += dy; py2 += dy; wy = py+dy; }
2098 x1 =
x2 = y1 = y2 = 0;
2125 if (pTop || pBot || pL || pR || pINSIDE) {
2132 if (px != pxorg || py != pyorg) {
2156 if (pINSIDE)
gPad->ShowGuidelines(
this, event);
2157 if (pTop)
gPad->ShowGuidelines(
this, event,
't',
true);
2158 if (pBot)
gPad->ShowGuidelines(
this, event,
'b',
true);
2159 if (pL)
gPad->ShowGuidelines(
this, event,
'l',
true);
2160 if (pR)
gPad->ShowGuidelines(
this, event,
'r',
true);
2161 if (pA)
gPad->ShowGuidelines(
this, event,
'1',
true);
2162 if (pB)
gPad->ShowGuidelines(
this, event,
'2',
true);
2163 if (pC)
gPad->ShowGuidelines(
this, event,
'3',
true);
2164 if (pD)
gPad->ShowGuidelines(
this, event,
'4',
true);
2173 if (
gROOT->IsEscaped()) {
2178 if (opaque||ropaque) {
2181 x1 =
x2 = y1 = y2 = 0;
2207 if (pTop || pBot || pL || pR || pINSIDE) {
2214 if (pA || pB || pC || pD || pTop || pL || pR || pBot)
2220 if (px != pxorg || py != pyorg) {
2257 event =
gVirtualX->RequestLocator(1, 1, px, py);
2296 static Int_t axisNumber;
2298 static Int_t px1old, py1old, px2old, py2old;
2302 static TBox *zoombox;
2303 Double_t zbx1=0,zbx2=0,zby1=0,zby2=0;
2310 if (strstr(opt,
"cont4")) {
2319 if (!strcmp(axis->
GetName(),
"xaxis")) {
2323 if (!strcmp(axis->
GetName(),
"yaxis")) {
2327 if (!strcmp(axis->
GetName(),
"zaxis")) {
2333 if (axisNumber == 1) {
2339 }
else if (axisNumber == 2) {
2355 if (axisNumber == 1) {
2360 }
else if (axisNumber == 2) {
2374 zoombox =
new TBox(zbx1, zby1, zbx2, zby2);
2385 if (!opaque)
gVirtualX->SetLineColor(-1);
2393 if (axisNumber == 1) {
2403 if (axisNumber == 1) {
2408 }
else if (axisNumber == 2) {
2423 zoombox->
SetX1(zbx1);
2424 zoombox->
SetY1(zby1);
2425 zoombox->
SetX2(zbx2);
2426 zoombox->
SetY2(zby2);
2459 if (
gROOT->IsEscaped()) {
2461 if (opaque && zoombox) {
2470 if (ratio1 > ratio2) {
2475 if (ratio2 - ratio1 > 0.05) {
2477 if (axisNumber == 3 && hobj && hobj->
GetDimension() != 3) {
2486 Float_t newmin = zmin + (zmax-zmin)*ratio1;
2487 Float_t newmax = zmin + (zmax-zmin)*ratio2;
2511 if (axisNumber == 1) {
2519 }
else if (axisNumber == 2) {
2547 xmin = ((
xmin-xmi)/(xma-xmi))*(up-low)+low;
2548 xmax = ((
xmax-xmi)/(xma-xmi))*(up-low)+low;
2551 if (!strcmp(axis->
GetName(),
"xaxis")) axisNumber = 1;
2552 if (!strcmp(axis->
GetName(),
"yaxis")) axisNumber = 2;
2553 if (ratio2 - ratio1 > 0.05) {
2560 if (axisNumber == 1) axis->
SetRange(bin1,bin2);
2561 if (axisNumber == 2 && hobj1) {
2578 while ((obj= next())) {
2581 if (hobj == hobj1)
continue;
2584 if (axisNumber == 1) {
2586 }
else if (axisNumber == 2) {
2629 if (found)
return found;
2632 while ((cur = next())) {
2635 if (found)
return found;
2650 if (found)
return found;
2653 while ((cur = next())) {
2656 if (found)
return found;
2731 if (
fCanvas ==
this)
return nullptr;
2740 if (
fCanvas ==
this)
return nullptr;
2749 if (
fCanvas ==
this)
return nullptr;
2896 while ((obj=next())) {
2900 if (found)
return found;
2910 if (!subpadnumber) {
2917 while ((obj = next())) {
2920 if (pad->
GetNumber() == subpadnumber)
return pad;
2967 if (color <= 0)
return;
2985 gROOT->SetSelectedPad(
this);
3002 <<
" Name= "<<
GetName()<<
" Title= "<<
GetTitle()<<
" Option="<<option<<std::endl;
3014 if (opt.
Index(
"pfc")>=0 || opt.
Index(
"plc")>=0 || opt.
Index(
"pmc")>=0) {
3032 if (i>=ncolors) i = ncolors-1;
3044 Int_t const cellSize = 10;
3063 for (
int i = 0; i<
fCGnx; i++) {
3064 for (
int j = 0; j<
fCGny; j++) {
3076 for (
int i=0; i<np; i++) {
3085 TIter nextgraph(grlist);
3091 TIter nexthist(hlist);
3093 while ((oh = nexthist())) {
3107 for (
int r=i;
r<w+i;
r++) {
3108 for (
int c=j;
c<
h+j;
c++) {
3136 for (
Int_t i = 0; i<nxmax; i++) {
3137 for (
Int_t j = 0; j<=nymax; j++) {
3150#define NotFree(i, j) fCollideGrid[TMath::Max(TMath::Min(i+j*fCGnx,fCGnx*fCGny),0)] = kFALSE;
3177 yt = y1; y1 = y2; y2 = yt;
3179 for (i=
x1+1; i<
x2; i++) {
3186 yt = y1; y1 = y2; y2 = yt;
3189 for (j=y1+1; j<y2; j++) {
3209 for (
int i =
x1; i<=
x2; i++) {
3210 for (
int j = y1; j<=y2; j++)
NotFree(i, j);
3228 for (i =
x1; i<=
x2; i++) {
3233 for (i = y1; i<=y2; i++) {
3251 for (
Int_t i=1; i<
n; i++) {
3252 g->GetPoint(i-1,
x1,y1);
3253 g->GetPoint(i ,
x2,y2);
3267 (
int)((y1-
fY1)/ys), (
int)((y2-
fY1)/ys));
3280 if (
name.Index(
"hframe") >= 0)
return;
3285 bool haserrors =
false;
3286 TString drawOption =
h->GetDrawOption();
3290 if (drawOption.
Index(
"hist") < 0) {
3291 if (drawOption.
Index(
"e") >= 0) haserrors =
true;
3294 Int_t nx =
h->GetNbinsX();
3299 for (i = 1; i<nx; i++) {
3301 x1l =
h->GetBinCenter(i);
3307 y1l =
h->GetBinContent(i)-
h->GetBinErrorLow(i);
3313 y2l =
h->GetBinContent(i)+
h->GetBinErrorUp(i);
3319 for (j=y1; j<=y2; j++) {
3323 x1l =
h->GetBinLowEdge(i);
3329 y1l =
h->GetBinContent(i);
3336 x1l =
h->GetBinLowEdge(i)+
h->GetBinWidth(i);
3358 box->SetFillColorAlpha(
kRed,0.5);
3369 for (
int i = 0; i<
fCGnx; i++) {
3372 for (
int j = 0; j<
fCGny; j++) {
3373 if (
gPad->GetLogx()) {
3380 if (
gPad->GetLogy()) {
3389 box->DrawBox(X1L, Y1L, X2L, Y2L);
3391 box->SetFillColorAlpha(
kRed,t);
3392 box->DrawBox(X1L, Y1L, X2L, Y2L);
3396 if (t==0.15) t = 0.1;
3490 began3DScene =
kTRUE;
3497 if (padsav) padsav->
cd();
3526 if (color < 0) color = -color;
3533 if (bordersize <= 0) bordersize = 2;
3554 if (px1 < px2) {xl =
fX1; xt =
fX2; }
3555 else {xl =
fX2; xt =
fX1;}
3556 if (py1 > py2) {yl =
fY1; yt =
fY2;}
3557 else {yl =
fY2; yt =
fY1;}
3559 Double_t frameXs[7] = {}, frameYs[7] = {};
3563 frameXs[0] = xl; frameYs[0] = yl;
3564 frameXs[1] = xl + realBsX; frameYs[1] = yl + realBsY;
3565 frameXs[2] = frameXs[1]; frameYs[2] = yt - realBsY;
3566 frameXs[3] = xt - realBsX; frameYs[3] = frameYs[2];
3567 frameXs[4] = xt; frameYs[4] = yt;
3568 frameXs[5] = xl; frameYs[5] = yt;
3569 frameXs[6] = xl; frameYs[6] = yl;
3576 frameXs[0] = xl; frameYs[0] = yl;
3577 frameXs[1] = xl + realBsX; frameYs[1] = yl + realBsY;
3578 frameXs[2] = xt - realBsX; frameYs[2] = frameYs[1];
3579 frameXs[3] = frameXs[2]; frameYs[3] = yt - realBsY;
3580 frameXs[4] = xt; frameYs[4] = yt;
3581 frameXs[5] = xt; frameYs[5] = yl;
3582 frameXs[6] = xl; frameYs[6] = yl;
3715 ((
TPad*)obj)->PaintModified();
3727 began3DScene =
kTRUE;
3735 if (padsav) padsav->
cd();
3759 if (option[0] ==
's') {
3772 xb[0] =
x1; xb[1] =
x1; xb[2] =
x2; xb[3] =
x2;
3773 yb[0] = y1; yb[1] = y2; yb[2] = y2; yb[3] = y1;
3822 if (option[0] ==
's') {
3825 if (style0 >= 3100 && style0 < 4000) {
3827 xb[0] =
x1; xb[1] =
x1; xb[2] =
x2; xb[3] =
x2;
3828 yb[0] = y1; yb[1] = y2; yb[2] = y2; yb[3] = y1;
3834 if (option[0] ==
'l') {
3854 while ((obj = next())) {
3856 if (obj == stop)
break;
3857 ((
TPad*)obj)->CopyBackgroundPixmap(
x,
y);
3858 ((
TPad*)obj)->CopyBackgroundPixmaps((
TPad*)obj, stop,
x,
y);
3877 Warning(
"TPad::PaintFillArea",
"Float_t signature is obsolete. Use Double_t signature.");
3895 std::vector<Double_t>
x(nc, 0.);
3896 std::vector<Double_t>
y(nc, 0.);
3905 if (fillstyle >= 3100 && fillstyle < 4000) {
3927 for (
int i=0; i<
n; i++) {
3971 static Double_t ang1[10] = { 0., 10., 20., 30., 45.,5., 60., 70., 80., 89.99};
3972 static Double_t ang2[10] = {180.,170.,160.,150.,135.,5.,120.,110.,100., 89.99};
3974 Int_t fasi = FillStyle%1000;
3977 Int_t iAng1 = fasi%10;
4010 if (ang1[iAng1] != 5.)
PaintHatches(dy, ang1[iAng1], nn, xx, yy);
4011 if (ang2[iAng2] != 5.)
PaintHatches(dy, ang2[iAng2], nn, xx, yy);
4038 const Int_t maxnbi = 100;
4039 Double_t xli[maxnbi], xlh[2], ylh[2], xt1, xt2, yt1, yt2;
4040 Double_t ll,
x,
y,
x1,
x2, y1, y2,
a,
b, xi, xip, xin, yi, yip;
4046 ratiox = 1./(rwxmax-rwxmin);
4047 ratioy = 1./(rwymax-rwymin);
4060 gPad->GetPadPar(x1p,y1p,x2p,y2p);
4069 for (i=1; i<=nn; i++) {
4070 x = wndc*ratiox*(xx[i-1]-rwxmin);
4071 y = hndc*ratioy*(yy[i-1]-rwymin);
4072 yrot = sina*
x+cosa*
y;
4078 for (ycur=
ymax; ycur>=
ymin; ycur=ycur-dy) {
4080 for (i=2; i<=nn+1; i++) {
4083 if (i == nn+1) i2=1;
4084 x1 = wndc*ratiox*(xx[i1-1]-rwxmin);
4085 y1 = hndc*ratioy*(yy[i1-1]-rwymin);
4086 x2 = wndc*ratiox*(xx[i2-1]-rwxmin);
4087 y2 = hndc*ratioy*(yy[i2-1]-rwymin);
4088 xt1 = cosa*
x1-sina*y1;
4089 yt1 = sina*
x1+cosa*y1;
4090 xt2 = cosa*
x2-sina*y2;
4091 yt2 = sina*
x2+cosa*y2;
4102 if ((yi <= ycur) && (ycur < yip)) {
4104 if (nbi >= maxnbi)
return;
4114 if (nbi >= maxnbi)
return;
4117 if (nbi >= maxnbi)
return;
4124 a = (yt1-yt2)/(xt1-xt2);
4125 b = (yt2*xt1-xt2*yt1)/(xt1-xt2);
4134 if ((xi <= xin) && (xin < xip) &&
4138 if (nbi >= maxnbi)
return;
4147 for (i=1; i<=
m; i++) {
4148 if (xli[i] < xli[i-1]) {
4156 if (
inv == 0)
goto L50;
4162 if (nbi%2 != 0)
continue;
4164 for (i=1; i<=nbi; i=i+2) {
4166 xlh[0] = cosb*xli[i-1]-sinb*ycur;
4167 ylh[0] = sinb*xli[i-1]+cosb*ycur;
4168 xlh[1] = cosb*xli[i] -sinb*ycur;
4169 ylh[1] = sinb*xli[i] +cosb*ycur;
4171 xlh[0] = (xlh[0]/wndc)*(rwxmax-rwxmin)+rwxmin;
4172 ylh[0] = (ylh[0]/hndc)*(rwymax-rwymin)+rwymin;
4173 xlh[1] = (xlh[1]/wndc)*(rwxmax-rwxmin)+rwxmin;
4174 ylh[1] = (ylh[1]/hndc)*(rwymax-rwymin)+rwymin;
4175 gPad->PaintLine(xlh[0], ylh[0], xlh[1], ylh[1]);
4186 x[0] =
x1;
x[1] =
x2;
y[0] = y1;
y[1] = y2;
4236 for (i=0;i<3;i++) temp[i] = p1[i];
4238 for (i=0;i<3;i++) temp[i] = p2[i];
4240 PaintLine(xpad[0],xpad[1],xpad[3],xpad[4]);
4254 for (i=0;i<3;i++) temp[i] = p1[i];
4256 for (i=0;i<3;i++) temp[i] = p2[i];
4258 PaintLine(xpad[0],xpad[1],xpad[3],xpad[4]);
4274 Int_t i, i1=-1,np=1;
4275 for (i=0; i<
n-1; i++) {
4287 if (iclip == 0 && i <
n-2)
continue;
4321 if (option && (option[0] ==
'C')) mustClip =
kFALSE;
4324 Int_t i, i1=-1, np=1, iclip=0;
4326 for (i=0; i <
n-1; i++) {
4340 if (iclip == 0 && i <
n-2)
continue;
4372 for (
Int_t i=0; i<
n; i++) {
4391 for (
Int_t i = 1; i <
n; i++)
4410 for (i=0; i<
n; i++) {
4414 if (i <
n-1)
continue;
4416 if (np == 0)
continue;
4441 for (i=0; i<
n; i++) {
4445 if (i <
n-1)
continue;
4447 if (np == 0)
continue;
4537 if (
gPad == 0)
return 0;
4544 if (
this !=
gPad->GetCanvas()) {
4553 TPad *picked =
this;
4557 pickobj = &dummyLink;
4586 pick = ((
TPad*)obj)->
Pick(px, py, pickobj);
4591 }
else if (!
gROOT->GetEditorMode()) {
4598 if (dist == 0)
break;
4613 if (
fView && !gotPrim) {
4637 if (picked ==
this) {
4660 while ((obj = next()))
4694 ((
TPad*)
this)->SaveAs(filename);
4706 while ((obj = next())) {
4861 TString psname, fs1 = filenam;
4878 const char *opt_default =
"ps";
4880 TString opt = !option ? opt_default : option;
4902 if (strstr(opt,
"gif+")) {
4905 }
else if (strstr(opt,
"gif")) {
4908 }
else if (strstr(opt,
"png")) {
4911 }
else if (strstr(opt,
"jpg")) {
4914 }
else if (strstr(opt,
"tiff")) {
4917 }
else if (strstr(opt,
"xpm")) {
4920 }
else if (strstr(opt,
"bmp")) {
4927 if (!
gROOT->IsBatch() && image) {
4930 Color_t hc =
gPad->GetCanvas()->GetHighLightColor();
4931 gPad->GetCanvas()->SetHighLightColor(-1);
4939 Info(
"Print",
"GIF file %s has been created", psname.
Data());
4941 gPad->GetCanvas()->SetHighLightColor(hc);
4945 Color_t hc =
gPad->GetCanvas()->GetHighLightColor();
4946 gPad->GetCanvas()->SetHighLightColor(-1);
4953 Info(
"Print",
"file %s has been created", psname.
Data());
4955 gPad->GetCanvas()->SetHighLightColor(hc);
4957 Warning(
"Print",
"Unsupported image format %s", psname.
Data());
4963 if (strstr(opt,
"cxx")) {
4969 if (strstr(opt,
"root")) {
4975 if (strstr(opt,
"xml")) {
4982 if (strstr(opt,
"json")) {
4988 if (strstr(opt,
"svg")) {
5003 if ((
h =
gROOT->GetPluginManager()->FindHandler(
"TVirtualPS",
"svg"))) {
5004 if (
h->LoadPlugin() == -1)
5030 if (strstr(opt,
"tex")) {
5045 if ((
h =
gROOT->GetPluginManager()->FindHandler(
"TVirtualPS",
"tex"))) {
5046 if (
h->LoadPlugin() == -1)
5081 copen = psname.
EndsWith(
"(");
if (copen) psname[psname.
Length()-1] = 0;
5082 cclose = psname.
EndsWith(
")");
if (cclose) psname[psname.
Length()-1] = 0;
5083 copenb = psname.
EndsWith(
"[");
if (copenb) psname[psname.
Length()-1] = 0;
5084 ccloseb = psname.
EndsWith(
"]");
if (ccloseb) psname[psname.
Length()-1] = 0;
5088 if (copen || copenb) mustClose =
kFALSE;
5089 if (cclose || ccloseb) mustClose =
kTRUE;
5100 if (ratio < 1) pstype = 112;
5101 if (strstr(opt,
"Portrait")) pstype = 111;
5102 if (strstr(opt,
"Landscape")) pstype = 112;
5103 if (strstr(opt,
"eps")) pstype = 113;
5104 if (strstr(opt,
"Preview")) pstype = 113;
5112 if (strstr(opt,
"pdf") || strstr(opt,
"Title:") || strstr(opt,
"EmbedFonts")) {
5113 if ((
h =
gROOT->GetPluginManager()->FindHandler(
"TVirtualPS",
"pdf"))) {
5114 if (
h->LoadPlugin() == -1)
return;
5119 if ((
h =
gROOT->GetPluginManager()->FindHandler(
"TVirtualPS",
"image"))) {
5120 if (
h->LoadPlugin() == -1)
return;
5124 if ((
h =
gROOT->GetPluginManager()->FindHandler(
"TVirtualPS",
"ps"))) {
5125 if (
h->LoadPlugin() == -1)
return;
5133 if (titlePos !=
kNPOS) {
5140 if (!strstr(opt,
"pdf") || image) {
5157 if (!copen)
Info(
"Print",
"%s file %s has been created", opt.
Data(), psname.
Data());
5158 else Info(
"Print",
"%s file %s has been created using the current canvas", opt.
Data(), psname.
Data());
5167 if (titlePos !=
kNPOS) {
5174 if (cclose)
Info(
"Print",
"Current canvas added to %s file %s and file closed", opt.
Data(), psname.
Data());
5175 else Info(
"Print",
"%s file %s has been closed", opt.
Data(), psname.
Data());
5180 Info(
"Print",
"Current canvas added to %s file %s", opt.
Data(), psname.
Data());
5186 if (strstr(opt,
"EmbedFonts")) {
5187 gSystem->
Exec(
Form(
"gs -quiet -dSAFER -dNOPLATFONTS -dNOPAUSE -dBATCH -sDEVICE=pdfwrite -dUseCIEColor -dCompatibilityLevel=1.4 -dPDFSETTINGS=/printer -dCompatibilityLevel=1.4 -dMaxSubsetPct=100 -dSubsetFonts=true -dEmbedAllFonts=true -sOutputFile=pdf_temp.pdf -f %s",
5202 if ((
x1 >=
x2) || (y1 >= y2)) {
5203 Error(
"Range",
"illegal world coordinates range: x1=%f, y1=%f, x2=%f, y2=%f",
x1,y1,
x2,y2);
5241 Error(
"RangeAxis",
"illegal axis coordinates range: xmin=%f, ymin=%f, xmax=%f, ymax=%f",
5312 TH1 *hobj =
nullptr;
5318 while ((obj = next())) {
5330 if (
g) hobj =
g->GetHistogram();
5347 gPad->GetUxmax(),
gPad->GetUymax());
5349 b->SetLineStyle(
gPad->GetFrameLineStyle());
5350 b->SetLineWidth(
gPad->GetFrameLineWidth());
5351 b->SetLineColor(
gPad->GetFrameLineColor());
5355 if (padsav) padsav->
cd();
5485 Error(
"ResizePad",
"Cannot resize pad. No current pad available.");
5488 if (
gPad->GetWw()==0.0||
gPad->GetWh()==0.0) {
5489 Warning(
"ResizePad",
"gPad has at least one zero dimension.");
5493 Warning(
"ResizePad",
"The pad has at least one zero dimension.");
5498 if (
this ==
gPad->GetCanvas()) {
5506 Warning(
"ResizePad",
"The parent pad has at least one zero dimension.");
5555 while ((obj = next())) {
5557 ((
TPad*)obj)->ResizePad(option);
5561 if (
gPad->IsBatch())
5580 Warning(
"ResizePad",
"Inf/NaN propagated to the pad. Check drawn objects.");
5581 if (w <= 0 || w > 10000) {
5582 Warning(
"ResizePad",
"%s width changed from %d to %d\n",
GetName(),w,10);
5585 if (h <= 0 || h > 10000) {
5586 Warning(
"ResizePad",
"%s height changed from %d to %d\n",
GetName(),
h,10);
5603 if (padsav ==
this) {
5638 Int_t lenfil = filename ? strlen(filename) : 0;
5641 else psname = filename;
5652 ((
TPad*)
this)->Print(psname,
"gif");
5704 const char *cname =
GetName();
5705 Int_t nch = strlen(cname);
5707 strlcpy(lcname,cname,10);
5708 for (
Int_t k=1;k<=nch;k++) {
if (lcname[nch-k] ==
' ') lcname[nch-k] = 0;}
5709 if (lcname[0] == 0) {
5710 if (
this ==
gPad->GetCanvas()) {strlcpy(lcname,
"c1",10); nch = 2;}
5711 else {strlcpy(lcname,
"pad",10); nch = 3;}
5717 if (
this !=
gPad->GetCanvas()) {
5718 out <<
" "<<std::endl;
5719 out <<
"// ------------>Primitives in pad: "<<
GetName()<<std::endl;
5721 out<<
" TPad *"<<cname<<
" = new TPad("<<quote<<
GetName()<<quote<<
", "<<quote<<
GetTitle()
5728 out<<
" "<<cname<<
"->Draw();"<<std::endl;
5729 out<<
" "<<cname<<
"->cd();"<<std::endl;
5731 out<<
" "<<cname<<
"->Range("<<
fX1<<
","<<
fY1<<
","<<
fX2<<
","<<
fY2<<
");"<<std::endl;
5736 static Int_t viewNumber = 0;
5737 out<<
" TView *view"<<++viewNumber<<
" = TView::CreateView(1);"<<std::endl;
5738 out<<
" view"<<viewNumber<<
"->SetRange("<<rmin[0]<<
","<<rmin[1]<<
","<<rmin[2]<<
","
5739 <<rmax[0]<<
","<<rmax[1]<<
","<<rmax[2]<<
");"<<std::endl;
5744 out<<
" "<<cname<<
"->SetFillColor(ci);" << std::endl;
5746 out<<
" "<<cname<<
"->SetFillColor("<<
GetFillColor()<<
");"<<std::endl;
5749 out<<
" "<<cname<<
"->SetFillStyle("<<
GetFillStyle()<<
");"<<std::endl;
5752 out<<
" "<<cname<<
"->SetBorderMode("<<
GetBorderMode()<<
");"<<std::endl;
5755 out<<
" "<<cname<<
"->SetBorderSize("<<
GetBorderSize()<<
");"<<std::endl;
5758 out<<
" "<<cname<<
"->SetLogx();"<<std::endl;
5761 out<<
" "<<cname<<
"->SetLogy();"<<std::endl;
5764 out<<
" "<<cname<<
"->SetLogz();"<<std::endl;
5767 out<<
" "<<cname<<
"->SetGridx();"<<std::endl;
5770 out<<
" "<<cname<<
"->SetGridy();"<<std::endl;
5773 out<<
" "<<cname<<
"->SetTickx("<<
GetTickx()<<
");"<<std::endl;
5776 out<<
" "<<cname<<
"->SetTicky("<<
GetTicky()<<
");"<<std::endl;
5779 out<<
" "<<cname<<
"->SetTheta("<<
GetTheta()<<
");"<<std::endl;
5782 out<<
" "<<cname<<
"->SetPhi("<<
GetPhi()<<
");"<<std::endl;
5785 out<<
" "<<cname<<
"->SetLeftMargin("<<
GetLeftMargin()<<
");"<<std::endl;
5788 out<<
" "<<cname<<
"->SetRightMargin("<<
GetRightMargin()<<
");"<<std::endl;
5791 out<<
" "<<cname<<
"->SetTopMargin("<<
GetTopMargin()<<
");"<<std::endl;
5794 out<<
" "<<cname<<
"->SetBottomMargin("<<
GetBottomMargin()<<
");"<<std::endl;
5800 out<<
" "<<cname<<
"->SetFrameFillColor(ci);" << std::endl;
5813 out<<
" "<<cname<<
"->SetFrameLineColor(ci);" << std::endl;
5833 out<<
" "<<cname<<
"->SetFrameFillColor(ci);" << std::endl;
5835 out<<
" "<<cname<<
"->SetFrameFillColor("<<frame->
GetFillColor()<<
");"<<std::endl;
5838 out<<
" "<<cname<<
"->SetFrameFillStyle("<<frame->
GetFillStyle()<<
");"<<std::endl;
5841 out<<
" "<<cname<<
"->SetFrameLineStyle("<<frame->
GetLineStyle()<<
");"<<std::endl;
5846 out<<
" "<<cname<<
"->SetFrameLineColor(ci);" << std::endl;
5848 out<<
" "<<cname<<
"->SetFrameLineColor("<<frame->
GetLineColor()<<
");"<<std::endl;
5851 out<<
" "<<cname<<
"->SetFrameLineWidth("<<frame->
GetLineWidth()<<
");"<<std::endl;
5854 out<<
" "<<cname<<
"->SetFrameBorderMode("<<frame->
GetBorderMode()<<
");"<<std::endl;
5857 out<<
" "<<cname<<
"->SetFrameBorderSize("<<frame->
GetBorderSize()<<
");"<<std::endl;
5865 while ((obj = next())) {
5867 if (!strcmp(obj->
GetName(),
"Graph")) ((
TGraph*)obj)->SetName(
Form(
"Graph%d",grnum++));
5870 out<<
" "<<cname<<
"->Modified();"<<std::endl;
5872 if (padsav) padsav->
cd();
5885 Error(
"SetAspectRatio",
"cannot fix aspect ratio, height of pad is 0");
5909 while ((obj = next())) {
5923 if (fstyle == 0) fstyle = 4000;
5986 if ((xlow < 0) || (xlow > 1) || (ylow < 0) || (ylow > 1)) {
5987 Error(
"TPad",
"illegal bottom left position: x=%f, y=%f", xlow, ylow);
5990 if ((xup < 0) || (xup > 1) || (yup < 0) || (yup > 1)) {
5991 Error(
"TPad",
"illegal top right position: x=%f, y=%f", xup, yup);
5994 if (xup-xlow <= 0) {
5995 Error(
"TPad",
"illegal width: %f", xup-xlow);
5998 if (yup-ylow <= 0) {
5999 Error(
"TPad",
"illegal height: %f", yup-ylow);
6036 SetPad(xlow, ylow, xup, yup);
6044 if (!view)
delete fView;
6117 x1 =
x2 = y1 = y2 = 0;
6119 if (aBBox.
fX<bBBox.
fX) {
6135 else if (mode ==
'y') {
6136 if (aBBox.
fY<bBBox.
fY) {
6174 : fa(0), fb(0), fdist(0), fdir(
' ')
6178 : fa(
a), fb(
b), fdist(
dist), fdir(direction)
6204 std::vector<dField> curDist;
6205 std::vector<dField> otherDist;
6215 Int_t dSizeArrow = 12;
6217 movedX = movedY =
false;
6220 if (mode !=
'i') resize =
true;
6228 static TPad * tmpGuideLinePad;
6231 if (tmpGuideLinePad) {
6232 if (
object == tmpGuideLinePad) {
6233 tmpGuideLinePad->
Delete();
6234 tmpGuideLinePad = 0;
6237 tmpGuideLinePad->
Delete();
6238 tmpGuideLinePad = 0;
6242 prims =
gPad->GetListOfPrimitives();
6249 if (!tmpGuideLinePad){
6250 tmpGuideLinePad =
new TPad(
"tmpGuideLinePad",
"tmpGuideLinePad", 0, 0, 1, 1);
6256 tmpGuideLinePad->
Draw();
6257 tmpGuideLinePad->
cd();
6260 if (cling && !
log) threshold = 7;
6273 MX =
gPad->GetX1() + 0.5 * (
gPad->GetX2()-
gPad->GetX1());
6274 MY =
gPad->GetY1() + 0.5 * (
gPad->GetY2()-
gPad->GetY1());
6275 pMX =
gPad->XtoPixel(MX);
6276 pMY =
gPad->YtoPixel(MY);
6279 if (cling && (!resize)) {
6287 L->SetLineColor(lineColor);
6291 if (cling && (!resize)) {
6299 L->SetLineColor(lineColor);
6303 for (
UInt_t i = 0; i<
n; i++) {
6309 if (cling && (!resize)) {
6316 L->SetLineColor(lineColor);
6321 if (cling && (!resize)) {
6329 L->SetLineColor(lineColor);
6336 for (
UInt_t i = 0; i<
n; i++) {
6339 aBBox =
a->GetBBox();
6340 for (
UInt_t j = i+1; j<
n; j++) {
6343 bBBox =
b->GetBBox();
6348 dField abDist = dField();
6351 if ((
b != cur)&&(
a != cur)) otherDist.push_back(abDist);
6352 else curDist.push_back(abDist);
6356 dField abDist = dField();
6359 if ((
b != cur)&&(
a != cur)) otherDist.push_back(abDist);
6360 else curDist.push_back(abDist);
6368 for (
UInt_t i = 0; i<curDist.size(); i++) {
6369 for (
UInt_t j = 0; j<otherDist.size(); j++) {
6370 if ((curDist[i].fdir == otherDist[j].fdir) && (otherDist[j].fdir==
'x') && (
TMath::Abs(curDist[i].fdist-otherDist[j].fdist)<threshold)) {
6371 if (cling && (!movedX) && (!resize)) {
6377 DrawDist(curDist[i].fa->GetBBox(), curDist[i].fb->GetBBox(),
'x');
6378 DrawDist(otherDist[j].fa->GetBBox(), otherDist[j].fb->GetBBox(),
'x');
6380 if ((curDist[i].fdir == otherDist[j].fdir) && (otherDist[j].fdir==
'y') && (
TMath::Abs(curDist[i].fdist-otherDist[j].fdist)<threshold)) {
6381 if (cling && (!movedY) && (!resize)) {
6387 DrawDist(curDist[i].fa->GetBBox(), curDist[i].fb->GetBBox(),
'y');
6388 DrawDist(otherDist[j].fa->GetBBox(), otherDist[j].fb->GetBBox(),
'y');
6391 for (
UInt_t j = i; j<curDist.size(); j++) {
6393 if ((curDist[i].fdir == curDist[j].fdir) && (curDist[j].fdir==
'x') && (
TMath::Abs(curDist[i].fdist-curDist[j].fdist)<threshold)) {
6394 if (cling && (!movedX) && (!resize)) {
6399 DrawDist(curDist[i].fa->GetBBox(), curDist[i].fb->GetBBox(),
'x');
6400 DrawDist(curDist[j].fa->GetBBox(), curDist[j].fb->GetBBox(),
'x');
6403 if ((curDist[i].fdir == curDist[j].fdir) && (curDist[j].fdir==
'y') && (
TMath::Abs(curDist[i].fdist-curDist[j].fdist)<threshold)) {
6404 if (cling && (!movedY) && (!resize)) {
6409 DrawDist(curDist[i].fa->GetBBox(), curDist[i].fb->GetBBox(),
'y');
6410 DrawDist(curDist[j].fa->GetBBox(), curDist[j].fb->GetBBox(),
'y');
6417 for (
UInt_t i = 0; i<
n; i++) {
6419 if (
a && (cur !=
a)) {
6420 aBBox =
a->GetBBox();
6432 gPad->PixeltoX(aBBox.
fX+aBBox.
fWidth),
gPad->PixeltoY(aBBox.
fY-dSizeArrow-
gPad->VtoPixel(0)), 0.01,
"<|>");
6474 if (tmpGuideLinePad) {
6477 tmpGuideLinePad->
Delete();
6478 tmpGuideLinePad = 0;
6565 Int_t nch, nobjects;
6568 if (
b.IsReading()) {
6580 b.ReadClassBuffer(TPad::Class(),
this,
v, R__s, R__c);
6585 while ((obj = next())) {
6604 TObject::Streamer(
b);
6605 TAttLine::Streamer(
b);
6606 TAttFill::Streamer(
b);
6607 b >> single;
fX1 = single;
6608 b >> single;
fY1 = single;
6609 b >> single;
fX2 = single;
6610 b >> single;
fY2 = single;
6613 TAttPad::Streamer(
b);
6615 TVirtualPad::Streamer(
b);
6616 TAttPad::Streamer(
b);
6617 b >> single;
fX1 = single;
6618 b >> single;
fY1 = single;
6619 b >> single;
fX2 = single;
6620 b >> single;
fY2 = single;
6647 b >> single;
fWNDC = single;
6648 b >> single;
fHNDC = single;
6658 TVirtualPad::Streamer(
b);
6659 TAttPad::Streamer(
b);
6718 char drawoption[64];
6719 for (
Int_t i = 0; i < nobjects; i++) {
6722 b.ReadFastArray(drawoption,nch);
6745 b >> single;
fPhi = single;
6760 b.CheckByteCount(R__s, R__c, TPad::IsA());
6764 b.WriteClassBuffer(TPad::Class(),
this);
6809 while ((obj = next())) {
6893 if (!
gPad)
return nullptr;
6895 if (strlen(emode))
gROOT->SetEditorMode(emode);
6896 if (
gROOT->GetEditorMode() == 0 && strlen(pname) > 2)
gROOT->SetEditorMode(&pname[1]);
6900 TObject *oldlast =
gPad->GetListOfPrimitives() ?
gPad->GetListOfPrimitives()->Last() :
nullptr;
6903 Bool_t hasname = strlen(pname) > 0;
6904 if (!pname[0] && !emode[0]) testlast =
kTRUE;
6905 if (testlast)
gROOT->SetEditorMode();
6907 if (
gROOT->GetEditorMode() == 0) {
6910 if (obj)
return obj;
6913 if (!
gPad->GetListOfPrimitives())
return nullptr;
6914 obj =
gPad->GetListOfPrimitives()->Last();
6915 if (obj != oldlast)
return obj;
6936 if (
gPad->IsBatch())
return 0;
6937 return (
TObject*)
gROOT->ProcessLineFast(
Form(
"new TGToolTip((TBox*)0x%lx,\"%s\",%d)",
6948 gROOT->ProcessLineFast(
Form(
"delete (TGToolTip*)0x%lx", (
Long_t)tip));
6959 gROOT->ProcessLineFast(
Form(
"((TGToolTip*)0x%lx)->Reset((TPad*)0x%lx)",
6970 gROOT->ProcessLineFast(
Form(
"((TGToolTip*)0x%lx)->Hide()",(
Long_t)tip));
6978 ::Info(
"TPad::x3d()",
"This function is deprecated. Use %s->GetViewer3D(\"x3d\") instead",this->
GetName());
6981 if (!type || !
type[0]) {
7026 if (!strstr(
type,
"pad")) {
7030 Warning(
"TPad::CreateViewer3D",
"Cannot create 3D viewer of type: %s",
type);
7036 if (strstr(
type,
"gl") && !strstr(
type,
"ogl"))
7039 createdExternal =
kTRUE;
7055 if (createdExternal) {
7092 Emit(
"RecordPave(const TObject*)", (
Long_t)obj);
7100 Emit(
"RecordLatex(const TObject*)", (
Long_t)obj);
static const double x2[5]
static const double x1[5]
static Bool_t ContainsTImage(TList *li)
Auxiliary function.
R__EXTERN TPluginManager * gPluginMgr
R__EXTERN TVirtualMutex * gROOTMutex
char * Form(const char *fmt,...)
char * StrDup(const char *str)
Duplicate the string str.
R__EXTERN TStyle * gStyle
R__EXTERN TSystem * gSystem
#define R__LOCKGUARD(mutex)
R__EXTERN TVirtualPS * gVirtualPS
R__EXTERN Int_t(* gThreadXAR)(const char *xact, Int_t nb, void **ar, Int_t *iret)
Draw all kinds of Arrows.
virtual void Draw(Option_t *option="")
Draw this arrow with its current attributes.
Abstract base class for elements drawn in the editor.
virtual void SetBBoxCenterY(const Int_t y)=0
virtual void SetBBoxCenterX(const Int_t x)=0
virtual void SetBBoxX1(const Int_t x)=0
virtual void SetBBoxY1(const Int_t y)=0
virtual void SetBBoxX2(const Int_t x)=0
virtual void SetBBoxY2(const Int_t y)=0
virtual Rectangle_t GetBBox()=0
virtual TPoint GetBBoxCenter()=0
virtual Color_t GetFillColor() const
Return the fill area color.
virtual Style_t GetFillStyle() const
Return the fill area style.
virtual void Modify()
Change current fill area attributes if necessary.
Style_t fFillStyle
Fill area style.
virtual void SetFillColor(Color_t fcolor)
Set the fill area color.
virtual Bool_t IsTransparent() const
virtual void SetFillStyle(Style_t fstyle)
Set the fill area style.
virtual Color_t GetLineColor() const
Return the line color.
virtual void SetLineStyle(Style_t lstyle)
Set the line style.
virtual Width_t GetLineWidth() const
Return the line width.
virtual void SetLineWidth(Width_t lwidth)
Set the line width.
Width_t fLineWidth
Line width.
virtual void SetLineColor(Color_t lcolor)
Set the line color.
virtual Style_t GetLineStyle() const
Return the line style.
virtual void Modify()
Change current line attributes if necessary.
virtual void SetMarkerColor(Color_t mcolor=1)
Set the marker color.
virtual void SetMarkerStyle(Style_t mstyle=1)
Set the marker style.
virtual void SetMarkerSize(Size_t msize=1)
Set the marker size.
virtual void SetBottomMargin(Float_t bottommargin)
Set Pad bottom margin in fraction of the pad height.
Color_t GetFrameFillColor() const
virtual void SetLeftMargin(Float_t leftmargin)
Set Pad left margin in fraction of the pad width.
Color_t GetFrameLineColor() const
Style_t GetFrameLineStyle() const
Float_t fRightMargin
RightMargin.
Style_t GetFrameFillStyle() const
Float_t fLeftMargin
LeftMargin.
Float_t fTopMargin
TopMargin.
Float_t GetLeftMargin() const
Width_t GetFrameLineWidth() const
Float_t GetBottomMargin() const
virtual void SetRightMargin(Float_t rightmargin)
Set Pad right margin in fraction of the pad width.
Float_t GetRightMargin() const
Int_t GetFrameBorderMode() const
virtual void SetTopMargin(Float_t topmargin)
Set Pad top margin in fraction of the pad height.
Width_t GetFrameBorderSize() const
Float_t fBottomMargin
BottomMargin.
Float_t GetTopMargin() const
virtual Float_t GetTextSize() const
Return the text size.
virtual void SetTextAlign(Short_t align=11)
Set the text alignment.
virtual Short_t GetTextAlign() const
Return the text alignment.
virtual Font_t GetTextFont() const
Return the text font.
virtual Color_t GetTextColor() const
Return the text color.
virtual void SetTextAngle(Float_t tangle=0)
Set the text angle.
virtual Float_t GetTextAngle() const
Return the text angle.
virtual void SetTextColor(Color_t tcolor=1)
Set the text color.
virtual void SetTextFont(Font_t tfont=62)
Set the text font.
virtual void SetTextSize(Float_t tsize=1)
Set the text size.
Class to manage histogram axis.
virtual Double_t GetBinLowEdge(Int_t bin) const
Return low edge of bin.
virtual Int_t FindFixBin(Double_t x) const
Find bin number corresponding to abscissa x.
Int_t GetLast() const
Return last bin on the axis i.e.
virtual void SetLimits(Double_t xmin, Double_t xmax)
virtual TObject * GetParent() const
virtual void SetRange(Int_t first=0, Int_t last=0)
Set the viewing range for the axis using bin numbers.
virtual Double_t GetBinUpEdge(Int_t bin) const
Return up edge of bin.
Int_t GetFirst() const
Return first bin on the axis i.e.
Each class (see TClass) has a linked list of its base class(es).
TClass * GetClassPointer(Bool_t load=kTRUE)
Get pointer to the base class TClass.
virtual void SetY2(Double_t y2)
virtual void SetX1(Double_t x1)
virtual void Draw(Option_t *option="")
Draw this box with its current attributes.
virtual void SetX2(Double_t x2)
virtual void SetY1(Double_t y1)
Using a TBrowser one can browse all ROOT objects.
Buffer base class used for serializing objects.
ABC describing GUI independent main window (with menubar, scrollbars and a drawing area).
UInt_t GetWindowHeight() const
TObject * GetClickSelected() const
TVirtualPad * GetClickSelectedPad() const
void SetClickSelectedPad(TPad *pad)
void SetSelectedPad(TPad *pad)
void SetDoubleBuffer(Int_t mode=1) override
Set Double Buffer On/Off.
TCanvasImp * GetCanvasImp() const override
Bool_t IsRetained() const override
static Bool_t SupportAlpha()
Static function returning "true" if transparency is supported.
Int_t GetEventY() const override
Bool_t IsBatch() const override
TVirtualPadPainter * GetCanvasPainter()
Access and (probably) creation of pad painter.
Color_t GetHighLightColor() const override
Bool_t IsGrayscale()
Check whether this canvas is to be drawn in grayscale mode.
void SaveSource(const char *filename="", Option_t *option="")
Save primitives in this canvas as a C++ macro file.
virtual void HandleInput(EEventType button, Int_t x, Int_t y)
Handle Input Events.
TObject * GetSelected() const override
Int_t GetEventX() const override
void SetCanvasSize(UInt_t ww, UInt_t wh) override
Set Width and Height of canvas to ww and wh respectively.
TVirtualPad * GetSelectedPad() const override
void SetCursor(ECursor cursor) override
Set cursor.
Int_t GetCanvasID() const override
UInt_t GetWindowWidth() const
void FeedbackMode(Bool_t set)
Turn rubberband feedback mode on or off.
void SetClickSelected(TObject *obj)
TVirtualPad * GetPadSave() const override
void Update() override
Update canvas pad buffers.
virtual void Cleared(TVirtualPad *pad)
Emit pad Cleared signal.
UInt_t GetWw() const override
Bool_t OpaqueMoving() const override
UInt_t GetWh() const override
void SetSelected(TObject *obj) override
Set selected canvas.
Int_t GetEvent() const override
void SetBatch(Bool_t batch=kTRUE) override
Toggle batch mode.
Bool_t OpaqueResizing() const override
TClass instances represent classes, structs and namespaces in the ROOT type system.
TList * GetListOfMethods(Bool_t load=kTRUE)
Return list containing the TMethods of a class.
Int_t GetNmethods()
Return the number of methods of this class Note that in case the list of methods is not yet created,...
Int_t GetNdata()
Return the number of data members of this class Note that in case the list of data members is not yet...
TList * GetListOfDataMembers(Bool_t load=kTRUE)
Return list containing the TDataMembers of a class.
TList * GetListOfBases()
Return list containing the TBaseClass(es) of a class.
virtual void ls(Option_t *option="") const
List (ls) all objects in this collection.
void Browse(TBrowser *b)
Browse this collection (called by TBrowser).
virtual Int_t GetSize() const
Return the capacity of the collection, i.e.
The color creation and management class.
static Int_t GetColor(const char *hexcolor)
Static method returning color number for color specified by hex color string of form: "#rrggbb",...
static void SaveColor(std::ostream &out, Int_t ci)
Save a color with index > 228 as a C++ statement(s) on output stream out.
static Int_t GetColorBright(Int_t color)
Static function: Returns the bright color number corresponding to n If the TColor object does not exi...
static Int_t GetColorDark(Int_t color)
Static function: Returns the dark color number corresponding to n If the TColor object does not exist...
virtual void SetAlpha(Float_t a)
static void SetGrayscale(Bool_t set=kTRUE)
Set whether all colors should return grayscale values.
static void Pave(Int_t event, Int_t px, Int_t py, Int_t mode)
Create a new pavetext in gPad.
static void Line(Int_t event, Int_t px, Int_t py, Int_t mode)
Create a new line/arrow in this gPad.
static void PolyLine(Int_t event, Int_t px, Int_t py, Int_t mode)
Create a new PolyLine in gPad.
static void Text(Int_t event, Int_t px, Int_t py, Int_t mode)
Create a new TLatex at the cursor position in gPad.
static void Ellipse(Int_t event, Int_t px, Int_t py, Int_t mode)
Create a new arc/ellipse in this gPad.
static void Pad(Int_t event, Int_t px, Int_t py, Int_t)
Create a new pad in gPad.
All ROOT classes may have RTTI (run time type identification) support added.
This class stores the date and time with a precision of one second in an unsigned 32 bit word (950130...
const char * AsSQLString() const
Return the date & time in SQL compatible string format, like: 1997-01-15 20:16:28.
const char * AsString() const
Return the date & time as a string (ctime() format).
virtual Int_t GetValue(const char *name, Int_t dflt) const
Returns the integer value for a resource.
TExec is a utility class that can be used to execute a C++ command when some event happens in a pad.
virtual void Exec(const char *command="")
Execute the command referenced by this object.
virtual void Paint(Option_t *option="")
Paint this wbox with its current attributes.
virtual void UseCurrentStyle()
Replace current frame attributes by current style.
A TGraph is an object made of two arrays X and Y with npoints each.
@ kClipFrame
clip to the frame boundary
1-D histogram with a float per channel (see TH1 documentation)}
TH1 is the base class of all histogram classes in ROOT.
virtual void SetDirectory(TDirectory *dir)
By default when an histogram is created, it is added to the list of histogram objects in the current ...
virtual Double_t GetNormFactor() const
virtual Int_t GetDimension() const
@ kNoStats
don't draw stats box
@ kIsZoomed
bit set when zooming on Y axis
TAxis * GetXaxis()
Get the behaviour adopted by the object about the statoverflows. See EStatOverflows for more informat...
virtual Double_t GetMaximum(Double_t maxval=FLT_MAX) const
Return maximum value smaller than maxval of bins in the range, unless the value has been overridden b...
virtual void SetMaximum(Double_t maximum=-1111)
virtual void SetMinimum(Double_t minimum=-1111)
virtual TH1 * DrawCopy(Option_t *option="", const char *name_postfix="_copy") const
Copy this histogram and Draw in the current pad.
virtual void Draw(Option_t *option="")
Draw this histogram with options.
virtual Int_t GetMaximumBin() const
Return location of bin with maximum value in the range.
virtual Double_t GetBinContent(Int_t bin) const
Return content of bin number bin.
virtual Int_t GetMinimumBin() const
Return location of bin with minimum value in the range.
virtual Double_t GetMinimum(Double_t minval=-FLT_MAX) const
Return minimum value larger than minval of bins in the range, unless the value has been overridden by...
virtual Double_t GetSumOfWeights() const
Return the sum of weights excluding under/overflows.
The Histogram stack class.
TH1 * GetHistogram() const
Returns a pointer to the histogram used to draw the axis Takes into account the two following cases.
Option_t * GetOption() const
This class displays a legend box (TPaveText) containing several legend entries.
virtual void Draw(Option_t *option="")
Draw this legend with its current attributes.
Option_t * GetOption() const
Returns the object option stored in the list.
virtual void Add(TObject *obj)
virtual TObject * After(const TObject *obj) const
Returns the object after object obj.
virtual TObjLink * LastLink() const
virtual TObject * Remove(TObject *obj)
Remove object from the list.
virtual void AddFirst(TObject *obj)
Add object at the beginning of the list.
virtual TObject * FindObject(const char *name) const
Find an object in this list using its name.
virtual TObjLink * FirstLink() const
virtual TObject * At(Int_t idx) const
Returns the object at position idx. Returns 0 if idx is out of range.
virtual TObject * Last() const
Return the last object in the list. Returns 0 when list is empty.
virtual void RecursiveRemove(TObject *obj)
Remove object from this collection and recursively remove the object from all other objects (and coll...
virtual TObject * First() const
Return the first object in the list. Returns 0 when list is empty.
virtual void AddLast(TObject *obj)
Add object at the end of the list.
virtual void Clear(Option_t *option="")
Remove all objects from the list.
Each ROOT class (see TClass) has a linked list of methods.
A TMultiGraph is a collection of TGraph (or derived) objects.
TH1F * GetHistogram()
Returns a pointer to the histogram used to draw the axis.
The TNamed class is the base class for all named ROOT classes.
virtual void SetTitle(const char *title="")
Set the title of the TNamed.
virtual void SetName(const char *name)
Set the name of the TNamed.
virtual const char * GetTitle() const
Returns title of object.
virtual const char * GetName() const
Returns name of object.
Wrapper around a TObject so it can be stored in a TList.
void SetObject(TObject *obj)
TObject * GetObject() const
Option_t * GetOption() const
Mother of all ROOT objects.
virtual Int_t DistancetoPrimitive(Int_t px, Int_t py)
Computes distance from point (px,py) to the object.
virtual const char * GetName() const
Returns name of object.
R__ALWAYS_INLINE Bool_t TestBit(UInt_t f) const
@ kNotDeleted
object has not been deleted
virtual const char * ClassName() const
Returns name of class to which the object belongs.
virtual void UseCurrentStyle()
Set current style settings in this object This function is called when either TCanvas::UseCurrentStyl...
virtual Option_t * GetDrawOption() const
Get option used by the graphics system to draw this object.
virtual void Warning(const char *method, const char *msgfmt,...) const
Issue warning message.
virtual TObject * FindObject(const char *name) const
Must be redefined in derived classes.
virtual void SavePrimitive(std::ostream &out, Option_t *option="")
Save a primitive as a C++ statement(s) on output stream "out".
virtual void Delete(Option_t *option="")
Delete this object.
void SetBit(UInt_t f, Bool_t set)
Set or unset the user status bits as specified in f.
virtual Bool_t InheritsFrom(const char *classname) const
Returns kTRUE if object inherits from class "classname".
virtual void Error(const char *method, const char *msgfmt,...) const
Issue error message.
virtual void Draw(Option_t *option="")
Default Draw method for all objects.
virtual void Paint(Option_t *option="")
This method must be overridden if a class wants to paint itself.
@ kCannotPick
if object in a pad cannot be picked
@ kCanDelete
if object in a list can be deleted
@ kMustCleanup
if object destructor must call RecursiveRemove()
virtual void Info(const char *method, const char *msgfmt,...) const
Issue info message.
The most important graphics class in the ROOT system.
Short_t GetBorderMode() const override
Bool_t OpaqueMoving() const override
Is pad moving in opaque mode ?
void PaintTextNDC(Double_t u, Double_t v, const char *text) override
Paint text in CurrentPad NDC coordinates.
Int_t GetTicky() const override
virtual Int_t Clip(Float_t *x, Float_t *y, Float_t xclipl, Float_t yclipb, Float_t xclipr, Float_t yclipt)
Clipping routine: Cohen Sutherland algorithm.
virtual void HideToolTip(Int_t event)
Hide tool tip depending on the event type.
Double_t fAbsYlowNDC
Absolute Y top left corner of pad in NDC [0,1].
Double_t fXtoAbsPixelk
Conversion coefficient for X World to absolute pixel.
void SetAttMarkerPS(Color_t color, Style_t style, Size_t msize) override
Set postscript marker attributes.
virtual void DivideSquare(Int_t n, Float_t xmargin=0.01, Float_t ymargin=0.01, Int_t color=0)
"n" is the total number of sub-pads.
void AbsCoordinates(Bool_t set) override
Double_t AbsPixeltoY(Int_t py) override
Bool_t IsBatch() const override
Is pad in batch mode ?
Double_t GetUymax() const override
Returns the maximum y-coordinate value visible on the pad. If log axis the returned value is in decad...
void AddExec(const char *name, const char *command) override
Add a new TExec object to the list of Execs.
Double_t fWNDC
Width of pad along X in Normalized Coordinates (NDC)
Int_t NextPaletteColor() override
Get the next autocolor in the pad.
void PaintBorder(Color_t color, Bool_t tops)
Paint the pad border.
Double_t GetPhi() const override
void FillCollideGrid(TObject *o)
Initialise the grid used to find empty space when adding a box (Legend) in a pad.
void SetView(TView *view=nullptr) override
Set the current TView. Delete previous view if view=0.
TVirtualViewer3D * GetViewer3D(Option_t *type="") override
Create/obtain handle to 3D viewer.
Double_t fPixeltoYk
Conversion coefficient for pixel to Y World.
void PaintHatches(Double_t dy, Double_t angle, Int_t nn, Double_t *xx, Double_t *yy)
This routine draw hatches inclined with the angle "angle" and spaced of "dy" in normalized device coo...
void PaintLine3D(Float_t *p1, Float_t *p2) override
Paint 3-D line in the CurrentPad.
static Int_t fgMaxPickDistance
Maximum Pick Distance.
void ResizePad(Option_t *option="") override
Compute pad conversion coefficients.
void PaintPolyMarker(Int_t n, Float_t *x, Float_t *y, Option_t *option="") override
Paint polymarker in CurrentPad World coordinates.
Double_t fPhi
phi angle to view as lego/surface
Double_t fPixeltoY
yworld = fPixeltoYk + fPixeltoY*ypixel
virtual void RecordLatex(const TObject *obj)
Emit RecordLatex() signal.
Double_t fAbsXlowNDC
Absolute X top left corner of pad in NDC [0,1].
Double_t fVtoPixelk
Conversion coefficient for V NDC to pixel.
Bool_t fGridx
Set to true if grid along X.
TObject * fPadView3D
! 3D View of this TPad
void CopyBackgroundPixmaps(TPad *start, TPad *stop, Int_t x, Int_t y)
Copy pixmaps of pads laying below pad "stop" into pad "stop".
Double_t GetUxmax() const override
Returns the maximum x-coordinate value visible on the pad. If log axis the returned value is in decad...
void Divide(Int_t nx=1, Int_t ny=1, Float_t xmargin=0.01, Float_t ymargin=0.01, Int_t color=0) override
Automatic pad generation by division.
void SavePrimitive(std::ostream &out, Option_t *option="") override
Save primitives in this pad on the C++ source file out.
Double_t fXtoPixel
xpixel = fXtoPixelk + fXtoPixel*xworld
TList * fExecs
List of commands to be executed when a pad event occurs.
Double_t PadtoY(Double_t y) const override
Convert y from pad to Y.
Int_t fTickx
Set to 1 if tick marks along X.
void SetBBoxY1(const Int_t y) override
Set top of BoundingBox to a value (resize in y direction on top)
Int_t fTicky
Set to 1 if tick marks along Y.
Int_t GetPixmapID() const override
virtual void XYtoAbsPixel(Double_t x, Double_t y, Int_t &xpixel, Int_t &ypixel) const
Bool_t GetGridx() const override
Double_t fX2
X of upper X coordinate.
void SetLogz(Int_t value=1) override
Set Lin/Log scale for Z.
void Browse(TBrowser *b) override
Browse pad.
Int_t XtoPixel(Double_t x) const override
void SetAttFillPS(Color_t color, Style_t style) override
Set postscript fill area attributes.
Int_t fCGnx
! Size of the collide grid along x
void SetBBoxCenterY(const Int_t y) override
Set Y coordinate of the center of the Pad.
Double_t fPixeltoX
xworld = fPixeltoXk + fPixeltoX*xpixel
void CopyBackgroundPixmap(Int_t x, Int_t y)
Copy pixmap of this pad as background of the current pad.
Double_t fYtoPixel
ypixel = fYtoPixelk + fYtoPixel*yworld
void DeleteToolTip(TObject *tip) override
Delete tool tip object.
void Close(Option_t *option="") override
Delete all primitives in pad and pad itself.
Double_t fAbsWNDC
Absolute Width of pad along X in NDC.
UInt_t GetWw() const override
Get Ww.
void PaintModified() override
Traverse pad hierarchy and (re)paint only modified pads.
void SetEditable(Bool_t mode=kTRUE) override
Set pad editable yes/no If a pad is not editable:
const char * GetTitle() const override
Returns title of object.
void PaintDate()
Paint the current date and time if the option date is on.
static void SetMaxPickDistance(Int_t maxPick=5)
static function to set the maximum Pick Distance fgMaxPickDistance This parameter is used in TPad::Pi...
void SetBBoxX2(const Int_t x) override
Set right hand side of BoundingBox to a value (resize in x direction on right)
void SetBBoxX1(const Int_t x) override
Set lefthandside of BoundingBox to a value (resize in x direction on left)
virtual Int_t ClippingCode(Double_t x, Double_t y, Double_t xcl1, Double_t ycl1, Double_t xcl2, Double_t ycl2)
Compute the endpoint codes for TPad::Clip.
Double_t GetUymin() const override
Returns the minimum y-coordinate value visible on the pad. If log axis the returned value is in decad...
Double_t fX1
X of lower X coordinate.
TList * GetListOfPrimitives() const override
void SetFillStyle(Style_t fstyle) override
Override TAttFill::FillStyle for TPad because we want to handle style=0 as style 4000.
TH1F * DrawFrame(Double_t xmin, Double_t ymin, Double_t xmax, Double_t ymax, const char *title="") override
Draw an empty pad frame with X and Y axis.
Double_t fVtoPixel
ypixel = fVtoPixelk + fVtoPixel*vndc
TCanvasImp * GetCanvasImp() const override
Get canvas implementation pointer if any.
Int_t GetEvent() const override
Get Event.
Double_t PadtoX(Double_t x) const override
Convert x from pad to X.
virtual void DrawCrosshair()
Function called to draw a crosshair in the canvas.
Double_t YtoPad(Double_t y) const override
Convert y from Y to pad.
virtual void RangeChanged()
Double_t fUymin
Minimum value on the Y axis.
void SetPad(const char *name, const char *title, Double_t xlow, Double_t ylow, Double_t xup, Double_t yup, Color_t color=35, Short_t bordersize=5, Short_t bordermode=-1) override
Set all pad parameters.
void SetCursor(ECursor cursor) override
Set cursor type.
Int_t GetCanvasID() const override
Get canvas identifier.
Int_t fLogz
(=0 if Z linear scale, =1 if log scale)
Double_t fYtoPixelk
Conversion coefficient for Y World to pixel.
Bool_t PlaceBox(TObject *o, Double_t w, Double_t h, Double_t &xl, Double_t &yb) override
Place a box in NDC space.
TPad()
Pad default constructor.
Double_t AbsPixeltoX(Int_t px) override
void UseCurrentStyle() override
Force a copy of current style for all objects in pad.
static Int_t GetMaxPickDistance()
Static function (see also TPad::SetMaxPickDistance)
void Range(Double_t x1, Double_t y1, Double_t x2, Double_t y2) override
Set world coordinate system for the pad.
Double_t fUtoPixelk
Conversion coefficient for U NDC to pixel.
Double_t fPixeltoXk
Conversion coefficient for pixel to X World.
Bool_t IsModified() const override
Double_t fY1
Y of lower Y coordinate.
Int_t GetEventY() const override
Get Y event.
Int_t fGLDevice
! OpenGL off-screen pixmap identifier
Double_t fYlowNDC
Y bottom left corner of pad in NDC [0,1].
TObject * WaitPrimitive(const char *pname="", const char *emode="") override
Loop and sleep until a primitive with name=pname is found in the pad.
void SetAttTextPS(Int_t align, Float_t angle, Color_t color, Style_t font, Float_t tsize) override
Set postscript text attributes.
Bool_t fModified
Set to true when pad is modified.
TLegend * BuildLegend(Double_t x1=0.3, Double_t y1=0.21, Double_t x2=0.3, Double_t y2=0.21, const char *title="", Option_t *option="") override
Build a legend from the graphical objects in the pad.
virtual TPad * Pick(Int_t px, Int_t py, TObjLink *&pickobj)
Search for an object at pixel position px,py.
void Update() override
Update pad.
virtual void SetNumber(Int_t number)
Int_t fNumber
pad number identifier
void PaintFillAreaNDC(Int_t n, Double_t *x, Double_t *y, Option_t *option="") override
Paint fill area in CurrentPad NDC coordinates.
Double_t fAbsPixeltoXk
Conversion coefficient for absolute pixel to X World.
void Clear(Option_t *option="") override
Delete all pad primitives.
Int_t YtoPixel(Double_t y) const override
Int_t GetTickx() const override
void PaintLine(Double_t x1, Double_t y1, Double_t x2, Double_t y2) override
Paint line in CurrentPad World coordinates.
Int_t GetGLDevice() override
Get GL device.
Double_t fAspectRatio
ratio of w/h in case of fixed ratio
virtual void RecordPave(const TObject *obj)
Emit RecordPave() signal.
void PaintBorderPS(Double_t xl, Double_t yl, Double_t xt, Double_t yt, Int_t bmode, Int_t bsize, Int_t dark, Int_t light) override
Paint a frame border with Postscript.
Double_t fUymax
Maximum value on the Y axis.
void Modified(Bool_t flag=1) override
void SetLogy(Int_t value=1) override
Set Lin/Log scale for Y.
virtual Int_t ClipPolygon(Int_t n, Double_t *x, Double_t *y, Int_t nn, Double_t *xc, Double_t *yc, Double_t xclipl, Double_t yclipb, Double_t xclipr, Double_t yclipt)
Clip polygon using the Sutherland-Hodgman algorithm.
void ExecuteEventAxis(Int_t event, Int_t px, Int_t py, TAxis *axis) override
Execute action corresponding to one event for a TAxis object (called by TAxis::ExecuteEvent....
void HighLight(Color_t col=kRed, Bool_t set=kTRUE) override
Highlight pad.
void SetBatch(Bool_t batch=kTRUE) override
Set pad in batch mode.
TCanvas * fCanvas
! Pointer to mother canvas
TVirtualPad * GetMother() const override
TVirtualViewer3D * fViewer3D
! Current 3D viewer
virtual void x3d(Option_t *type="")
Deprecated: use TPad::GetViewer3D() instead.
Bool_t HasCrosshair() const override
Return kTRUE if the crosshair has been activated (via SetCrosshair).
Bool_t IsRetained() const override
Is pad retained ?
Bool_t Collide(Int_t i, Int_t j, Int_t w, Int_t h)
Check if a box of size w and h collide some primitives in the pad at position i,j.
Int_t DistancetoPrimitive(Int_t px, Int_t py) override
Compute distance from point px,py to a box.
Bool_t fFixedAspectRatio
True if fixed aspect ratio.
void PaintFillArea(Int_t n, Float_t *x, Float_t *y, Option_t *option="") override
void RecursiveRemove(TObject *obj) override
Recursively remove object from a pad and its sub-pads.
Bool_t HasFixedAspectRatio() const override
void CloseToolTip(TObject *tip) override
Hide tool tip.
Double_t GetUxmin() const override
Returns the minimum x-coordinate value visible on the pad. If log axis the returned value is in decad...
void SetToolTipText(const char *text, Long_t delayms=1000) override
Set tool tip text associated with this pad.
void PaintPolyLine(Int_t n, Float_t *x, Float_t *y, Option_t *option="") override
Paint polyline in CurrentPad World coordinates.
void ls(Option_t *option="") const override
List all primitives in pad.
virtual ~TPad()
Pad destructor.
TView * GetView() const override
Double_t fVtoAbsPixelk
Conversion coefficient for V NDC to absolute pixel.
TVirtualPad * GetPadSave() const override
Get save pad.
void SetAttLinePS(Color_t color, Style_t style, Width_t lwidth) override
Set postscript line attributes.
TVirtualPad * GetVirtCanvas() const override
Get virtual canvas.
void DeleteExec(const char *name) override
Remove TExec name from the list of Execs.
void CopyPixmaps() override
Copy the sub-pixmaps of the pad to the canvas.
void CopyPixmap() override
Copy the pixmap of the pad to the canvas.
Double_t GetY1() const override
TPoint GetBBoxCenter() override
Return the center of the Pad as TPoint in pixels.
void FillCollideGridTFrame(TObject *o)
Bool_t GetGridy() const override
void LineNotFree(Int_t x1, Int_t x2, Int_t y1, Int_t y2)
Mark as "not free" the cells along a line.
Double_t fAbsHNDC
Absolute Height of pad along Y in NDC.
virtual void RangeAxisChanged()
void ExecuteEvent(Int_t event, Int_t px, Int_t py) override
Execute action corresponding to one event.
TObject * fTip
! tool tip associated with box
void SetCanvasSize(UInt_t ww, UInt_t wh) override
Set canvas size.
Int_t GetLogz() const override
virtual void AutoExec()
Execute the list of Execs when a pad event occurs.
Bool_t fAbsCoord
Use absolute coordinates.
Int_t fNumPaletteColor
Number of objects with an automatic color.
Int_t fCrosshairPos
Position of crosshair.
void FillCollideGridTGraph(TObject *o)
void SetFixedAspectRatio(Bool_t fixed=kTRUE) override
Fix pad aspect ratio to current value if fixed is true.
Short_t GetBorderSize() const override
void RedrawAxis(Option_t *option="") override
Redraw the frame axis.
void DrawDist(Rectangle_t aBBox, Rectangle_t bBBox, char mode)
Draw Arrows to indicated equal distances of Objects with given BBoxes.
Int_t fLogx
(=0 if X linear scale, =1 if log scale)
Double_t GetAbsWNDC() const override
Int_t YtoAbsPixel(Double_t y) const override
Double_t fUtoPixel
xpixel = fUtoPixelk + fUtoPixel*undc
Int_t fCrosshair
Crosshair type (0 if no crosshair requested)
void PaintFillAreaHatches(Int_t n, Double_t *x, Double_t *y, Int_t FillStyle)
This function paints hatched fill area according to the FillStyle value The convention for the Hatch ...
void RangeAxis(Double_t xmin, Double_t ymin, Double_t xmax, Double_t ymax) override
Set axis coordinate system for the pad.
@ kCannotMove
Fixed position.
@ kClearAfterCR
Clear after CR.
@ kHori
Pad is horizontal.
@ kPrintingPS
PS Printing.
@ kFraming
Frame is requested.
Double_t fUtoAbsPixelk
Conversion coefficient for U NDC to absolute pixel.
void ResetToolTip(TObject *tip) override
Reset tool tip, i.e.
Double_t GetTheta() const override
TList * fPrimitives
->List of primitives (subpads)
UInt_t GetWh() const override
Get Wh.
TCanvas * GetCanvas() const override
Short_t fBorderSize
pad bordersize in pixels
TView * fView
! Pointer to 3-D view (if one exists)
Rectangle_t GetBBox() override
Return the bounding Box of the Pad.
Bool_t * fCollideGrid
! Grid used to find empty space when adding a box (Legend) in a pad
void Paint(Option_t *option="") override
Paint all primitives in pad.
void FillCollideGridTBox(TObject *o)
Double_t fTheta
theta angle to view as lego/surface
void DrawCollideGrid()
This method draws the collide grid on top of the canvas.
void SetVertical(Bool_t vert=kTRUE) override
Set pad vertical (default) or horizontal.
void FillCollideGridTH1(TObject *o)
void GetPadPar(Double_t &xlow, Double_t &ylow, Double_t &xup, Double_t &yup) override
Return lower and upper bounds of the pad in NDC coordinates.
void PaintText(Double_t x, Double_t y, const char *text) override
Paint text in CurrentPad World coordinates.
Int_t fPadPaint
Set to 1 while painting the pad.
static void DrawColorTable()
Static function to Display Color Table in a pad.
Double_t GetXlowNDC() const override
void SaveAs(const char *filename="", Option_t *option="") const override
Save Pad contents in a file in one of various formats.
Int_t fPixmapID
! Off-screen pixmap identifier
Bool_t fEditable
True if canvas is editable.
Double_t GetYlowNDC() const override
TObject * FindObject(const char *name) const override
Search if object named name is inside this pad or in pads inside this pad.
Color_t GetHighLightColor() const override
Get highlight color.
Bool_t OpaqueResizing() const override
Is pad resizing in opaque mode ?
TVirtualPad * cd(Int_t subpadnumber=0) override
Set Current pad.
Int_t GetLogy() const override
void PaintLineNDC(Double_t u1, Double_t v1, Double_t u2, Double_t v2) override
Paint line in normalized coordinates.
void Print(const char *filename="") const override
Save Pad contents in a file in one of various formats.
Int_t GetEventX() const override
Get X event.
TFrame * GetFrame() override
Get frame.
Double_t fYtoAbsPixelk
Conversion coefficient for Y World to absolute pixel.
Double_t fXtoPixelk
Conversion coefficient for X World to pixel.
Int_t fLogy
(=0 if Y linear scale, =1 if log scale)
TFrame * fFrame
! Pointer to 2-D frame (if one exists)
TVirtualPadPainter * GetPainter() override
Get pad painter from TCanvas.
void Draw(Option_t *option="") override
Draw Pad in Current pad (re-parent pad if necessary).
Double_t fHNDC
Height of pad along Y in Normalized Coordinates (NDC)
void ShowGuidelines(TObject *object, const Int_t event, const char mode='i', const bool cling=true) override
Shows lines to indicate if a TAttBBox2D object is aligned to the center or to another object,...
virtual Bool_t IsEditable() const override
Int_t GetCrosshair() const
Return the crosshair type (from the mother canvas) crosshair type = 0 means no crosshair.
void GetRangeAxis(Double_t &xmin, Double_t &ymin, Double_t &xmax, Double_t &ymax) override
Return pad axis coordinates range.
void SetBorderMode(Short_t bordermode) override
void PaintBox(Double_t x1, Double_t y1, Double_t x2, Double_t y2, Option_t *option="") override
Paint box in CurrentPad World coordinates.
void DrawClassObject(const TObject *obj, Option_t *option="") override
Draw class inheritance tree of the class to which obj belongs.
Int_t fCGny
! Size of the collide grid along y
Double_t fXlowNDC
X bottom left corner of pad in NDC [0,1].
TObject * GetPrimitive(const char *name) const override
Get primitive.
Double_t fUxmin
Minimum value on the X axis.
Double_t GetAbsHNDC() const override
void SetBBoxCenter(const TPoint &p) override
Set center of the Pad.
void SetSelected(TObject *obj) override
Set selected.
TObject * GetSelected() const override
Get selected.
void GetRange(Double_t &x1, Double_t &y1, Double_t &x2, Double_t &y2) override
Return pad world coordinates range.
void PaintPolyLineNDC(Int_t n, Double_t *x, Double_t *y, Option_t *option="") override
Paint polyline in CurrentPad NDC coordinates.
Bool_t IsVertical() const override
Int_t IncrementPaletteColor(Int_t i, TString opt) override
Increment (i==1) or set (i>1) the number of autocolor in the pad.
void PaintPadFrame(Double_t xmin, Double_t ymin, Double_t xmax, Double_t ymax) override
Paint histogram/graph frame.
Double_t GetAbsYlowNDC() const override
Double_t fUxmax
Maximum value on the X axis.
Double_t fY2
Y of upper Y coordinate.
Double_t fAbsPixeltoYk
Conversion coefficient for absolute pixel to Y World.
TVirtualPad * GetSelectedPad() const override
Get selected pad.
void PaintPolyLine3D(Int_t n, Double_t *p) override
Paint 3-D polyline in the CurrentPad.
TVirtualPad * GetPad(Int_t subpadnumber) const override
Get a pointer to subpadnumber of this pad.
Short_t fBorderMode
Bordermode (-1=down, 0 = no border, 1=up)
void SetLogx(Int_t value=1) override
Set Lin/Log scale for X.
void ReleaseViewer3D(Option_t *type="") override
Release current (external) viewer.
void SetCrosshair(Int_t crhair=1) override
Set crosshair active/inactive.
void SetDoubleBuffer(Int_t mode=1) override
Set double buffer mode ON or OFF.
Int_t fNextPaletteColor
Next automatic color.
void SetBBoxCenterX(const Int_t x) override
Set X coordinate of the center of the Pad.
Int_t GetLogx() const override
TObject * fPadPointer
! free pointer
Double_t GetX2() const override
TObject * CreateToolTip(const TBox *b, const char *text, Long_t delayms) override
Create a tool tip and return its pointer.
Double_t GetWNDC() const override
Get width of pad along X in Normalized Coordinates (NDC)
void Pop() override
Pop pad to the top of the stack.
Double_t GetAbsXlowNDC() const override
Double_t GetHNDC() const override
Get height of pad along Y in Normalized Coordinates (NDC)
TPad * fMother
! pointer to mother of the list
const char * GetName() const override
Returns name of object.
Int_t XtoAbsPixel(Double_t x) const override
Bool_t fGridy
Set to true if grid along Y.
void SetBBoxY2(const Int_t y) override
Set bottom of BoundingBox to a value (resize in y direction on bottom)
Double_t XtoPad(Double_t x) const override
Convert x from X to pad.
The histogram statistics painter class.
A Pave (see TPave) with text, lines or/and boxes inside.
virtual TText * AddText(Double_t x1, Double_t y1, const char *label)
Add a new Text line to this pavetext at given coordinates.
virtual void Draw(Option_t *option="")
Draw this pavetext with its current attributes.
virtual TLine * AddLine(Double_t x1=0, Double_t y1=0, Double_t x2=0, Double_t y2=0)
Add a new graphics line to this pavetext.
virtual TBox * AddBox(Double_t x1, Double_t y1, Double_t x2, Double_t y2)
Add a new graphics box to this pavetext.
Int_t GetBorderSize() const
virtual void SetBorderSize(Int_t bordersize=4)
Long_t ExecPlugin(int nargs, const T &... params)
TPluginHandler * FindHandler(const char *base, const char *uri=0)
Returns the handler if there exists a handler for the specified URI.
void Emit(const char *signal, const T &arg)
Activate signal with single parameter.
static Int_t IncreaseDirLevel()
Increase the indentation level for ls().
static void IndentLevel()
Functions used by ls() to indent an object hierarchy.
static Int_t DecreaseDirLevel()
Decrease the indentation level for ls().
void ToLower()
Change string to lower-case.
Bool_t EndsWith(const char *pat, ECaseCompare cmp=kExact) const
Return true if string ends with the specified string.
TString & Replace(Ssiz_t pos, Ssiz_t n, const char *s)
const char * Data() const
TString & ReplaceAll(const TString &s1, const TString &s2)
Bool_t BeginsWith(const char *s, ECaseCompare cmp=kExact) const
TString & Prepend(const char *cs)
TString & Append(const char *cs)
Bool_t Contains(const char *pat, ECaseCompare cmp=kExact) const
Ssiz_t Index(const char *pat, Ssiz_t i=0, ECaseCompare cmp=kExact) const
void SetPadBorderMode(Int_t mode=1)
void SetPadTopMargin(Float_t margin=0.1)
void SetOptLogx(Int_t logx=1)
void SetPadBottomMargin(Float_t margin=0.1)
Int_t GetOptTitle() const
Int_t GetPadTickX() const
Color_t GetPadColor() const
void SetPadRightMargin(Float_t margin=0.1)
void SetTitleFont(Style_t font=62, Option_t *axis="X")
Float_t GetPadRightMargin() const
void SetTitleBorderSize(Width_t size=2)
Style_t GetTitleFont(Option_t *axis="X") const
Return title font.
void SetPadTickY(Int_t ticky)
Color_t GetTitleFillColor() const
void SetPadTickX(Int_t tickx)
Bool_t GetPadGridY() const
void SetPadGridX(Bool_t gridx)
void SetTitleTextColor(Color_t color=1)
Float_t GetPadLeftMargin() const
Double_t GetHatchesSpacing() const
Bool_t GetPadGridX() const
void SetPadLeftMargin(Float_t margin=0.1)
void SetPadGridY(Bool_t gridy)
void SetOptLogy(Int_t logy=1)
Int_t GetPadTickY() const
Width_t GetPadBorderSize() const
Width_t GetTitleBorderSize() const
Int_t GetColorPalette(Int_t i) const
Return color number i in current palette.
void SetTitleFillColor(Color_t color=1)
Float_t GetPadBottomMargin() const
void SetOptLogz(Int_t logz=1)
void SetPadColor(Color_t color=19)
Color_t GetTitleTextColor() const
Int_t GetPadBorderMode() const
Int_t GetNumberOfColors() const
Return number of colors in the color palette.
void SetPadBorderSize(Width_t size=1)
Int_t GetHatchesLineWidth() const
Float_t GetPadTopMargin() const
virtual Bool_t ExpandPathName(TString &path)
Expand a pathname getting rid of special shell characters like ~.
virtual Int_t Exec(const char *shellcmd)
Execute a command.
virtual Bool_t AccessPathName(const char *path, EAccessMode mode=kFileExists)
Returns FALSE if one can access a file using the specified access mode.
virtual int Rename(const char *from, const char *to)
Rename a file.
virtual void Sleep(UInt_t milliSec)
Sleep milliSec milli seconds.
virtual Bool_t ProcessEvents()
Process pending events (GUI, timers, sockets).
Base class for several text objects.
virtual TText * DrawText(Double_t x, Double_t y, const char *text)
Draw this text with new coordinates.
virtual void SetNDC(Bool_t isNDC=kTRUE)
Set NDC mode on if isNDC = kTRUE, off otherwise.
virtual void Paint(Option_t *option="")
Paint this text with its current attributes.
virtual void WCtoNDC(const Float_t *pw, Float_t *pn)=0
virtual Int_t GetDistancetoAxis(Int_t axis, Int_t px, Int_t py, Double_t &ratio)=0
virtual void ResizePad()=0
virtual void GetRange(Float_t *min, Float_t *max)=0
Provides 3D viewer interface (TVirtualViewer3D) support on a pad.
TVirtualPS is an abstract interface to Postscript, PDF, SVG.
virtual void Text(Double_t x, Double_t y, const char *string)=0
virtual void DrawPS(Int_t n, Float_t *xw, Float_t *yw)=0
virtual void DrawBox(Double_t x1, Double_t y1, Double_t x2, Double_t y2)=0
virtual void DrawPolyMarker(Int_t n, Float_t *x, Float_t *y)=0
virtual void Open(const char *filename, Int_t type=-111)=0
virtual void DrawFrame(Double_t xl, Double_t yl, Double_t xt, Double_t yt, Int_t mode, Int_t border, Int_t dark, Int_t light)=0
To make it possible to use GL for 2D graphic in a TPad/TCanvas.
virtual void DrawBox(Double_t x1, Double_t y1, Double_t x2, Double_t y2, EBoxMode mode)=0
virtual void ClearDrawable()=0
virtual void SetOpacity(Int_t percent)=0
virtual void DrawPolyLine(Int_t n, const Double_t *x, const Double_t *y)=0
virtual Color_t GetLineColor() const =0
virtual void SetLineStyle(Style_t lstyle)=0
virtual void SetFillColor(Color_t fcolor)=0
virtual void DestroyDrawable(Int_t device)=0
virtual void CopyDrawable(Int_t device, Int_t px, Int_t py)=0
virtual void DrawLine(Double_t x1, Double_t y1, Double_t x2, Double_t y2)=0
virtual void DrawFillArea(Int_t n, const Double_t *x, const Double_t *y)=0
virtual Int_t CreateDrawable(UInt_t w, UInt_t h)=0
virtual void SetLineColor(Color_t lcolor)=0
virtual Style_t GetLineStyle() const =0
virtual void SaveImage(TVirtualPad *pad, const char *fileName, Int_t type) const =0
virtual void DrawLineNDC(Double_t u1, Double_t v1, Double_t u2, Double_t v2)=0
virtual void SetFillStyle(Style_t fstyle)=0
virtual void SetTextSize(Float_t tsize=1)=0
virtual void SetLineWidth(Width_t lwidth)=0
virtual void DrawPolyLineNDC(Int_t n, const Double_t *u, const Double_t *v)=0
virtual void DrawTextNDC(Double_t u, Double_t v, const char *text, ETextMode mode)=0
virtual Width_t GetLineWidth() const =0
virtual void SelectDrawable(Int_t device)=0
virtual void DrawPolyMarker(Int_t n, const Double_t *x, const Double_t *y)=0
virtual void DrawText(Double_t x, Double_t y, const char *text, ETextMode mode)=0
virtual Style_t GetFillStyle() const =0
virtual void InvalidateCS()
Empty definition.
TVirtualPad is an abstract base class for the Pad and Canvas classes.
virtual Int_t YtoAbsPixel(Double_t y) const =0
virtual Double_t GetX2() const =0
virtual TVirtualPad * cd(Int_t subpadnumber=0)=0
virtual Int_t XtoAbsPixel(Double_t x) const =0
virtual Double_t GetY1() const =0
const char * GetName() const override=0
Returns name of object.
virtual Int_t GetNumber() const =0
virtual Int_t VtoPixel(Double_t v) const =0
virtual Int_t VtoAbsPixel(Double_t v) const =0
virtual Double_t GetY2() const =0
virtual Int_t UtoPixel(Double_t u) const =0
virtual void GetRange(Double_t &x1, Double_t &y1, Double_t &x2, Double_t &y2)=0
virtual Short_t GetBorderSize() const =0
virtual Bool_t IsEditable() const =0
virtual Double_t GetX1() const =0
Abstract 3D shapes viewer.
static TVirtualViewer3D * Viewer3D(TVirtualPad *pad=0, Option_t *type="")
Create a Viewer 3D of specified type.
virtual Bool_t BuildingScene() const =0
virtual void EndScene()=0
virtual void PadPaint(TVirtualPad *)
virtual void BeginScene()=0
virtual Bool_t CanLoopOnPrimitives() const
Short_t GetBorderSize() const
Short_t GetBorderMode() const
virtual void SetBorderMode(Short_t bordermode)
virtual void SetBorderSize(Short_t bordersize)
void box(Int_t pat, Double_t x1, Double_t y1, Double_t x2, Double_t y2)
double dist(Rotation3D const &r1, Rotation3D const &r2)
void CallRecursiveRemoveIfNeeded(TObject &obj)
call RecursiveRemove for obj if gROOT is valid and obj.TestBit(kMustCleanup) is true.
Int_t Nint(T x)
Round to nearest integer. Rounds half integers to the nearest even integer.
Short_t Max(Short_t a, Short_t b)
Double_t Floor(Double_t x)
Double_t Ceil(Double_t x)
Int_t Finite(Double_t x)
Check if it is finite with a mask in order to be consistent in presence of fast math.
Double_t Sqrt(Double_t x)
LongDouble_t Power(LongDouble_t x, LongDouble_t y)
Short_t Min(Short_t a, Short_t b)
Double_t Log10(Double_t x)
void inv(rsa_NUMBER *, rsa_NUMBER *, rsa_NUMBER *)
Rectangle structure (maps to the X11 XRectangle structure)