26 #include "QwTreeEventBuffer.h" // Create hit list from G4 Monte Carlo
49 fMain =
new TGMainFrame(gClient->GetRoot(),10,10,kMainFrame | kVerticalFrame);
50 fMain->SetLayoutBroken(kTRUE);
51 fMain->SetWindowName(
"Qweak 2D Single Event Display");
61 fMenuFile =
new TGPopupMenu(gClient->GetRoot());
66 fMenuHelp =
new TGPopupMenu(gClient->GetRoot());
71 fMenuFile->Connect(
"Activated(Int_t)",
"QwEventDisplay",
this,
"HandleMenu(Int_t)");
72 fMenuHelp->Connect(
"Activated(Int_t)",
"QwEventDisplay",
this,
"HandleMenu(Int_t)");
77 gClient->GetColorByName(
"#deba87", ucolor);
78 fMenuBar->SetBackgroundColor(ucolor);
87 gClient->GetColorByName(
"#ffffff",ucolor);
88 TGHorizontalFrame *fLogos =
new TGHorizontalFrame(
fMain,900,80,kHorizontalFrame | kRaisedFrame,ucolor);
89 fLogos->SetLayoutBroken(kTRUE);
91 TGIcon *QweakLogo =
new TGIcon(fLogos,
getenv_safe_TString(
"QWANALYSIS") +
"/Extensions/Logos/qweak.jpg");
92 fLogos->AddFrame(QweakLogo,
new TGLayoutHints(kLHintsLeft | kLHintsTop,2,2,2,2));
93 QweakLogo->MoveResize(0,1,140,77);
96 ufont = gClient->GetFont(
"-*-helvetica-bold-r-*-*-34-*-*-*-*-*-*-*");
98 valBox.fMask = kGCForeground | kGCBackground | kGCFillStyle | kGCFont | kGCGraphicsExposures;
99 gClient->GetColorByName(
"#000000",valBox.fForeground);
100 gClient->GetColorByName(
"#c0c0c0",valBox.fBackground);
101 valBox.fFillStyle = kFillSolid;
102 valBox.fFont = ufont->GetFontHandle();
103 valBox.fGraphicsExposures = kFALSE;
104 uGC = gClient->GetGC(&valBox, kTRUE);
107 gClient->GetColorByName(
"#d45954",ucolor);
108 TGLabel *TitleBox =
new TGLabel(fLogos,
"Qweak 2D Single Event Display",uGC->GetGC(),ufont->GetFontStruct(),kRaisedFrame,ucolor);
109 TitleBox->SetTextJustify(36);
110 TitleBox->SetMargins(0,0,0,0);
111 TitleBox->SetWrapLength(-1);
112 fLogos->AddFrame(TitleBox,
new TGLayoutHints(kLHintsLeft | kLHintsTop,2,2,2,2));
113 TitleBox->MoveResize(143,1,627,77);
116 TGIcon *GWULogo =
new TGIcon(fLogos,
getenv_safe_TString(
"QWANALYSIS") +
"/Extensions/Logos/gwu_logo_main.gif");
117 fLogos->AddFrame(GWULogo,
new TGLayoutHints(kLHintsNormal));
118 GWULogo->MoveResize(772,1,135,77);
121 fMain->AddFrame(fLogos,
new TGLayoutHints(kLHintsLeft | kLHintsTop,2,2,2,2));
122 fLogos->MoveResize(0,20,900,100);
128 gClient->GetColorByName(
"#0047ab",ucolor);
135 gClient->GetColorByName(
"#d4cf87",ucolor);
140 gClient->GetColorByName(
"#deba87", ucolor);
141 ufont = gClient->GetFont(
"-*-charter-bold-r-*-*-15-*-*-*-*-*-*-*");
142 GCValues_t valunterLabel;
143 valunterLabel.fMask = kGCForeground | kGCBackground | kGCFillStyle | kGCFont | kGCGraphicsExposures;
144 gClient->GetColorByName(
"#000000",valunterLabel.fForeground);
145 gClient->GetColorByName(
"#c0c0c0",valunterLabel.fBackground);
146 valunterLabel.fFillStyle = kFillSolid;
147 valunterLabel.fFont = ufont->GetFontHandle();
148 valunterLabel.fGraphicsExposures = kFALSE;
149 uGC = gClient->GetGC(&valunterLabel, kTRUE);
152 TGLabel *EventCounterLabel =
new TGLabel(
fEventBox1,
"Event Counter",uGC->GetGC(),ufont->GetFontStruct(),kSunkenFrame,ucolor);
153 EventCounterLabel->SetTextJustify(36);
154 EventCounterLabel->SetMargins(0,0,0,0);
155 EventCounterLabel->SetWrapLength(-1);
156 fEventBox1->AddFrame(EventCounterLabel,
new TGLayoutHints(kLHintsLeft | kLHintsTop,2,2,2,2));
157 EventCounterLabel->MoveResize(45,6,125,20);
158 EventCounterLabel->SetBackgroundColor(ucolor);
161 gClient->GetColorByName(
"#507ba7", ucolor);
166 ufont = gClient->GetFont(
"-*-courier-bold-r-*-*-12-*-*-*-*-*-*-*");
167 GCValues_t valentHit;
168 valentHit.fMask = kGCForeground | kGCBackground | kGCFillStyle | kGCFont | kGCGraphicsExposures;
169 gClient->GetColorByName(
"#000000",valentHit.fForeground);
170 gClient->GetColorByName(
"#c0c0c0",valentHit.fBackground);
171 valentHit.fFillStyle = kFillSolid;
172 valentHit.fFont = ufont->GetFontHandle();
173 valentHit.fGraphicsExposures = kFALSE;
174 uGC = gClient->GetGC(&valentHit, kTRUE);
181 ufont = gClient->GetFont(
"-*-charter-bold-r-*-*-33-*-*-*-*-*-*-*");
182 GCValues_t valntHitLabel;
183 valntHitLabel.fMask = kGCForeground | kGCBackground | kGCFillStyle | kGCFont | kGCGraphicsExposures;
184 gClient->GetColorByName(
"#000000",valntHitLabel.fForeground);
185 gClient->GetColorByName(
"#c0c0c0",valntHitLabel.fBackground);
186 valntHitLabel.fFillStyle = kFillSolid;
187 valntHitLabel.fFont = ufont->GetFontHandle();
188 valntHitLabel.fGraphicsExposures = kFALSE;
189 uGC = gClient->GetGC(&valntHitLabel, kTRUE);
190 gClient->GetColorByName(
"#fff897",ucolor);
209 ufont = gClient->GetFont(
"-*-helvetica-bold-r-*-*-11-*-*-*-*-*-*-*");
210 GCValues_t valitButton;
211 valitButton.fMask = kGCForeground | kGCBackground | kGCFillStyle | kGCFont | kGCGraphicsExposures;
212 gClient->GetColorByName(
"#000000",valitButton.fForeground);
213 gClient->GetColorByName(
"#c0c0c0",valitButton.fBackground);
214 valitButton.fFillStyle = kFillSolid;
215 valitButton.fFont = ufont->GetFontHandle();
216 valitButton.fGraphicsExposures = kFALSE;
217 uGC = gClient->GetGC(&valitButton, kTRUE);
220 gClient->GetColorByName(
"#d4cf87",ucolor);
221 TGTextButton *GotoEventButton =
new TGTextButton(
fEventCounter,
"&Goto Event",-1,uGC->GetGC(),ufont->GetFontStruct());
222 GotoEventButton->Connect(
"Clicked()",
"QwEventDisplay",
this,
"GotoEvent()");
223 GotoEventButton->SetTextJustify(36);
224 GotoEventButton->SetMargins(0,0,0,0);
225 GotoEventButton->SetWrapLength(-1);
226 GotoEventButton->Resize(67,24);
227 GotoEventButton->ChangeBackground(ucolor);
230 fEventCounter->AddFrame(GotoEventButton,
new TGLayoutHints(kLHintsLeft | kLHintsTop,2,2,2,2));
231 GotoEventButton->MoveResize(64,133,67,24);
249 gClient->GetColorByName(
"#d4cf87",ucolor);
258 ufont = gClient->GetFont(
"-*-charter-bold-r-*-*-15-*-*-*-*-*-*-*");
261 GCValues_t valitsLabel;
262 valitsLabel.fMask = kGCForeground | kGCBackground | kGCFillStyle | kGCFont | kGCGraphicsExposures;
263 gClient->GetColorByName(
"#000000",valitsLabel.fForeground);
264 gClient->GetColorByName(
"#c0c0c0",valitsLabel.fBackground);
265 valitsLabel.fFillStyle = kFillSolid;
266 valitsLabel.fFont = ufont->GetFontHandle();
267 valitsLabel.fGraphicsExposures = kFALSE;
268 uGC = gClient->GetGC(&valitsLabel, kTRUE);
269 gClient->GetColorByName(
"#deba87", ucolor);
272 TGLabel *fWireInfoLabel =
new TGLabel(
fEventBox2,
"Wire Hit Information",uGC->GetGC(),ufont->GetFontStruct(),kSunkenFrame,ucolor);
273 fWireInfoLabel->SetTextJustify(36);
274 fWireInfoLabel->SetMargins(0,0,0,0);
275 fWireInfoLabel->SetWrapLength(-1);
276 fWireInfoLabel->MoveResize(129,6,196,20);
277 fWireInfoLabel->SetBackgroundColor(ucolor);
278 fEventBox2->AddFrame(fWireInfoLabel,
new TGLayoutHints(kLHintsLeft | kLHintsTop,2,2,2,2));
287 gClient->GetColorByName(
"#d4cf87",ucolor);
292 ufont = gClient->GetFont(
"-*-charter-bold-r-*-*-15-*-*-*-*-*-*-*");
293 GCValues_t valInfoLabel;
294 valInfoLabel.fMask = kGCForeground | kGCBackground | kGCFillStyle | kGCFont | kGCGraphicsExposures;
295 gClient->GetColorByName(
"#000000",valInfoLabel.fForeground);
296 gClient->GetColorByName(
"#c0c0c0",valInfoLabel.fBackground);
297 valInfoLabel.fFillStyle = kFillSolid;
298 valInfoLabel.fFont = ufont->GetFontHandle();
299 valInfoLabel.fGraphicsExposures = kFALSE;
300 uGC = gClient->GetGC(&valInfoLabel, kTRUE);
301 gClient->GetColorByName(
"#deba87", ucolor);
304 TGLabel *fOctantLabel =
new TGLabel(
fEventBox3,
"Octant Identification",uGC->GetGC(),ufont->GetFontStruct(),kSunkenFrame,ucolor);
305 fOctantLabel->SetTextJustify(36);
306 fOctantLabel->SetMargins(0,0,0,0);
307 fOctantLabel->SetWrapLength(-1);
308 fOctantLabel->MoveResize(25,6,175,20);
309 fOctantLabel->SetBackgroundColor(ucolor);
310 fEventBox3->AddFrame(fOctantLabel,
new TGLayoutHints(kLHintsLeft | kLHintsTop,2,2,2,2));
314 Int_t wOctantID =
fOctantID->GetCanvasWindowId();
315 cOctantID =
new TCanvas(
"cOctantID", 10, 10, wOctantID);
319 fOctantID->GetCanvas()->SetFillColor(kAzure-7);
320 Octant_1 =
new TPaveLabel(.4,.75,.6,.95,
"3");
324 Octant_2 =
new TPaveLabel(.675,.675,.875,.875,
"4");
328 Octant_3 =
new TPaveLabel(.75,.4,.95,.6,
"5");
332 Octant_4 =
new TPaveLabel(.675,.125,.875,.325,
"6");
336 Octant_5 =
new TPaveLabel(.4,.05,.6,.25,
"7");
340 Octant_6 =
new TPaveLabel(.125,.125,.325,.325,
"8");
344 Octant_7 =
new TPaveLabel(.05,.4,.25,.6,
"1");
348 Octant_8 =
new TPaveLabel(.125,.675,.325,.875,
"2");
352 fOctantID->GetCanvas()->SetEditable(kFALSE);
359 fMain->AddFrame(
fEventBoxes,
new TGLayoutHints(kLHintsLeft | kLHintsTop,2,2,2,2));
366 ufont = gClient->GetFont(
"-*-charter-bold-r-*-*-15-*-*-*-*-*-*-*");
368 valTabs.fMask = kGCForeground | kGCBackground | kGCFillStyle | kGCFont | kGCGraphicsExposures;
369 gClient->GetColorByName(
"#000000",valTabs.fForeground);
370 gClient->GetColorByName(
"#c0c0c0",valTabs.fBackground);
371 valTabs.fFillStyle = kFillSolid;
372 valTabs.fFont = ufont->GetFontHandle();
373 valTabs.fGraphicsExposures = kFALSE;
374 uGC = gClient->GetGC(&valTabs, kTRUE);
375 gClient->GetColorByName(
"#0047ab",ucolor);
378 fRegions =
new TGTab(
fMain,900,312,uGC->GetGC(),ufont->GetFontStruct(),kChildFrame,ucolor);
379 gClient->GetColorByName(
"#d4cf87",ucolor);
387 fRegion1->SetBackgroundColor(ucolor);
391 Int_t wRegion1XY =
fRegion1XY->GetCanvasWindowId();
392 cR1XY =
new TCanvas(
"cR1XY", 10, 10, wRegion1XY);
397 Label_R1XY =
new TPaveLabel(.03,.94,.97,.99,
"Front View (X-Y Projection)");
407 Int_t wRegion1YZ =
fRegion1YZ->GetCanvasWindowId();
408 cR1YZ =
new TCanvas(
"cR1YZ", 10, 10, wRegion1YZ);
413 Label_R1YZ =
new TPaveLabel(.03,.94,.97,.99,
"Top View (Y-Z Projection)");
423 Int_t wRegion1XZ =
fRegion1XZ->GetCanvasWindowId();
424 cR1XZ =
new TCanvas(
"cR1XZ", 10, 10, wRegion1XZ);
429 Label_R1XZ =
new TPaveLabel(.03,.94,.97,.99,
"Side View (X-Z Projection)");
443 fRegion2->SetBackgroundColor(ucolor);
447 Int_t wRegion2XY =
fRegion2XY->GetCanvasWindowId();
448 cR2XY =
new TCanvas(
"cR2XY", 10, 10, wRegion2XY);
453 Label_R2XY =
new TPaveLabel(.03,.94,.97,.99,
"Front View (X-Y Projection)");
463 Int_t wRegion2YZ =
fRegion2YZ->GetCanvasWindowId();
464 cR2YZ =
new TCanvas(
"cR2YZ", 10, 10, wRegion2YZ);
469 Label_R2YZ =
new TPaveLabel(.03,.94,.97,.99,
"Top View (Y-Z Projection)");
487 tR2XY1 =
new TText(.03, .03,
"Cham. 1");
490 tR2XY2 =
new TText(.29, .03,
"Cham. 2");
493 tR2XY3 =
new TText(.55, .03,
"Cham. 3");
496 tR2XY4 =
new TText(.81, .03,
"Cham. 4");
503 Int_t wRegion2XZ =
fRegion2XZ->GetCanvasWindowId();
504 cR2XZ =
new TCanvas(
"cR2XZ",10, 10, wRegion2XZ);
509 Label_R2XZ =
new TPaveLabel(.03,.94,.97,.99,
"Side View (X-Z Projection)");
527 tR2XZ1 =
new TText(.03, .03,
"Cham. 1");
530 tR2XZ2 =
new TText(.29, .03,
"Cham. 2");
533 tR2XZ3 =
new TText(.55, .03,
"Cham. 3");
536 tR2XZ4 =
new TText(.81, .03,
"Cham. 4");
551 Int_t wRegion2bXY =
fRegion2bXY->GetCanvasWindowId();
552 cR2bXY =
new TCanvas(
"cR2bXY", 10, 10, wRegion2bXY);
557 Label_R2bXY =
new TPaveLabel(.03,.94,.97,.99,
"Front View (X-Y Projection)");
567 Int_t wRegion2bYZ =
fRegion2bYZ->GetCanvasWindowId();
568 cR2bYZ =
new TCanvas(
"cR2bYZ", 10, 10, wRegion2bYZ);
573 Label_R2bYZ =
new TPaveLabel(.03,.94,.97,.99,
"Top View (Y-Z Projection)");
591 tR2bXY1 =
new TText(.03, .03,
"Cham. 5");
594 tR2bXY2 =
new TText(.29, .03,
"Cham. 6");
597 tR2bXY3 =
new TText(.55, .03,
"Cham. 7");
600 tR2bXY4 =
new TText(.81, .03,
"Cham. 8");
607 Int_t wRegion2bXZ =
fRegion2bXZ->GetCanvasWindowId();
608 cR2bXZ =
new TCanvas(
"cR2bXZ",10, 10, wRegion2bXZ);
613 Label_R2bXZ =
new TPaveLabel(.03,.94,.97,.99,
"Side View (X-Z Projection)");
631 tR2bXZ1 =
new TText(.03, .03,
"Cham. 5");
634 tR2bXZ2 =
new TText(.29, .03,
"Cham. 6");
637 tR2bXZ3 =
new TText(.55, .03,
"Cham. 7");
640 tR2bXZ4 =
new TText(.81, .03,
"Cham. 8");
651 fRegion3->SetBackgroundColor(ucolor);
655 Int_t wRegion3XY =
fRegion3XY->GetCanvasWindowId();
656 cR3XY =
new TCanvas(
"cR3XY", 10, 10, wRegion3XY);
661 Label_R3XY =
new TPaveLabel(.03,.94,.97,.99,
"Front View (Normal to Tilt Angle)");
679 tR3XY1 =
new TText(.03, .03,
"Leia (1)");
682 tR3XY2 =
new TText(.28, .03,
"Vader (2)");
685 tR3XY3 =
new TText(.55, .03,
"Han (3)");
688 tR3XY4 =
new TText(.81, .03,
"Yoda (4)");
698 Int_t wRegion3YZ =
fRegion3YZ->GetCanvasWindowId();
699 cR3YZ =
new TCanvas(
"cR3YZ", 10, 10, wRegion3YZ);
704 Label_R3YZ =
new TPaveLabel(.03,.94,.97,.99,
"Top View (Oriented to Tilt Angle)");
722 tR3YZ1 =
new TText(.03, .03,
"Leia (1)");
725 tR3YZ2 =
new TText(.28, .03,
"Vader (2)");
728 tR3YZ3 =
new TText(.55, .03,
"Han (3)");
731 tR3YZ4 =
new TText(.81, .03,
"Yoda (4)");
741 Int_t wRegion3XZ =
fRegion3XZ->GetCanvasWindowId();
742 cR3XZ =
new TCanvas(
"cR3XZ", 10, 10, wRegion3XZ);
747 Label_R3XZ =
new TPaveLabel(.03,.94,.97,.99,
"Side View (Rotated to Tilt Angle)");
765 tR3XZ1 =
new TText(.03, .03,
"Leia (1)");
768 tR3XZ2 =
new TText(.28, .03,
"Vader (2)");
771 tR3XZ3 =
new TText(.55, .03,
"Han (3)");
774 tR3XZ4 =
new TText(.81, .03,
"Yoda (4)");
793 fMain->AddFrame(
fRegions,
new TGLayoutHints(kLHintsLeft | kLHintsTop,2,2,2,2));
794 fRegions->MoveResize(0,340,900,332);
795 gClient->GetColorByName(
"#deba87", ucolor);
796 fRegions->GetTabTab(
"Region 1--GEM")->SetBackgroundColor(ucolor);
797 fRegions->GetTabTab(
"Region 2--HDC (1-4)")->SetBackgroundColor(ucolor);
798 fRegions->GetTabTab(
"Region 2--HDC (5-8)")->SetBackgroundColor(ucolor);
799 fRegions->GetTabTab(
"Region 3--VDC")->SetBackgroundColor(ucolor);
800 fRegions->GetTabTab(
"Region 3--TS")->SetBackgroundColor(ucolor);
806 gClient->GetColorByName(
"#0047ab",ucolor);
807 TGHorizontalFrame *fButtons =
new TGHorizontalFrame(
fMain,900,60,kHorizontalFrame,ucolor);
808 fButtons->SetLayoutBroken(kTRUE);
809 ufont = gClient->GetFont(
"-*-helvetica-bold-r-*-*-12-*-*-*-*-*-*-*");
810 gClient->GetColorByName(
"#d4cf87",ucolor);
814 valutton.fMask = kGCForeground | kGCBackground | kGCFillStyle | kGCFont | kGCGraphicsExposures;
815 gClient->GetColorByName(
"#000000",valutton.fForeground);
816 gClient->GetColorByName(
"#c0c0c0",valutton.fBackground);
817 valutton.fFillStyle = kFillSolid;
818 valutton.fFont = ufont->GetFontHandle();
819 valutton.fGraphicsExposures = kFALSE;
820 uGC = gClient->GetGC(&valutton, kTRUE);
822 ExitButton =
new TGTextButton(fButtons,
"E&xit",
"gApplication->Terminate(0)");
830 fButtons->AddFrame(
ExitButton,
new TGLayoutHints(kLHintsLeft | kLHintsTop,2,2,2,2));
834 GCValues_t valousButton;
835 valousButton.fMask = kGCForeground | kGCBackground | kGCFillStyle | kGCFont | kGCGraphicsExposures;
836 gClient->GetColorByName(
"#000000",valousButton.fForeground);
837 gClient->GetColorByName(
"#c0c0c0",valousButton.fBackground);
838 valousButton.fFillStyle = kFillSolid;
839 valousButton.fFont = ufont->GetFontHandle();
840 valousButton.fGraphicsExposures = kFALSE;
841 uGC = gClient->GetGC(&valousButton, kTRUE);
843 TGTextButton *PreviousButton =
new TGTextButton(fButtons,
"&Previous Event",-1,uGC->GetGC(),ufont->GetFontStruct());
844 PreviousButton->Connect(
"Clicked()",
"QwEventDisplay",
this,
"GoPrevious()");
845 PreviousButton->SetTextJustify(36);
846 PreviousButton->SetMargins(0,0,0,0);
847 PreviousButton->SetWrapLength(-1);
848 PreviousButton->Resize(100,50);
849 PreviousButton->ChangeBackground(ucolor);
851 fButtons->AddFrame(PreviousButton,
new TGLayoutHints(kLHintsLeft | kLHintsTop,2,2,2,2));
852 PreviousButton->MoveResize(12,6,100,50);
856 valutton.fMask = kGCForeground | kGCBackground | kGCFillStyle | kGCFont | kGCGraphicsExposures;
857 gClient->GetColorByName(
"#000000",valutton.fForeground);
858 gClient->GetColorByName(
"#c0c0c0",valutton.fBackground);
859 valutton.fFillStyle = kFillSolid;
860 valutton.fFont = ufont->GetFontHandle();
861 valutton.fGraphicsExposures = kFALSE;
862 uGC = gClient->GetGC(&valutton, kTRUE);
864 TGTextButton *NextButton =
new TGTextButton(fButtons,
"&Next Event",-1,uGC->GetGC(),ufont->GetFontStruct());
865 NextButton->Connect(
"Clicked()",
"QwEventDisplay",
this,
"GoNext()");
866 NextButton->SetTextJustify(36);
867 NextButton->SetMargins(0,0,0,0);
868 NextButton->SetWrapLength(-1);
869 NextButton->Resize(100,50);
870 NextButton->ChangeBackground(ucolor);
872 fButtons->AddFrame(NextButton,
new TGLayoutHints(kLHintsNormal));
873 NextButton->MoveResize(125,6,100,50);
876 fMain->AddFrame(fButtons,
new TGLayoutHints(kLHintsLeft | kLHintsTop,2,2,2,2));
877 fButtons->MoveResize(0,652,900,80);
883 TRootEmbeddedCanvas *fKey =
new TRootEmbeddedCanvas(0,fButtons,280,280);
884 Int_t wKey = fKey->GetCanvasWindowId();
885 TCanvas *cKey =
new TCanvas(
"cKey", 10, 10, wKey);
886 fKey->AdoptCanvas(cKey);
887 fButtons->AddFrame(fKey,
new TGLayoutHints(kLHintsLeft | kLHintsTop,2,2,2,2));
888 fKey->MoveResize(245,6,515,50);
890 fKey->GetCanvas()->cd();
891 fKey->GetCanvas()->SetFillColor(0);
892 TPaveLabel *Label_KeyX =
new TPaveLabel(.01,.05,.24,.95,
" X");
893 Label_KeyX->SetTextAlign(12);
894 Label_KeyX->SetTextColor(
kRed);
895 Label_KeyX->SetShadowColor(0);
897 TLine *Line_KeyX =
new TLine(.1,.5,.2,.5);
898 Line_KeyX->SetLineColor(
kRed);
900 TPaveLabel *Label_KeyY =
new TPaveLabel(.25,.05,.49,.95,
" Y");
901 Label_KeyY->SetTextAlign(12);
902 Label_KeyY->SetTextColor(kViolet);
903 Label_KeyY->SetShadowColor(0);
905 TLine *Line_KeyY =
new TLine(.4,.1,.4,.9);
906 Line_KeyY->SetLineColor(kViolet);
908 TPaveLabel *Label_KeyU =
new TPaveLabel(.5,.05,.74,.95,
" U");
909 Label_KeyU->SetTextAlign(12);
910 Label_KeyU->SetTextColor(
kGreen);
911 Label_KeyU->SetShadowColor(0);
913 TLine *Line_KeyU =
new TLine(.59,.1,.7,.9);
914 Line_KeyU->SetLineColor(
kGreen);
916 TPaveLabel *Label_KeyV =
new TPaveLabel(.75,.05,.99,.95,
" V");
917 Label_KeyV->SetTextAlign(12);
918 Label_KeyV->SetTextColor(
kBlue);
919 Label_KeyV->SetShadowColor(0);
921 TLine *Line_KeyV =
new TLine(.84,.9,.95,.1);
922 Line_KeyV->SetLineColor(
kBlue);
924 fKey->GetCanvas()->SetEditable(kFALSE);
925 fKey->GetCanvas()->Update();
928 fMain->SetMWMHints(kMWMDecorAll,kMWMFuncAll,kMWMInputModeless);
929 fMain->MapSubwindows();
932 fMain->Resize(900,712);
943 printf(
"\nCannot open file. This feature is currently non-functional. Use the Q-weak Data Analysis GUI to control files or re-open the display with a different run file.\n");
948 printf(
"\nCannot close file. This feature is currently non-functional. Use the Q-weak Data Analysis GUI to control files or re-open the display with a different run file.\n");
953 printf(
"\nTutorial documentation is located at https://qweak.jlab.org/wiki/index.php/Track_Reconstruction.\n");
956 printf(
"\n**************************************\n** Qweak 2D Event Display **\n** Jefferson Lab -- Hall C **\n** Author: Derek Jones **\n** The George Washington University **\n** Contact: dwjones8@gwu.edu **\n** Last updated: 7-26-2010 **\n**************************************\n");
964 if (fEventNumber > 1){
1024 if (fEventNumber > 0){
1043 printf(
"Drawing event %d...\n", fEventNumber);
1056 fOctantID->GetCanvas()->SetEditable(kTRUE);
1087 fOctantID->GetCanvas()->SetEditable(kFALSE);
1095 printf(
"Printing hit list...");
1099 char fHitBuffer[30];
1102 for(QwHitContainer::iterator fHit =
fHitList->begin(); fHit !=
fHitList->end(); fHit++){
1103 if(fHit->GetElement() > 0){
1104 if (fHit->GetRegion() == 1){
1105 sprintf(fHitBuffer,
"Region %i: Trace %i, Plane %i", fHit->GetRegion(), fHit->GetElement(), fHit->GetPlane());
1107 else if (fHit->GetRegion() == 2){
1108 sprintf(fHitBuffer,
"Region %i: Wire %i, Plane %i Drift Distance: %f", fHit->GetRegion(), fHit->GetElement(), fHit->GetPlane(), fHit->GetDriftDistance());
1110 else if (fHit->GetRegion() == 3){
1111 sprintf(fHitBuffer,
"Region %i: Wire %i, Plane %i Drift Distance: %f", fHit->GetRegion(), fHit->GetElement(), fHit->GetPlane(), fHit->GetDriftDistance());
1146 for(QwHitContainer::iterator fHit = Hits_R1r->begin(); fHit != Hits_R1r->end(); fHit++){
1148 int fTrace = fHit->GetElement();
1153 Line.SetLineColor(kViolet);
1158 for(QwHitContainer::iterator fHit = Hits_R1y->begin(); fHit != Hits_R1y->end(); fHit++){
1160 int fTrace = fHit->GetElement();
1163 Line.SetY2(.5 + (
R1_WIDTH*R1_CM*.5));
1165 Line.SetLineColor(kViolet);
1169 fRegion1XY->GetCanvas()->SetEditable(kFALSE);
1176 for(QwHitContainer::iterator fHit = Hits_R1y->begin(); fHit != Hits_R1y->end(); fHit++){
1178 int fTrace = fHit->GetElement();
1181 Line.SetY2(.5 + (
R1_DEPTH*R1_CM*.5));
1183 Line.SetLineColor(kViolet);
1187 fRegion1YZ->GetCanvas()->SetEditable(kFALSE);
1194 for(QwHitContainer::iterator fHit = Hits_R1y->begin(); fHit != Hits_R1y->end(); fHit++){
1200 Line.SetLineColor(kViolet);
1201 Line.SetLineWidth(22);
1205 fRegion1XZ->GetCanvas()->SetEditable(kFALSE);
1213 for(QwHitContainer::iterator fHit = Hits_R2x->begin(); fHit != Hits_R2x->end(); fHit++){
1215 int fWire = fHit->GetElement();
1216 int fPlane = fHit->GetPlane();
1238 Line.SetX2(.5 + (
R2_WIDTH*R2_CM*.5));
1240 Line.SetLineColor(
kRed);
1245 for(QwHitContainer::iterator fHit = Hits_R2u->begin(); fHit != Hits_R2u->end(); fHit++){
1247 int fWire = fHit->GetElement();
1248 int fPlane = fHit->GetPlane();
1274 Line.SetX2(.5 + (
R2_WIDTH*R2_CM*.5));
1275 Line.SetY2(.5 - (
R2_LENGTH*R2_CM*.5) + (((
R2_UVDIST*R2_CM*(fWire - fShiftTrim)) + fPShift)*tan(
R2_ANGLE*TMath::DegToRad())));
1289 Line.SetLineColor(
kGreen);
1294 for(QwHitContainer::iterator fHit = Hits_R2v->begin(); fHit != Hits_R2v->end(); fHit++){
1296 int fWire = fHit->GetElement();
1297 int fPlane = fHit->GetPlane();
1323 Line.SetX2(.5 + (
R2_WIDTH*R2_CM*.5));
1324 Line.SetY2(.5 + (
R2_LENGTH*R2_CM*.5) - (((
R2_UVDIST*R2_CM*(fWire - fShiftTrim)) + fPShift)*tan(
R2_ANGLE*TMath::DegToRad())));
1338 Line.SetLineColor(
kBlue);
1342 fRegion2XY->GetCanvas()->SetEditable(kFALSE);
1350 for(QwHitContainer::iterator fHit = Hits_R2x->begin(); fHit != Hits_R2x->end(); fHit++){
1352 int fPlane = fHit->GetPlane();
1392 Line.SetX2(.5 + (
R2_WIDTH*R2_CM*.5));
1394 Line.SetLineColor(
kRed);
1395 Line.SetLineWidth(2);
1400 for(QwHitContainer::iterator fHit = Hits_R2u->begin(); fHit != Hits_R2u->end(); fHit++){
1402 int fWire = fHit->GetElement();
1403 int fPlane = fHit->GetPlane();
1447 Line.SetX2(.5 + (
R2_WIDTH*R2_CM*.5));
1462 Line.SetLineColor(
kGreen);
1463 Line.SetLineWidth(2);
1468 for(QwHitContainer::iterator fHit = Hits_R2v->begin(); fHit != Hits_R2v->end(); fHit++){
1470 int fWire = fHit->GetElement();
1471 int fPlane = fHit->GetPlane();
1515 Line.SetX2(.5 + (
R2_WIDTH*R2_CM*.5));
1530 Line.SetLineColor(
kBlue);
1531 Line.SetLineWidth(2);
1535 fRegion2YZ->GetCanvas()->SetEditable(kFALSE);
1543 for(QwHitContainer::iterator fHit = Hits_R2x->begin(); fHit != Hits_R2x->end(); fHit++){
1545 int fWire = fHit->GetElement();
1546 int fPlane = fHit->GetPlane();
1591 Line.SetLineColor(
kRed);
1596 for(QwHitContainer::iterator fHit = Hits_R2u->begin(); fHit != Hits_R2u->end(); fHit++){
1598 int fWire = fHit->GetElement();
1599 int fPlane = fHit->GetPlane();
1658 Line.SetLineColor(
kGreen);
1659 Line.SetLineWidth(2);
1664 for(QwHitContainer::iterator fHit = Hits_R2v->begin(); fHit != Hits_R2v->end(); fHit++){
1666 int fWire = fHit->GetElement();
1667 int fPlane = fHit->GetPlane();
1726 Line.SetLineColor(
kBlue);
1727 Line.SetLineWidth(2);
1731 fRegion2XZ->GetCanvas()->SetEditable(kFALSE);
1741 for(QwHitContainer::iterator fHit = Hits_R3u->begin(); fHit != Hits_R3u->end(); fHit++){
1743 int fWire = fHit->GetElement();
1744 int fPlane = fHit->GetPlane();
1766 Line.SetY1(fYShift - (
R3_LENGTH*R3_CM*.5));
1767 Line.SetX2(.5 + (
R3_WIDTH*R3_CM*.5));
1772 Line.SetY1(fYShift - (
R3_LENGTH*R3_CM*.5));
1774 Line.SetY2(fYShift + (
R3_LENGTH*R3_CM*.5));
1780 Line.SetY2(fYShift + (
R3_LENGTH*R3_CM*.5));
1782 Line.SetLineColor(
kGreen);
1787 for(QwHitContainer::iterator fHit = Hits_R3v->begin(); fHit != Hits_R3v->end(); fHit++){
1789 int fWire = fHit->GetElement();
1790 int fPlane = fHit->GetPlane();
1812 Line.SetY1(fYShift + (
R3_LENGTH*R3_CM*.5));
1813 Line.SetX2(.5 + (
R3_WIDTH*R3_CM*.5));
1818 Line.SetY1(fYShift + (
R3_LENGTH*R3_CM*.5));
1820 Line.SetY2(fYShift - (
R3_LENGTH*R3_CM*.5));
1826 Line.SetY2(fYShift - (
R3_LENGTH*R3_CM*.5));
1828 Line.SetLineColor(
kBlue);
1832 fRegion3XY->GetCanvas()->SetEditable(kFALSE);
1838 for(QwHitContainer::iterator fHit = Hits_R3u->begin(); fHit != Hits_R3u->end(); fHit++){
1840 int fWire = fHit->GetElement();
1841 int fPlane = fHit->GetPlane();
1863 Line.SetY1(fYShift);
1864 Line.SetX2(.5 + (
R3_WIDTH*R3_CM*.5));
1865 Line.SetY2(fYShift);
1869 Line.SetY1(fYShift);
1871 Line.SetY2(fYShift);
1875 Line.SetY1(fYShift);
1877 Line.SetY2(fYShift);
1879 Line.SetLineColor(
kGreen);
1880 Line.SetLineWidth(3);
1885 for(QwHitContainer::iterator fHit = Hits_R3v->begin(); fHit != Hits_R3v->end(); fHit++){
1887 int fWire = fHit->GetElement();
1888 int fPlane = fHit->GetPlane();
1910 Line.SetY1(fYShift);
1911 Line.SetX2(.5 + (
R3_WIDTH*R3_CM*.5));
1912 Line.SetY2(fYShift);
1916 Line.SetY1(fYShift);
1918 Line.SetY2(fYShift);
1922 Line.SetY1(fYShift);
1924 Line.SetY2(fYShift);
1926 Line.SetLineColor(
kBlue);
1927 Line.SetLineWidth(3);
1931 fRegion3YZ->GetCanvas()->SetEditable(kFALSE);
1937 for(QwHitContainer::iterator fHit = Hits_R3u->begin(); fHit != Hits_R3u->end(); fHit++){
1939 int fWire = fHit->GetElement();
1940 int fPlane = fHit->GetPlane();
1966 Line.SetX1(fXShift);
1968 Line.SetX2(fXShift);
1972 Line.SetX1(fXShift);
1974 Line.SetX2(fXShift);
1975 Line.SetY2(fYShift + (
R3_LENGTH*R3_CM*.5));
1978 Line.SetX1(fXShift);
1980 Line.SetX2(fXShift);
1981 Line.SetY2(fYShift + (
R3_LENGTH*R3_CM*.5));
1983 Line.SetLineColor(
kGreen);
1984 Line.SetLineWidth(3);
1989 for(QwHitContainer::iterator fHit = Hits_R3v->begin(); fHit != Hits_R3v->end(); fHit++){
1991 int fWire = fHit->GetElement();
1992 int fPlane = fHit->GetPlane();
2018 Line.SetX1(fXShift);
2020 Line.SetX2(fXShift);
2024 Line.SetX1(fXShift);
2026 Line.SetX2(fXShift);
2027 Line.SetY2(fYShift - (
R3_LENGTH*R3_CM*.5));
2030 Line.SetX1(fXShift);
2032 Line.SetX2(fXShift);
2033 Line.SetY2(fYShift - (
R3_LENGTH*R3_CM*.5));
2035 Line.SetLineColor(
kBlue);
2036 Line.SetLineWidth(3);
2040 fRegion3XZ->GetCanvas()->SetEditable(kFALSE);
TRootEmbeddedCanvas * fRegion3XZ
TRootEmbeddedCanvas * fRegion3XY
TRootEmbeddedCanvas * fRegion3YZ
TGGroupFrame * fCurrentEvent
TGHorizontalFrame * fEventBoxes
QwSubsystemArrayTracking * fSubsystemArray
// Excluded from dictionary
TGCompositeFrame * fRegion3TS
TGCompositeFrame * fRegion2b
TRootEmbeddedCanvas * fRegion1XZ
const TString getenv_safe_TString(const char *name)
std::vector< TLine > Line_R2x
QwHitContainer * fHitList
TGNumberEntry * fCurrentEventEntry
QwHitContainer * GetHitContainer() const
Get the hit list.
QwTreeEventBuffer * fEventBuffer
TGLayoutHints * fMenuBarHelpLayout
std::vector< TLine > Line_R3v
TGVerticalFrame * fEventBox3
TRootEmbeddedCanvas * fRegion1XY
TGCompositeFrame * fRegion2
TGVerticalFrame * fEventBox2
TRootEmbeddedCanvas * fRegion2XY
TGCompositeFrame * fRegion1
std::vector< TLine > Line_R1y
TGTextButton * ExitButton
QwEventDisplay(const TGWindow *p, UInt_t w, UInt_t h)
TGLabel * fCurrentEventLabel
unsigned int GetSpecificEvent(const int eventnumber)
Read the specified event.
TGLayoutHints * fMenuBarLayout
TRootEmbeddedCanvas * fRegion2bXZ
std::vector< TLine > Line_R1r
TRootEmbeddedCanvas * fRegion2YZ
TGListBox * fWireInfoListBox
TGCompositeFrame * fRegion3
TRootEmbeddedCanvas * fRegion2bYZ
void HandleMenu(Int_t id)
void GetSubList_Dir(EQwRegionID region, EQwDetectorPackage package, EQwDirectionID direction, std::vector< QwHit > &sublist)
void Print(const Option_t *option=0) const
virtual ~QwEventDisplay()
TRootEmbeddedCanvas * fRegion2bXY
std::vector< TLine > Line_R3u
TRootEmbeddedCanvas * fOctantID
TGVerticalFrame * fEventCounter
std::vector< TLine > Line_R2v
TRootEmbeddedCanvas * fRegion1YZ
TRootEmbeddedCanvas * fRegion2XZ
std::vector< TLine > Line_R2u
TGVerticalFrame * fEventBox1
TGLayoutHints * fMenuBarItemLayout