#ifdef WIN32
#pragma optimize("",off)
#endif
#include <stdlib.h>
#include <string.h>
#include <ctype.h>
#include "Riostream.h"
#include "TROOT.h"
#include "TColor.h"
#include "TVirtualPad.h"
#include "TPoints.h"
#include "TTeXDump.h"
#include "TStyle.h"
#include "TMath.h"
#include "TObjString.h"
#include "TObjArray.h"
#include "TClass.h"
ClassImp(TTeXDump)
TTeXDump::TTeXDump() : TVirtualPS()
{
fStream = 0;
fType = 0;
gVirtualPS = this;
fBoundingBox = kFALSE;
fRange = kFALSE;
fXsize = 0.;
fYsize = 0.;
fCurrentRed = -1.;
fCurrentGreen = -1.;
fCurrentBlue = -1.;
fCurrentAlpha = 1.;
fLineScale = 0.;
}
TTeXDump::TTeXDump(const char *fname, Int_t wtype) : TVirtualPS(fname, wtype)
{
fStream = 0;
fType = 0;
gVirtualPS = this;
fBoundingBox = kFALSE;
fRange = kFALSE;
fXsize = 0.;
fYsize = 0.;
fCurrentRed = -1.;
fCurrentGreen = -1.;
fCurrentBlue = -1.;
fCurrentAlpha = 1.;
fLineScale = 0.;
Open(fname, wtype);
}
void TTeXDump::Open(const char *fname, Int_t wtype)
{
if (fStream) {
Warning("Open", "TeX file already open");
return;
}
SetLineScale(gStyle->GetLineScalePS());
fLenBuffer = 0;
fType = abs(wtype);
gStyle->GetPaperSize(fXsize, fYsize);
Float_t xrange, yrange;
if (gPad) {
Double_t ww = gPad->GetWw();
Double_t wh = gPad->GetWh();
ww *= gPad->GetWNDC();
wh *= gPad->GetHNDC();
Double_t ratio = wh/ww;
xrange = fXsize;
yrange = fXsize*ratio;
if (yrange > fYsize) { yrange = fYsize; xrange = yrange/ratio;}
fXsize = xrange; fYsize = yrange;
}
fStream = new std::ofstream(fname,std::ios::out);
if (fStream == 0 || !fStream->good()) {
printf("ERROR in TTeXDump::Open: Cannot open file:%s\n",fname);
if (fStream == 0) return;
}
gVirtualPS = this;
for (Int_t i=0;i<fSizBuffer;i++) fBuffer[i] = ' ';
fBoundingBox = kFALSE;
fRange = kFALSE;
Range(fXsize, fYsize);
NewPage();
}
TTeXDump::~TTeXDump()
{
Close();
}
void TTeXDump::Close(Option_t *)
{
if (!gVirtualPS) return;
if (!fStream) return;
if (gPad) gPad->Update();
PrintStr("@");
PrintStr("\\end{tikzpicture}@");
if (fStream) { fStream->close(); delete fStream; fStream = 0;}
gVirtualPS = 0;
}
void TTeXDump::On()
{
if (!fType) {
Error("On", "no TeX file open");
Off();
return;
}
gVirtualPS = this;
}
void TTeXDump::Off()
{
gVirtualPS = 0;
}
void TTeXDump::DrawBox(Double_t x1, Double_t y1, Double_t x2, Double_t y2)
{
Float_t x1c = XtoTeX(x1);
Float_t y1c = YtoTeX(y1);
Float_t x2c = XtoTeX(x2);
Float_t y2c = YtoTeX(y2);
Int_t fillis = fFillStyle/1000;
Int_t fillsi = fFillStyle%1000;
if (fillis==1) {
SetColor(fFillColor);
PrintStr("@");
PrintStr("\\draw [color=c, fill=c");
if (fCurrentAlpha != 1.) {
PrintStr(", fill opacity=");
WriteReal(fCurrentAlpha, kFALSE);
}
PrintStr("] (");
WriteReal(x1c, kFALSE);
PrintFast(1,",");
WriteReal(y1c, kFALSE);
PrintStr(") rectangle (");
WriteReal(x2c, kFALSE);
PrintFast(1,",");
WriteReal(y2c, kFALSE);
PrintStr(");");
}
if (fillis>1 && fillis<4) {
SetColor(fFillColor);
PrintStr("@");
PrintStr("\\draw [pattern=");
if (fillsi==1) PrintStr("crosshatch dots");
if (fillsi==2) PrintStr("dots");
if (fillsi==4) PrintStr("north east lines");
if (fillsi==5) PrintStr("north west lines");
if (fillsi==6) PrintStr("vertical lines");
if (fillsi==7) PrintStr("horizontal lines");
if (fillsi==10) PrintStr("bricks");
if (fillsi==13) PrintStr("crosshatch");
PrintStr(", pattern color=c");
if (fCurrentAlpha != 1.) {
PrintStr(", fill opacity=");
WriteReal(fCurrentAlpha, kFALSE);
}
PrintStr("] (");
WriteReal(x1c, kFALSE);
PrintFast(1,",");
WriteReal(y1c, kFALSE);
PrintStr(") rectangle (");
WriteReal(x2c, kFALSE);
PrintFast(1,",");
WriteReal(y2c, kFALSE);
PrintStr(");");
}
if (fillis == 0) {
SetColor(fLineColor);
PrintStr("@");
PrintStr("\\draw [c");
PrintStr(",line width=");
WriteReal(0.3*fLineScale*fLineWidth, kFALSE);
if (fCurrentAlpha != 1.) {
PrintStr(", opacity=");
WriteReal(fCurrentAlpha, kFALSE);
}
PrintStr("] (");
WriteReal(x1c, kFALSE);
PrintFast(1,",");
WriteReal(y1c, kFALSE);
PrintStr(") -- (");
WriteReal(x1c, kFALSE);
PrintFast(1,",");
WriteReal(y2c, kFALSE);
PrintStr(") -- (");
WriteReal(x2c, kFALSE);
PrintFast(1,",");
WriteReal(y2c, kFALSE);
PrintStr(") -- (");
WriteReal(x2c, kFALSE);
PrintFast(1,",");
WriteReal(y1c, kFALSE);
PrintStr(") -- (");
WriteReal(x1c, kFALSE);
PrintFast(1,",");
WriteReal(y1c, kFALSE);
PrintStr(");");
}
}
void TTeXDump::DrawFrame(Double_t, Double_t, Double_t, Double_t,
Int_t, Int_t, Int_t, Int_t)
{
Warning("DrawFrame", "not yet implemented");
}
void TTeXDump::DrawPolyLine(Int_t, TPoints *)
{
Warning("DrawPolyLine", "not yet implemented");
}
void TTeXDump::DrawPolyLineNDC(Int_t, TPoints *)
{
Warning("DrawPolyLineNDC", "not yet implemented");
}
void TTeXDump::DrawPolyMarker(Int_t, Float_t *, Float_t *)
{
Warning("DrawPolyMarker", "not yet implemented");
}
void TTeXDump::DrawPolyMarker(Int_t n, Double_t *xw, Double_t *yw)
{
Float_t x, y;
SetColor(fMarkerColor);
PrintStr("@");
PrintStr("\\foreach \\P in {");
x = XtoTeX(xw[0]);
y = YtoTeX(yw[0]);
PrintStr("(");
WriteReal(x, kFALSE);
PrintFast(1,",");
WriteReal(y, kFALSE);
PrintStr(")");
for (Int_t i=1;i<n;i++) {
x = XtoTeX(xw[i]);
y = YtoTeX(yw[i]);
PrintFast(2,",(");
WriteReal(x, kFALSE);
PrintFast(1,",");
WriteReal(y, kFALSE);
PrintFast(1,")");
}
if (fMarkerStyle == 23 || fMarkerStyle == 32) {
PrintStr("}{\\draw[mark options={color=c,fill=c,rotate=180},mark size=");
} else {
PrintStr("}{\\draw[mark options={color=c,fill=c},mark size=");
}
PrintStr(Form("%fpt,mark=",8./3.33*fMarkerSize));
switch (fMarkerStyle) {
case 1 :
PrintStr("*");
PrintStr(",mark size=1pt");
break;
case 2 :
PrintStr("+");
break;
case 3 :
PrintStr("asterisk");
break;
case 4 :
PrintStr("o");
break;
case 5 :
PrintStr("x");
break;
case 20 :
PrintStr("*");
break;
case 21 :
PrintStr("square*");
break;
case 22 :
PrintStr("triangle*");
break;
case 23 :
PrintStr("triangle*");
break;
case 24 :
PrintStr("o");
break;
case 25 :
PrintStr("square");
break;
case 26 :
PrintStr("triangle");
break;
case 27 :
PrintStr("diamond");
break;
case 28 :
PrintStr("cross");
break;
case 29 :
PrintStr("newstar*");
break;
case 30 :
PrintStr("newstar");
break;
case 31 :
PrintStr("10-pointed star");
break;
case 32 :
PrintStr("triangle");
break;
case 33 :
PrintStr("diamond*");
break;
case 34 :
PrintStr("cross*");
break;
}
PrintStr("] plot coordinates {\\P};}");
}
void TTeXDump::DrawPS(Int_t nn, Double_t *xw, Double_t *yw)
{
Int_t n = TMath::Abs(nn);;
Float_t x, y;
if( n <= 1) {
Error("DrawPS", "Two points are needed");
return;
}
x = XtoTeX(xw[0]);
y = YtoTeX(yw[0]);
Int_t fillis = fFillStyle/1000;
Int_t fillsi = fFillStyle%1000;
if (nn>0) {
SetColor(fLineColor);
PrintStr("@");
PrintStr("\\draw [c");
switch(fLineStyle) {
case 1:
break;
case 2:
PrintStr(",dashed");
break;
case 3:
PrintStr(",dotted");
break;
case 4:
PrintStr(",dash pattern=on 2.4pt off 3.2pt on 0.8pt off 3.2pt");
break;
case 5:
PrintStr(",dash pattern=on 4pt off 2.4pt on 0.8pt off 2.4pt");
break;
case 6:
PrintStr(",dash pattern=on 4pt off 2.4pt on 0.8pt off 2.4pt on 0.8pt off 2.4pt on 0.8pt off 2.4pt");
break;
case 7:
PrintStr(",dash pattern=on 4pt off 4pt");
break;
case 8:
PrintStr(",dash pattern=on 4pt off 2.4pt on 0.8pt off 2.4pt on 0.8pt off 2.4pt");
break;
case 9:
PrintStr(",dash pattern=on 16pt off 4pt");
break;
case 10:
PrintStr(",dash pattern=on 16pt off 8pt on 0.8pt off 8pt");
break;
}
PrintStr(",line width=");
WriteReal(0.3*fLineScale*fLineWidth, kFALSE);
} else {
SetColor(fFillColor);
if (fillis==1) {
PrintStr("@");
PrintStr("\\draw [c, fill=c");
} else if (fillis==0) {
PrintStr("@");
PrintStr("\\draw [c");
} else {
PrintStr("\\draw [pattern=");
if (fillsi==1) PrintStr("crosshatch dots");
if (fillsi==2) PrintStr("dots");
if (fillsi==4) PrintStr("north east lines");
if (fillsi==5) PrintStr("north west lines");
if (fillsi==6) PrintStr("vertical lines");
if (fillsi==7) PrintStr("horizontal lines");
if (fillsi==10) PrintStr("bricks");
if (fillsi==13) PrintStr("crosshatch");
PrintStr(", pattern color=c");
}
if (fCurrentAlpha != 1.) {
PrintStr(", fill opacity=");
WriteReal(fCurrentAlpha, kFALSE);
}
}
PrintStr("] (");
WriteReal(x, kFALSE);
PrintFast(1,",");
WriteReal(y, kFALSE);
PrintStr(") -- ");
for (Int_t i=1;i<n;i++) {
x = XtoTeX(xw[i]);
y = YtoTeX(yw[i]);
PrintFast(1,"(");
WriteReal(x, kFALSE);
PrintFast(1,",");
WriteReal(y, kFALSE);
PrintFast(1,")");
if (i<n-1) PrintStr(" -- ");
else PrintStr(";@");
}
}
void TTeXDump::NewPage()
{
if (gPad) {
Double_t ww = gPad->GetWw();
Double_t wh = gPad->GetWh();
fYsize = fXsize*wh/ww;
} else {
fYsize = 27;
}
if(!fBoundingBox) {
PrintStr("\\begin{tikzpicture}@");
DefineMarkers();
fBoundingBox = kTRUE;
}
}
void TTeXDump::Range(Float_t xsize, Float_t ysize)
{
fXsize = xsize;
fYsize = ysize;
fRange = kTRUE;
}
void TTeXDump::SetFillColor( Color_t cindex )
{
fFillColor = cindex;
if (gStyle->GetFillColor() <= 0) cindex = 0;
}
void TTeXDump::SetLineColor( Color_t cindex )
{
fLineColor = cindex;
}
void TTeXDump::SetLineStyle(Style_t linestyle)
{
fLineStyle = linestyle;
}
void TTeXDump::SetLineWidth(Width_t linewidth)
{
fLineWidth = linewidth;
}
void TTeXDump::SetMarkerSize( Size_t msize)
{
fMarkerSize = msize;
}
void TTeXDump::SetMarkerColor( Color_t cindex)
{
fMarkerColor = cindex;
}
void TTeXDump::SetColor(Int_t color)
{
if (color < 0) color = 0;
TColor *col = gROOT->GetColor(color);
if (col) SetColor(col->GetRed(), col->GetGreen(), col->GetBlue());
else SetColor(1., 1., 1.);
fCurrentAlpha = col->GetAlpha();
}
void TTeXDump::SetColor(Float_t r, Float_t g, Float_t b)
{
if (fCurrentRed == r && fCurrentGreen == g && fCurrentBlue == b) return;
fCurrentRed = r;
fCurrentGreen = g;
fCurrentBlue = b;
PrintStr("@");
PrintStr("\\definecolor{c}{rgb}{");
WriteReal(r, kFALSE);
PrintFast(1,",");
WriteReal(g, kFALSE);
PrintFast(1,",");
WriteReal(b, kFALSE);
PrintFast(2,"};");
}
void TTeXDump::SetTextColor( Color_t cindex )
{
fTextColor = cindex;
}
void TTeXDump::Text(Double_t x, Double_t y, const char *chars)
{
Double_t wh = (Double_t)gPad->XtoPixel(gPad->GetX2());
Double_t hh = (Double_t)gPad->YtoPixel(gPad->GetY1());
Float_t tsize, ftsize;
if (wh < hh) {
tsize = fTextSize*wh;
Int_t sizeTTF = (Int_t)(tsize+0.5);
ftsize = (sizeTTF*fXsize*gPad->GetAbsWNDC())/wh;
} else {
tsize = fTextSize*hh;
Int_t sizeTTF = (Int_t)(tsize+0.5);
ftsize = (sizeTTF*fYsize*gPad->GetAbsHNDC())/hh;
}
ftsize *= 2.22097;
if (ftsize <= 0) return;
TString t(chars);
if (t.Index("\\")>=0 || t.Index("^{")>=0 || t.Index("_{")>=0) {
t.Prepend("$");
t.Append("$");
} else {
t.ReplaceAll("<","$<$");
t.ReplaceAll(">","$>$");
t.ReplaceAll("_","\\_");
}
t.ReplaceAll("&","\\&");
t.ReplaceAll("#","\\#");
t.ReplaceAll("%","\\%");
Int_t txalh = fTextAlign/10;
if (txalh <1) txalh = 1; if (txalh > 3) txalh = 3;
Int_t txalv = fTextAlign%10;
if (txalv <1) txalv = 1; if (txalv > 3) txalv = 3;
SetColor(fTextColor);
PrintStr("@");
PrintStr("\\draw");
if (txalh!=2 || txalv!=2) {
PrintStr(" [anchor=");
if (txalv==1) PrintStr("base");
if (txalv==3) PrintStr("north");
if (txalh==1) PrintStr(" west");
if (txalh==3) PrintStr(" east");
PrintFast(1,"]");
}
PrintFast(2," (");
WriteReal(XtoTeX(x), kFALSE);
PrintFast(1,",");
WriteReal(YtoTeX(y), kFALSE);
PrintStr(") node[scale=");
WriteReal(ftsize, kFALSE);
PrintStr(", color=c, rotate=");
WriteReal(fTextAngle, kFALSE);
PrintFast(2,"]{");
PrintStr(t.Data());
PrintFast(2,"};");
}
void TTeXDump::TextNDC(Double_t u, Double_t v, const char *chars)
{
Double_t x = gPad->GetX1() + u*(gPad->GetX2() - gPad->GetX1());
Double_t y = gPad->GetY1() + v*(gPad->GetY2() - gPad->GetY1());
Text(x, y, chars);
}
Float_t TTeXDump::UtoTeX(Double_t u)
{
Double_t cm = fXsize*(gPad->GetAbsXlowNDC() + u*gPad->GetAbsWNDC());
return cm;
}
Float_t TTeXDump::VtoTeX(Double_t v)
{
Double_t cm = fYsize*(gPad->GetAbsYlowNDC() + v*gPad->GetAbsHNDC());
return cm;
}
Float_t TTeXDump::XtoTeX(Double_t x)
{
Double_t u = (x - gPad->GetX1())/(gPad->GetX2() - gPad->GetX1());
return UtoTeX(u);
}
Float_t TTeXDump::YtoTeX(Double_t y)
{
Double_t v = (y - gPad->GetY1())/(gPad->GetY2() - gPad->GetY1());
return VtoTeX(v);
}
void TTeXDump::CellArrayBegin(Int_t, Int_t, Double_t, Double_t, Double_t,
Double_t)
{
Warning("CellArrayBegin", "not yet implemented");
}
void TTeXDump::CellArrayFill(Int_t, Int_t, Int_t)
{
Warning("CellArrayFill", "not yet implemented");
}
void TTeXDump::CellArrayEnd()
{
Warning("CellArrayEnd", "not yet implemented");
}
void TTeXDump::DrawPS(Int_t, Float_t *, Float_t *)
{
Warning("DrawPS", "not yet implemented");
}
void TTeXDump::DefineMarkers()
{
PrintStr("\\pgfdeclareplotmark{cross} {@");
PrintStr("\\pgfpathmoveto{\\pgfpoint{-0.3\\pgfplotmarksize}{\\pgfplotmarksize}}@");
PrintStr("\\pgfpathlineto{\\pgfpoint{+0.3\\pgfplotmarksize}{\\pgfplotmarksize}}@");
PrintStr("\\pgfpathlineto{\\pgfpoint{+0.3\\pgfplotmarksize}{0.3\\pgfplotmarksize}}@");
PrintStr("\\pgfpathlineto{\\pgfpoint{+1\\pgfplotmarksize}{0.3\\pgfplotmarksize}}@");
PrintStr("\\pgfpathlineto{\\pgfpoint{+1\\pgfplotmarksize}{-0.3\\pgfplotmarksize}}@");
PrintStr("\\pgfpathlineto{\\pgfpoint{+0.3\\pgfplotmarksize}{-0.3\\pgfplotmarksize}}@");
PrintStr("\\pgfpathlineto{\\pgfpoint{+0.3\\pgfplotmarksize}{-1.\\pgfplotmarksize}}@");
PrintStr("\\pgfpathlineto{\\pgfpoint{-0.3\\pgfplotmarksize}{-1.\\pgfplotmarksize}}@");
PrintStr("\\pgfpathlineto{\\pgfpoint{-0.3\\pgfplotmarksize}{-0.3\\pgfplotmarksize}}@");
PrintStr("\\pgfpathlineto{\\pgfpoint{-1.\\pgfplotmarksize}{-0.3\\pgfplotmarksize}}@");
PrintStr("\\pgfpathlineto{\\pgfpoint{-1.\\pgfplotmarksize}{0.3\\pgfplotmarksize}}@");
PrintStr("\\pgfpathlineto{\\pgfpoint{-0.3\\pgfplotmarksize}{0.3\\pgfplotmarksize}}@");
PrintStr("\\pgfpathclose@");
PrintStr("\\pgfusepathqstroke@");
PrintStr("}@");
PrintStr("\\pgfdeclareplotmark{cross*} {@");
PrintStr("\\pgfpathmoveto{\\pgfpoint{-0.3\\pgfplotmarksize}{\\pgfplotmarksize}}@");
PrintStr("\\pgfpathlineto{\\pgfpoint{+0.3\\pgfplotmarksize}{\\pgfplotmarksize}}@");
PrintStr("\\pgfpathlineto{\\pgfpoint{+0.3\\pgfplotmarksize}{0.3\\pgfplotmarksize}}@");
PrintStr("\\pgfpathlineto{\\pgfpoint{+1\\pgfplotmarksize}{0.3\\pgfplotmarksize}}@");
PrintStr("\\pgfpathlineto{\\pgfpoint{+1\\pgfplotmarksize}{-0.3\\pgfplotmarksize}}@");
PrintStr("\\pgfpathlineto{\\pgfpoint{+0.3\\pgfplotmarksize}{-0.3\\pgfplotmarksize}}@");
PrintStr("\\pgfpathlineto{\\pgfpoint{+0.3\\pgfplotmarksize}{-1.\\pgfplotmarksize}}@");
PrintStr("\\pgfpathlineto{\\pgfpoint{-0.3\\pgfplotmarksize}{-1.\\pgfplotmarksize}}@");
PrintStr("\\pgfpathlineto{\\pgfpoint{-0.3\\pgfplotmarksize}{-0.3\\pgfplotmarksize}}@");
PrintStr("\\pgfpathlineto{\\pgfpoint{-1.\\pgfplotmarksize}{-0.3\\pgfplotmarksize}}@");
PrintStr("\\pgfpathlineto{\\pgfpoint{-1.\\pgfplotmarksize}{0.3\\pgfplotmarksize}}@");
PrintStr("\\pgfpathlineto{\\pgfpoint{-0.3\\pgfplotmarksize}{0.3\\pgfplotmarksize}}@");
PrintStr("\\pgfpathclose@");
PrintStr("\\pgfusepathqfillstroke@");
PrintStr("}@");
PrintStr("\\pgfdeclareplotmark{newstar} {@");
PrintStr("\\pgfpathmoveto{\\pgfqpoint{0pt}{\\pgfplotmarksize}}@");
PrintStr("\\pgfpathlineto{\\pgfqpointpolar{44}{0.5\\pgfplotmarksize}}@");
PrintStr("\\pgfpathlineto{\\pgfqpointpolar{18}{\\pgfplotmarksize}}@");
PrintStr("\\pgfpathlineto{\\pgfqpointpolar{-20}{0.5\\pgfplotmarksize}}@");
PrintStr("\\pgfpathlineto{\\pgfqpointpolar{-54}{\\pgfplotmarksize}}@");
PrintStr("\\pgfpathlineto{\\pgfqpointpolar{-90}{0.5\\pgfplotmarksize}}@");
PrintStr("\\pgfpathlineto{\\pgfqpointpolar{234}{\\pgfplotmarksize}}@");
PrintStr("\\pgfpathlineto{\\pgfqpointpolar{198}{0.5\\pgfplotmarksize}}@");
PrintStr("\\pgfpathlineto{\\pgfqpointpolar{162}{\\pgfplotmarksize}}@");
PrintStr("\\pgfpathlineto{\\pgfqpointpolar{134}{0.5\\pgfplotmarksize}}@");
PrintStr("\\pgfpathclose@");
PrintStr("\\pgfusepathqstroke@");
PrintStr("}@");
PrintStr("\\pgfdeclareplotmark{newstar*} {@");
PrintStr("\\pgfpathmoveto{\\pgfqpoint{0pt}{\\pgfplotmarksize}}@");
PrintStr("\\pgfpathlineto{\\pgfqpointpolar{44}{0.5\\pgfplotmarksize}}@");
PrintStr("\\pgfpathlineto{\\pgfqpointpolar{18}{\\pgfplotmarksize}}@");
PrintStr("\\pgfpathlineto{\\pgfqpointpolar{-20}{0.5\\pgfplotmarksize}}@");
PrintStr("\\pgfpathlineto{\\pgfqpointpolar{-54}{\\pgfplotmarksize}}@");
PrintStr("\\pgfpathlineto{\\pgfqpointpolar{-90}{0.5\\pgfplotmarksize}}@");
PrintStr("\\pgfpathlineto{\\pgfqpointpolar{234}{\\pgfplotmarksize}}@");
PrintStr("\\pgfpathlineto{\\pgfqpointpolar{198}{0.5\\pgfplotmarksize}}@");
PrintStr("\\pgfpathlineto{\\pgfqpointpolar{162}{\\pgfplotmarksize}}@");
PrintStr("\\pgfpathlineto{\\pgfqpointpolar{134}{0.5\\pgfplotmarksize}}@");
PrintStr("\\pgfpathclose@");
PrintStr("\\pgfusepathqfillstroke@");
PrintStr("}@");
}