18Int_t year, month, day;
20TProfile *hYear =
nullptr, *hMonth =
nullptr, *hDay =
nullptr;
27Int_t rMonth[3] = { 12, 1, 13 };
28Int_t rDay[3] = { 31, 1, 32 };
29Double_t rTemp[3] = { 55.0, -20.0, 35.0 };
31void HighlightDay(
Int_t xhb)
41 if (xhb != customhb) day = xhb;
43 if (hDay->GetBinEntries(day) == 0) temp =
" ";
52void HighlightMonth(
Int_t xhb)
55 hDay =
new TProfile(
"hDay",
"; day; temp, #circC", rDay[0], rDay[1], rDay[2]);
56 hDay->SetMinimum(rTemp[1]);
57 hDay->SetMaximum(rTemp[2]);
58 hDay->GetYaxis()->SetNdivisions(410);
59 hDay->SetFillColor(
kGray);
62 hDay->
Draw(
"HIST, CP");
67 if (xhb != customhb) month = xhb;
69 hDay->SetTitle(
TString::Format(
"temperature by day (month = %02d, year = %d)", month, year));
72 HighlightDay(customhb);
75void HighlightYear(
Int_t xhb)
78 hMonth =
new TProfile(
"hMonth",
"; month; temp, #circC", rMonth[0], rMonth[1], rMonth[2]);
79 hMonth->SetMinimum(rTemp[1]);
80 hMonth->SetMaximum(rTemp[2]);
81 hMonth->GetXaxis()->SetNdivisions(112);
82 hMonth->GetXaxis()->CenterLabels();
83 hMonth->GetYaxis()->SetNdivisions(410);
84 hMonth->SetFillColor(
kGray+1);
87 hMonth->Draw(
"HIST, CP");
89 hMonth->SetHighlight();
92 year = xhb - 1 + rYear[1];
94 hMonth->SetTitle(
TString::Format(
"temperature by month (year = %d)", year));
97 HighlightMonth(customhb);
102 if (obj == hYear) HighlightYear(xhb);
103 if (obj == hMonth) HighlightMonth(xhb);
104 if (obj == hDay) HighlightDay(xhb);
115 auto dir =
gROOT->GetTutorialDir();
116 dir.Append(
"/tree/");
117 dir.ReplaceAll(
"/./",
"/");
118 if (
tree->ReadFile(
Form(
"%stemperature_Prague.dat",dir.Data())) == 0)
return;
122 rYear[1] = (
Int_t)
tree->GetLeaf(
"YEAR")->GetValue();
123 tree->GetEntry(
tree->GetEntries() - 1);
124 rYear[2] = (
Int_t)
tree->GetLeaf(
"YEAR")->GetValue();
125 rYear[2] = rYear[2] + 1;
126 rYear[0] = rYear[2] - rYear[1];
129 hYear =
new TProfile(
"hYear",
"temperature (average) by year; year; temp, #circC", rYear[0], rYear[1], rYear[2]);
130 tree->Draw(
"T:YEAR>>hYear",
"",
"goff");
141 Canvas =
new TCanvas(
"Canvas",
"Canvas", 0, 0, 700, 900);
142 Canvas->
HighlightConnect(
"HighlightTemp(TVirtualPad*,TObject*,Int_t,Int_t)");
143 Canvas->
Divide(1, 3, 0.001, 0.001);
145 hYear->
Draw(
"HIST, LP");
char * Form(const char *fmt,...)
Formats a string in a circular formatting buffer.
R__EXTERN TStyle * gStyle
virtual void SetNdivisions(Int_t n=510, Bool_t optim=kTRUE)
Set the number of divisions for this axis.
virtual void SetLineColor(Color_t lcolor)
Set the line 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 SetTextSizePixels(Int_t npixels)
Set the text size in pixel.
virtual void HighlightConnect(const char *slot)
This is "simplification" for function TCanvas::Connect with Highlighted signal for specific slot.
TVirtualPad * cd(Int_t subpadnumber=0) override
Set current canvas & pad.
void Update() override
Update canvas pad buffers.
virtual Double_t GetMean(Int_t axis=1) const
For axis = 1,2 or 3 returns the mean value of the histogram along X,Y or Z axis.
virtual void SetMaximum(Double_t maximum=-1111)
void Draw(Option_t *option="") override
Draw this histogram with options.
virtual void SetMinimum(Double_t minimum=-1111)
virtual void SetHighlight(Bool_t set=kTRUE)
Set highlight (enable/disable) mode for the histogram by default highlight mode is disable.
To draw Mathematical Formula.
Mother of all ROOT objects.
virtual void Draw(Option_t *option="")
Default Draw method for all objects.
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.
TVirtualPad * GetPad(Int_t subpadnumber) const override
Get a pointer to subpadnumber of this pad.
const char * Data() const
static TString Format(const char *fmt,...)
Static method which formats a string using a printf style format descriptor and return a TString.
void SetOptStat(Int_t stat=1)
The type of information printed in the histogram statistics box can be selected via the parameter mod...
virtual void SetText(Double_t x, Double_t y, const char *text)
A TTree represents a columnar dataset.
TVirtualPad is an abstract base class for the Pad and Canvas classes.
virtual void Modified(Bool_t flag=1)=0
void Draw(Option_t *option="") override=0
Default Draw method for all objects.
virtual void SetGridx(Int_t value=1)=0