1014 const char *where =
"PaintAxis";
1016 Double_t alfa, beta, ratio1, ratio2, grid_side;
1024 Double_t phil, phi, sinphi, cosphi;
1025 Double_t binLow = 0., binLow2 = 0., binLow3 = 0.;
1026 Double_t binHigh = 0., binHigh2 = 0., binHigh3 = 0.;
1027 Double_t binWidth = 0., binWidth2 = 0., binWidth3 = 0.;
1032 Double_t wlabel, dwlabel, axis_value;
1038 xx0 = xx1 = yy0 = yy1 = 0;
1039 Double_t xxmin, xxmax, yymin, yymax;
1040 xxmin = xxmax = yymin = yymax = 0;
1044 Double_t xmnlog, x00, x11, h2, h2sav, axmul,
y;
1047 Int_t nlabels, nticks, nticks0, nticks1;
1048 Int_t i, j, k,
l, decade, ltick;
1052 Int_t iexe, if1, if2, na, nf, ih1, ih2, nbinin, nch, kmod;
1053 Int_t optionLog,optionBlank,optionVert,optionPlus,optionMinus,optionUnlab,optionPara;
1054 Int_t optionDown,optionRight,optionLeft,optionCent,optionEqual,optionDecimals=0,optionDot;
1055 Int_t optionY,optionText,optionGrid,optionSize,optionNoopt,optionInt,optionM,optionUp,optionX;
1056 Int_t optionTime, optionArrow;
1057 Int_t first=0,last=0,labelnumber;
1058 Int_t xalign, yalign;
1059 Int_t nn1, nn2, nn3, n1a, n2a, n3a, nb2, nb3;
1060 Int_t nbins=10, n1aold, nn1old;
1062 n1aold = nn1old = 0;
1086 chtemp = &kchtemp[0];
1087 label = &chlabel[0];
1106 if(strchr(chopt,
'G')) optionLog = 1;
else optionLog = 0;
1107 if(strchr(chopt,
'B')) optionBlank= 1;
else optionBlank= 0;
1108 if(strchr(chopt,
'V')) optionVert = 1;
else optionVert = 0;
1109 if(strchr(chopt,
'+')) optionPlus = 1;
else optionPlus = 0;
1110 if(strchr(chopt,
'-')) optionMinus= 1;
else optionMinus= 0;
1111 if(strchr(chopt,
'U')) optionUnlab= 1;
else optionUnlab= 0;
1112 if(strchr(chopt,
'P')) optionPara = 1;
else optionPara = 0;
1113 if(strchr(chopt,
'O')) optionDown = 1;
else optionDown = 0;
1114 if(strchr(chopt,
'R')) optionRight= 1;
else optionRight= 0;
1115 if(strchr(chopt,
'L')) optionLeft = 1;
else optionLeft = 0;
1116 if(strchr(chopt,
'C')) optionCent = 1;
else optionCent = 0;
1117 if(strchr(chopt,
'=')) optionEqual= 1;
else optionEqual= 0;
1118 if(strchr(chopt,
'Y')) optionY = 1;
else optionY = 0;
1119 if(strchr(chopt,
'T')) optionText = 1;
else optionText = 0;
1120 if(strchr(chopt,
'W')) optionGrid = 1;
else optionGrid = 0;
1121 if(strchr(chopt,
'S')) optionSize = 1;
else optionSize = 0;
1122 if(strchr(chopt,
'N')) optionNoopt= 1;
else optionNoopt= 0;
1123 if(strchr(chopt,
'I')) optionInt = 1;
else optionInt = 0;
1124 if(strchr(chopt,
'M')) optionM = 1;
else optionM = 0;
1125 if(strchr(chopt,
'0')) optionUp = 1;
else optionUp = 0;
1126 if(strchr(chopt,
'X')) optionX = 1;
else optionX = 0;
1127 if(strchr(chopt,
't')) optionTime = 1;
else optionTime = 0;
1128 if(strchr(chopt,
'.')) optionDot = 1;
else optionDot = 0;
1133 if (!
gStyle->GetStripDecimals()) optionDecimals = 1;
1135 if(strchr(chopt,
'>')) optionArrow = 1;
1136 if(strchr(chopt,
'<')) optionArrow = optionArrow+2;
1138 if (
fAxis->GetLabels()) {
1154 Error(where,
"Invalid number of divisions: %d",ndiv);
1161 if (gridlength == 0) gridlength = 0.8;
1191 Int_t year, mm, dd, hh, mi, ss;
1192 if (sscanf(stringtimeoffset.
Data(),
"%d-%d-%d %d:%d:%d", &year, &mm, &dd, &hh, &mi, &ss) == 6) {
1195 tp.tm_year = year-1900;
1209 TString sdp = stringtimeoffset(ids+1,lns);
1210 sscanf(sdp.
Data(),
"%g",&dp);
1214 Error(where,
"Time offset has not the right format");
1217 timeoffset =
gStyle->GetTimeOffset();
1219 wmin += timeoffset - (
int)(timeoffset);
1220 wmax += timeoffset - (
int)(timeoffset);
1224 time_t timetp = (time_t)((
Long_t)(timeoffset));
1227 if (range>60) rangeBase = 60*20;
1228 if (range>3600) rangeBase = 3600*20;
1229 if (range>86400) rangeBase = 86400*20;
1230 if (range>2419200) rangeBase = 31556736;
1232 if (range>31536000) {
1233 tp0 = gmtime(&timetp);
1240 rangeBase = (timetp-mktime(tp0));
1241 rangeOffset = (
Double_t) (rangeBase);
1243 wmax += rangeOffset;
1244 wmin += rangeOffset;
1249 n2a = (ndiv%10000 - n1a)/100;
1250 n3a = (ndiv%1000000 - n2a -n1a)/10000;
1255 maxDigits = (ndiv/1000000);
1256 if (maxDigits==0) maxDigits =
gStyle->GetAxisMaxDigits();
1264 if (
wmin ==
wmax || ndiv == 0 || n1a <= 1 || optionLog) {
1270 if ( (
wmax-
wmin) < 1 && optionInt) {
1271 Error(where,
"option I not available");
1274 if (!optionNoopt || optionInt ) {
1282 if (binLow !=
Double_t(
int(binLow)) || binWidth !=
Double_t(
int(binWidth))) {
1286 if ((
wmin-binLow) > epsilon) { binLow += binWidth; nbins--; }
1287 if ((binHigh-
wmax) > epsilon) { binHigh -= binWidth; nbins--; }
1293 yymax = rtyw*(binHigh-
wmin) +
ymin;
1298 xxmax = rtxw*(binHigh-
wmin) +
xmin;
1306 yymin = alfa*xxmin + beta;
1307 yymax = alfa*xxmax + beta;
1322 if (!optionNoopt && n2a > 1 && binWidth > 0) {
1328 if (!optionNoopt && n3a > 1 && binWidth2 > 0) {
1342 ratio1 = 1/(rwxmax-rwxmin);
1343 ratio2 = 1/(rwymax-rwymin);
1344 x0 = ratio1*(
xmin-rwxmin);
1345 x1 = ratio1*(
xmax-rwxmin);
1346 y0 = ratio2*(
ymin-rwymin);
1347 y1 = ratio2*(
ymax-rwymin);
1348 if (!optionNoopt || optionInt ) {
1349 xx0 = ratio1*(xxmin-rwxmin);
1350 xx1 = ratio1*(xxmax-rwxmin);
1351 yy0 = ratio2*(yymin-rwymin);
1352 yy1 = ratio2*(yymax-rwymin);
1355 if ((x0 ==
x1) && (y0 ==
y1)) {
1356 Error(where,
"length of axis is 0");
1363 if (toffset==0 &&
x1 == x0) autotoff =
kTRUE;
1376 if (!
gPad->IsBatch()) {
1377 gVirtualX->GetCharacterUp(chupxvsav, chupyvsav);
1383 if (axis_length == 0) {
1384 Error(where,
"length of axis is 0");
1387 if (!optionNoopt || optionInt) {
1388 axis_lengthN =
TMath::Sqrt((xx1-xx0)*(xx1-xx0)+(yy1-yy0)*(yy1-yy0));
1389 axis_length0 =
TMath::Sqrt((xx0-x0)*(xx0-x0)+(yy0-y0)*(yy0-y0));
1391 if (axis_lengthN < epsilon) {
1400 wmin += timeoffset - (
int)(timeoffset) + rangeOffset;
1401 wmax += timeoffset - (
int)(timeoffset) + rangeOffset;
1407 if (
y1>=y0) phi = 0.5*
kPI;
1432 if (x0 ==
x1 &&
y1 > y0) mside = -1;
1433 if (optionPlus) mside = 1;
1434 if (optionMinus) mside = -1;
1435 if (optionPlus && optionMinus) mside = 0;
1438 if (optionEqual) lside = mside;
1439 if (optionPlus && optionMinus) {
1441 if (optionEqual) lside=1;
1446 if(xmside >= 0) tick_side = 1;
1447 else tick_side = -1;
1448 if (optionSize) atick[0] = tick_side*axis_length*
fTickSize;
1449 else atick[0] = tick_side*axis_length*0.03;
1451 atick[1] = 0.5*atick[0];
1452 atick[2] = 0.5*atick[1];
1455 if ((x0 ==
x1) && (
y1 > y0)) grid_side =-1;
1482 if (optionArrow==1)
a.PaintArrowNDC(xpl1, ypl1, xpl2, ypl2, as,
"|>");
1483 if (optionArrow==2)
a.PaintArrowNDC(xpl1, ypl1, xpl2, ypl2, as,
"<|");
1484 if (optionArrow==3)
a.PaintArrowNDC(xpl1, ypl1, xpl2, ypl2, as,
"<|>");
1492 if (ndiv == 0)
return;
1504 if (optionText &&
GetLabelFont()%10 != 3) charheight *= 0.66666;
1514 if (!optionUp && !optionDown && !optionY && !optionUnlab) {
1529 if (nl > 50)
angle = 90;
1542 strlcpy(chtemp,
fAxis->GetBinLabel(
i), 255);
1550 }
else if ((!strcmp(
fAxis->GetName(),
"yaxis") && !
gPad->TestBit(
kHori))
1551 || (!strcmp(
fAxis->GetName(),
"xaxis") &&
gPad->TestBit(
kHori))) {
1561 double scale=
gPad->GetWw()*
gPad->GetWNDC();
1562 if (scale>0.0) toffset =
TMath::Max(toffset,(
double)
w/scale);
1564 strlcpy(chtemp,
fAxis->GetBinLabel(
i), 255);
1573 strlcpy(chtemp,
fAxis->GetBinLabel(
i), 255);
1587 if (!
gPad->IsBatch()) {
1588 if (cosphi > 0)
gVirtualX->SetCharacterUp(-sinphi,cosphi);
1589 else gVirtualX->SetCharacterUp(sinphi,-cosphi);
1591 if (optionVert)
gVirtualX->SetCharacterUp(0,1);
1592 if (optionPara)
gVirtualX->SetCharacterUp(-sinphi,cosphi);
1593 if (optionDown)
gVirtualX->SetCharacterUp(cosphi,sinphi);
1599 if (x0 ==
x1) xalign = 3;
1600 if (y0 !=
y1) yalign = 2;
1601 if (optionCent) xalign = 2;
1602 if (optionRight) xalign = 3;
1603 if (optionLeft) xalign = 1;
1607 if (cosphi*sinphi > 0) xalign = 1;
1608 if (cosphi*sinphi < 0) xalign = 3;
1614 if (optionPlus && !optionMinus) {
1619 if (lside < 0) ylabel += atick[0];
1621 }
else if (y0 ==
y1) {
1622 if (optionMinus && !optionPlus) {
1633 if (mside <= 0) ylabel -=
TMath::Abs(atick[0]);
1635 if (optionLog) ylabel -= 0.5*charheight;
1640 if (optionText) ylabel /= 2;
1646 dxtick=(binHigh-binLow)/
Double_t(nticks-1);
1648 if (optionNoopt && !optionInt) dxtick=axis_length/
Double_t(nticks-1);
1649 else dxtick=axis_lengthN/
Double_t(nticks-1);
1651 for (k=0;k<nticks; k++) {
1653 if (k%nn3 == 0) ltick = 1;
1654 if (k%nn2 == 0) ltick = 0;
1658 xtick = zz* axis_length /
TMath::Abs(rwma-rwmi);
1663 if (!mside) ytick -= atick[ltick];
1664 if ( optionNoopt && !optionInt) {
1665 Rotate(xtick,ytick,cosphi,sinphi,x0,y0,xpl2,ypl2);
1666 Rotate(xtick,atick[ltick],cosphi,sinphi,x0,y0,xpl1,ypl1);
1669 Rotate(xtick,ytick,cosphi,sinphi,xx0,yy0,xpl2,ypl2);
1670 Rotate(xtick,atick[ltick],cosphi,sinphi,xx0,yy0,xpl1,ypl1);
1673 if ((x0 !=
x1) && (y0 !=
y1)) {
1676 if (cosphi > 0) ypl1 = ypl2 + atick[ltick];
1677 else ypl1 = ypl2 - atick[ltick];
1680 xpl1 = 0.5*(xpl1 + xpl2);
1682 ypl1 = 0.5*(ypl1 + ypl2) + atick[ltick];
1683 ypl2 = 0.5*(ypl1 + ypl2) - atick[ltick];
1687 if (!drawGridOnly) {
1691 if (optionArrow==1) {
1698 if (optionArrow==2) {
1705 if (optionArrow==3) {
1717 if (optionNoopt && !optionInt) {
1718 Rotate(xtick,0,cosphi,sinphi,x0,y0 ,xpl2,ypl2);
1719 Rotate(xtick,grid_side*gridlength ,cosphi,sinphi,x0,y0 ,xpl1,ypl1);
1722 Rotate(xtick,0,cosphi ,sinphi,xx0,yy0 ,xpl2,ypl2);
1723 Rotate(xtick,grid_side*gridlength ,cosphi,sinphi,xx0,yy0 ,xpl1,ypl1);
1733 if ((!optionNoopt || optionInt) && axis_length0) {
1734 nticks0 =
Int_t(axis_length0/dxtick);
1735 if (nticks0 > 1000) nticks0 = 1000;
1736 for (k=0; k<=nticks0; k++) {
1738 if (k%nn3 == 0) ltick = 1;
1739 if (k%nn2 == 0) ltick = 0;
1741 if (!mside) ytick0 -= atick[ltick];
1746 Rotate(xtick0,ytick0,cosphi,sinphi,xx0,yy0 ,xpl2,ypl2);
1747 Rotate(xtick0,atick[ltick],cosphi,sinphi,xx0,yy0 ,xpl1,ypl1);
1749 if ((x0 !=
x1) && (y0 !=
y1)) {
1752 if (cosphi > 0) ypl1 = ypl2 + atick[ltick];
1753 else ypl1 = ypl2 - atick[ltick];
1756 xpl1 = 0.5*(xpl1 + xpl2);
1758 ypl1 = 0.5*(ypl1 + ypl2) + atick[ltick];
1759 ypl2 = 0.5*(ypl1 + ypl2) - atick[ltick];
1763 if (!drawGridOnly)
PaintLineNDC(xpl1, ypl1, xpl2, ypl2);
1767 Rotate(xtick0,0,cosphi,sinphi,xx0,yy0,xpl2,ypl2);
1768 Rotate(xtick0,grid_side*gridlength ,cosphi,sinphi,xx0,yy0 ,xpl1,ypl1);
1777 if ((!optionNoopt || optionInt) && axis_length1) {
1778 nticks1 =
int(axis_length1/dxtick);
1779 if (nticks1 > 1000) nticks1 = 1000;
1780 for (k=0; k<=nticks1; k++) {
1782 if (k%nn3 == 0) ltick = 1;
1783 if (k%nn2 == 0) ltick = 0;
1785 if (!mside) ytick1 -= atick[ltick];
1790 Rotate(xtick1,ytick1,cosphi,sinphi,xx0,yy0 ,xpl2,ypl2);
1791 Rotate(xtick1,atick[ltick],cosphi,sinphi,xx0,yy0 ,xpl1,ypl1);
1793 if ((x0 !=
x1) && (y0 !=
y1)) {
1796 if (cosphi > 0) ypl1 = ypl2 + atick[ltick];
1797 else ypl1 = ypl2 - atick[ltick];
1800 xpl1 = 0.5*(xpl1 + xpl2);
1802 ypl1 = 0.5*(ypl1 + ypl2) + atick[ltick];
1803 ypl2 = 0.5*(ypl1 + ypl2) - atick[ltick];
1807 if (!drawGridOnly)
PaintLineNDC(xpl1, ypl1, xpl2, ypl2);
1810 Rotate(xtick1,0,cosphi,sinphi,xx0,yy0 ,xpl2,ypl2);
1811 Rotate(xtick1,grid_side*gridlength,cosphi,sinphi,xx0,yy0,xpl1,ypl1);
1822 if (!drawGridOnly && !optionUnlab) {
1826 if ((
wmin ==
wmax) || (ndiv == 0)) {
1827 Error(where,
"wmin (%f) == wmax (%f), or ndiv == 0",
wmin,
wmax);
1832 if (optionNoopt && !optionInt) dxlabel = axis_length/
Double_t(n1a);
1833 else dxlabel = axis_lengthN/
Double_t(n1a);
1835 if (!optionText && !optionTime) {
1857 if (iexe%3 == 1) iexe += 2;
1858 else if(iexe%3 == 2) iexe += 1;
1859 if (nexe < 0) nexe = -iexe;
1872 if (!noExponent && nf > maxDigits) flexpo =
kTRUE;
1873 if (!noExponent && nf < -maxDigits) flexne =
kTRUE;
1884 if (nexe%3 == 0 && ww <=
TMath::Power(10,maxDigits-1))
break;
1896 if (nexe%3 == 0 && ww >= rne)
break;
1901 for (
i=maxDigits-1;
i>0;
i--) {
1907 if (wdyn <= 0.999 && na < maxDigits-2) {
1927 if (if1 > 14) if1 = 14;
1928 if (if2 > 14) if2 = 14;
1929 if (if1 < 0) if1 = 0;
1932 len =
snprintf(chcoded,
sizeof(chcoded),
"%%%d.%df",if1,if2);
1934 len =
snprintf(chcoded,
sizeof(chcoded),
"%%%d.%df",if1+1,1);
1937 if ((
len < 0) || (
len >= (
int)
sizeof(chcoded)))
1938 strcpy(chcoded,
"%7.3f");
1944 Int_t ndecimals = 0;
1945 if (optionDecimals) {
1946 char *dot = strchr(chtemp,
'.');
1948 ndecimals = chtemp + strlen(chtemp) -dot;
1951 exp = strstr(chtemp,
"e-");
1953 sscanf(&exp[2],
"%d",&ndecimals);
1958 if (optionM) nlabels = n1a-1;
1961 for ( k=0; k<=nlabels; k++) {
1966 xlabel = zz* axis_length /
TMath::Abs(rwma-rwmi);
1970 if (optionM) xlabel += 0.5*dxlabel;
1972 axis_value = wlabel;
1974 if (!optionText && !optionTime) {
1975 snprintf(label,256,chcoded,wlabel);
1982 if (label[first] ==
'.') {
1983 strncpy(chtemp,
"0", 256);
1984 strlcat(chtemp, &label[first],256);
1985 strlcpy(label, chtemp, 256);
1986 first = 1; last = strlen(label);
1988 if (label[first] ==
'-' && label[first+1] ==
'.') {
1989 strncpy(chtemp,
"-0",256);
1990 strlcat(chtemp, &label[first+1],256);
1991 strlcpy(label, chtemp, 256);
1992 first = 1; last = strlen(label);
1997 char *adot = strchr(label,
'.');
1998 if (adot) adot[ndecimals] = 0;
2000 while (label[last] ==
'0') { label[last] = 0; last--;}
2004 if (label[last] ==
'.') {
2005 if (!optionDot) { label[last] = 0; last--;}
2009 if (last-first == 1 && label[first] ==
'-'
2010 && label[last] ==
'0') {
2011 strncpy(label,
"0", 256);
2019 timed = wlabel + (
int)(timeoffset) - rangeOffset;
2020 timelabel = (time_t)((
Long_t)(timed));
2021 if (optionTime == 1) {
2022 utctis = localtime(&timelabel);
2024 utctis = gmtime(&timelabel);
2027 if (timeformat.
Length() < 220) timeformattmp = timeformat;
2028 else timeformattmp =
"#splitline{Format}{too long}";
2034 snprintf(label, 256,
"%%S%7.5f", modf(timed,&tmpdb));
2035 tmplast = strlen(label)-1;
2038 while (label[tmplast] ==
'0') {
2039 label[tmplast] = 0; tmplast--;
2048 if (utctis !=
nullptr) {
2049 strftime(label, 256, timeformattmp.
Data(), utctis);
2051 strncpy(label,
"invalid", 256);
2053 strlcpy(chtemp, &label[0], 256);
2054 first = 0; last=strlen(label)-1;
2055 wlabel = wTimeIni + (k+1)*dwlabel;
2060 if (optionNoopt && !optionInt)
2061 Rotate (xlabel,ylabel,cosphi,sinphi,x0,y0,xx,yy);
2062 else Rotate (xlabel,ylabel,cosphi,sinphi,xx0,yy0,xx,yy);
2063 if (y0 ==
y1 && !optionDown && !optionUp) {
2064 yy -= 0.80*charheight;
2067 if (x0 !=
x1 && y0 !=
y1) {
2068 if (optionNoopt && !optionInt)
2069 Rotate (xlabel,0,cosphi,sinphi,x0,y0,xx,yy);
2070 else Rotate (xlabel,0,cosphi,sinphi,xx0,yy0,xx,yy);
2071 if (cosphi > 0 ) yy += ylabel;
2072 if (cosphi < 0 ) yy -= ylabel;
2075 if (!optionY || (x0 ==
x1)) {
2077 if (first > last) strncpy(chtemp,
" ", 256);
2078 else strlcpy(chtemp, &label[first], 255);
2081 if (!optionTime) typolabel.
ReplaceAll(
"-",
"#minus");
2086 double scale=
gPad->GetWw()*
gPad->GetWNDC();
2087 if (scale>0.0) toffset =
TMath::Max(toffset,(
double)
w/scale);
2096 strlcpy(chtemp,
fAxis->GetBinLabel(k+
fAxis->GetFirst()), 255);
2108 if (!optionText) lnlen = last-first+1;
2110 if (k+1 > nhilab) lnlen = 0;
2112 for (
l=1;
l<=lnlen;
l++) {
2113 if (!optionText) *chtemp = label[first+
l-2];
2115 if (lnlen == 0) strncpy(chtemp,
" ", 256);
2116 else strncpy(chtemp,
"1", 256);
2125 yy -= charheight*1.3;
2132 if (flexe && !optionText && nexe) {
2133 snprintf(label,256,
"#times10^{%d}", nexe);
2134 if (x0 !=
x1) { xfactor = axis_length+0.1*charheight; yfactor = 0; }
2135 else { xfactor =
y1-y0+0.1*charheight; yfactor = 0; }
2136 Rotate (xfactor,yfactor,cosphi,sinphi,x0,y0,xx,yy);
2140 if (
fAxis && !strcmp(
fAxis->GetName(),
"xaxis")) {
2142 gStyle->GetExponentOffset(xoff, yoff,
"x");
2146 if (
fAxis && !strcmp(
fAxis->GetName(),
"yaxis")) {
2148 gStyle->GetExponentOffset(xoff, yoff,
"y");
2166 if (optionLog && ndiv) {
2167 UInt_t xi1=0,xi2=0,wi=0,yi1=0,yi2=0,
hi=0,xl=0,xh=0;
2169 if ((
wmin ==
wmax) || (ndiv == 0)) {
2170 Error(where,
"wmin (%f) == wmax (%f), or ndiv == 0",
wmin,
wmax);
2174 Error(where,
"negative logarithmic axis");
2178 Error(where,
"negative logarithmic axis");
2182 if (xmnlog > 0) xmnlog += 1.E-6;
2183 else xmnlog -= 1.E-6;
2188 if (h2 > 0) h2 += 1.E-6;
2193 axmul = (x11-x00)/(h2sav-xmnlog);
2198 if ( xmnlog > 0 && (xmnlog-
Double_t(ih1) > 0) ) labelnumber++;
2199 Int_t changelablogid = 0;
2200 Int_t changelablognum = 0;
2201 for (j=1; j<=nbinin; j++) {
2206 if (x0 ==
x1 && j == 1) ylabel += charheight*0.33;
2207 if (y0 ==
y1 && j == 1) ylabel -= charheight*0.65;
2208 xone = x00+axmul*(
Double_t(decade)-xmnlog);
2210 if (j < 0) printf(
"j=%d\n",j);
2211 if (x00 > xone)
goto L160;
2212 if ((xone-x11)>epsilon)
break;
2215 if (!mside)
y -= atick[0];
2216 Rotate(xone,
y,cosphi,sinphi,x0,y0,xpl2,ypl2);
2217 Rotate(xtwo,atick[0],cosphi,sinphi,x0,y0,xpl1,ypl1);
2219 if ((x0 !=
x1) && (y0 !=
y1)) {
2222 if (cosphi > 0) ypl1 = ypl2 + atick[0];
2223 else ypl1 = ypl2 - atick[0];
2226 xpl1 = 0.5*(xpl1 + xpl2);
2228 ypl1 = 0.5*(ypl1 + ypl2) + atick[0];
2229 ypl2 = 0.5*(ypl1 + ypl2) - atick[0];
2233 if (!drawGridOnly)
PaintLineNDC(xpl1, ypl1, xpl2, ypl2);
2236 Rotate(xone,0,cosphi,sinphi,x0,y0,xpl2,ypl2);
2237 Rotate(xone,grid_side*gridlength,cosphi,sinphi,x0,y0,xpl1,ypl1);
2241 if (!drawGridOnly && !optionUnlab) {
2249 while (last > first) {
2250 if (label[last] !=
'0')
break;
2254 if (label[last] ==
'.') {label[last] = 0; last--;}
2256 snprintf(label,256,
"%d", labelnumber);
2259 Rotate (xone,ylabel,cosphi,sinphi,x0,y0,xx,yy);
2260 if ((x0 ==
x1) && !optionPara) {
2263 if (labelnumber == 0) nch=1;
2265 xx += nch*charheight;
2267 xx += 0.25*charheight;
2270 xx += 0.25*charheight;
2272 if ((y0 ==
y1) && !optionDown && !optionUp) {
2273 if (noExponent) yy += 0.33*charheight;
2275 if (n1a == 0)
return;
2277 if (kmod == 0) kmod=1000000;
2278 if ((nbinin <= n1a) || (j == 1) || (j == nbinin) || ((nbinin > n1a) && (j%kmod == 0))) {
2279 if (labelnumber == 0) {
2281 }
else if (labelnumber == 1) {
2285 chtemp = &label[first];
2287 snprintf(chtemp,256,
"10^{%d}", labelnumber);
2291 if (changelablogid == 0) changelablognum = nbinin-j;
2301 double scale=
gPad->GetWw()*
gPad->GetWNDC();
2302 if (scale>0.0) toffset =
TMath::Max(toffset,(
double)
w/scale);
2312 for (k=2;k<10;k++) {
2316 if (x00 > xone)
continue;
2317 if (xone > x11)
goto L200;
2319 if (!mside)
y -= atick[1];
2321 Rotate(xone,
y,cosphi,sinphi,x0,y0,xpl2,ypl2);
2322 Rotate(xtwo,atick[1],cosphi,sinphi,x0,y0,xpl1,ypl1);
2324 if ((x0 !=
x1) && (y0 !=
y1)) {
2327 if (cosphi > 0) ypl1 = ypl2 + atick[1];
2328 else ypl1 = ypl2 - atick[1];
2331 xpl1 = 0.5*(xpl1+xpl2);
2333 ypl1 = 0.5*(ypl1+ypl2) + atick[1];
2334 ypl2 = 0.5*(ypl1+ypl2) - atick[1];
2339 if ((nbinin <= idn) || ((nbinin > idn) && (k == 5))) {
2340 if (!drawGridOnly)
PaintLineNDC(xpl1, ypl1, xpl2, ypl2);
2344 if (moreLogLabels && !optionUnlab && !drawGridOnly && !overlap) {
2350 if (labelnumber-1 == 0) {
2352 }
else if (labelnumber-1 == 1) {
2355 snprintf(chtemp,256,
"%d#times10^{%d}", k, labelnumber-1);
2358 Rotate (xone,ylabel,cosphi,sinphi,x0,y0,xx,yy);
2359 if ((x0 ==
x1) && !optionPara) {
2362 if (labelnumber == 0) nch=1;
2364 xx += nch*charheight;
2366 if (labelnumber >= 0) xx += 0.25*charheight;
2367 else xx += 0.50*charheight;
2370 xx += 0.25*charheight;
2372 if ((y0 ==
y1) && !optionDown && !optionUp) {
2373 if (noExponent) yy += 0.33*charheight;
2376 if ((x0 !=
x1) && (y0 !=
y1)) {
2377 Rotate(xone,ylabel,cosphi,sinphi,x0,y0,xx,yy);
2378 if (cosphi > 0) yy += ylabel;
2387 xi1 =
gPad->XtoAbsPixel(u);
2388 yi1 =
gPad->YtoAbsPixel(
v);
2399 xi2 =
gPad->XtoAbsPixel(u);
2400 yi2 =
gPad->YtoAbsPixel(
v);
2403 if ((x0 ==
x1 && yi1-
hi <= yi2) || (y0 ==
y1 && xl+wi >= xh)){
2422 if (optionGrid && nbinin <= 5 && ndiv > 100) {
2423 Rotate(xone,0,cosphi,sinphi,x0,y0,xpl2, ypl2);
2424 Rotate(xone,grid_side*gridlength,cosphi,sinphi,x0,y0, xpl1,ypl1);
2431 Int_t dummy = 0;
if (dummy) { }
2435 if (!drawGridOnly && strlen(
GetTitle())) {
2439 charheight /= ((
x1==x0) ? padw : padh);
2443 if (toffset) ylabel = xlside*charheight+toffset;
2444 else ylabel = xlside*1.6*charheight;
2446 ylabel = xlside*1.6*charheight*toffset;
2449 ylabel = xlside*1.3*charheight*toffset;
2452 if (toffset == 0.) toffset =
gStyle->GetTitleOffset(
"X");
2453 ylabel = xlside*1.6*charheight*toffset;
2457 else axispos = axis_length;
2476 Rotate(axispos,ylabel,cosphi,sinphi,x0,y0,xpl1,ypl1);