13 #include "TGNumberEntry.h" 14 #include "TGTextView.h" 17 #include "TRootEmbeddedCanvas.h" 19 #include "TVirtualX.h" 68 fMC =
new MCBriefPad(
"fMCPadMultiTPC",
"MC Info.", 0.15, 0.13, 1.0, 0.17,
"");
72 fWireQ =
new TQPad(
"fWireQPadMultiTPC",
"ADCvsTime", 0.15, 0.0, 1.0, 0.13,
"TQ", 0, 0);
73 fWireQ->
Pad()->SetBit(TPad::kCannotMove,
true);
77 fMetaFrame =
new TGCompositeFrame(mf, 60, 60, kHorizontalFrame);
84 new TGLayoutHints(kLHintsTop | kLHintsLeft | kLHintsExpandX | kLHintsExpandY, 5, 5, 5, 5);
91 fMetaFrame->AddFrame(
fVFrame,
new TGLayoutHints(kLHintsTop | kLHintsLeft | kLHintsExpandY));
102 TGNumberFormat::kNESInteger,
103 TGNumberFormat::kNEAAnyNumber,
104 TGNumberFormat::kNELLimitMinMax,
106 wireReadoutGeom.Nplanes() - 1);
110 kWire = TMath::Nint(0.5 * wireReadoutGeom.Nwires(planeid));
120 fPlaneEntry->Connect(
"ValueSet(Long_t)",
"evd::TWQMultiTPCProjectionView",
this,
"SetPlane()");
122 "ReturnPressed()",
"evd::TWQMultiTPCProjectionView",
this,
"SetPlane()");
131 TGNumberFormat::kNESInteger,
132 TGNumberFormat::kNEAAnyNumber,
133 TGNumberFormat::kNELLimitMinMax,
135 wireReadoutGeom.Nwires(planeid) - 1);
142 fWireEntry->Connect(
"ValueSet(Long_t)",
"evd::TWQMultiTPCProjectionView",
this,
"SetWire()");
144 "ReturnPressed()",
"evd::TWQMultiTPCProjectionView",
this,
"SetWire()");
154 TGNumberFormat::kNESInteger,
155 TGNumberFormat::kNEAAnyNumber,
156 TGNumberFormat::kNELLimitMinMax,
158 wireReadoutGeom.Nwires(planeid) - 1);
171 "ValueSet(Long_t)",
"evd::TWQMultiTPCProjectionView",
this,
"SetThreshold()");
173 "ReturnPressed()",
"evd::TWQMultiTPCProjectionView",
this,
"SetThreshold()");
180 fGreyScale->Connect(
"Clicked()",
"evd::TWQMultiTPCProjectionView",
this,
"SetGreyscale()");
181 if (cst->fColorOrGray == 1)
fGreyScale->SetState(kButtonDown);
186 fMCOn->Connect(
"Clicked()",
"evd::TWQMultiTPCProjectionView",
this,
"SetMCInfo()");
194 fRawDraw->Connect(
"Clicked()",
"evd::TWQMultiTPCProjectionView",
this,
"SetRawCalib()");
195 fCalibDraw->Connect(
"Clicked()",
"evd::TWQMultiTPCProjectionView",
this,
"SetRawCalib()");
196 fRawCalibDraw->Connect(
"Clicked()",
"evd::TWQMultiTPCProjectionView",
this,
"SetRawCalib()");
208 fFrame->AddFrame(
fMCOn,
new TGLayoutHints(kLHintsBottom | kLHintsRight, 0, 0, 5, 1));
210 fFrame->AddFrame(
fGreyScale,
new TGLayoutHints(kLHintsBottom | kLHintsRight, 0, 0, 5, 1));
211 fFrame->AddFrame(
fRawCalibDraw,
new TGLayoutHints(kLHintsBottom | kLHintsRight, 0, 0, 5, 1));
212 fFrame->AddFrame(
fCalibDraw,
new TGLayoutHints(kLHintsBottom | kLHintsRight, 0, 0, 5, 1));
213 fFrame->AddFrame(
fRawDraw,
new TGLayoutHints(kLHintsBottom | kLHintsRight, 0, 0, 5, 1));
214 fFrame->AddFrame(
fPlaneEntry,
new TGLayoutHints(kLHintsBottom | kLHintsRight, 0, 0, 2, 1));
215 fFrame->AddFrame(
fPlaneLabel,
new TGLayoutHints(kLHintsBottom | kLHintsRight, 0, 0, 5, 1));
216 fFrame->AddFrame(
fWireEntry,
new TGLayoutHints(kLHintsBottom | kLHintsRight, 0, 0, 2, 1));
217 fFrame->AddFrame(
fWireLabel,
new TGLayoutHints(kLHintsBottom | kLHintsRight, 0, 0, 5, 1));
218 fFrame->AddFrame(
fThresEntry,
new TGLayoutHints(kLHintsBottom | kLHintsRight, 0, 0, 2, 1));
219 fFrame->AddFrame(
fThresLabel,
new TGLayoutHints(kLHintsBottom | kLHintsRight, 0, 0, 5, 1));
232 unsigned int ntpc = geo->
NTPC();
235 unsigned int nplanes = wireReadoutGeom.Nplanes();
239 for (
unsigned int t = 0; t < ntpc; ++t) {
240 for (
unsigned int i = 0; i < nplanes; ++i) {
241 double twx1 = 0. + t * 0.97 / (1. * ntpc);
242 double twx2 = t * 0.97 / (1. * ntpc);
244 double twy1 = 0.17 + (i) * (1.0 - 0.171) / (1. * nplanes);
245 double twy2 = 0.17 + (i + 1) * (1.0 - 0.171) / (1. * nplanes);
247 TString padname =
"fWireProjTPC";
252 TString padtitle =
"TPC";
261 new TWireProjPad(padname, padtitle, twx1, twy1, twx2, twy2, i + t * nplanes));
263 fPlanes.back()->Pad()->AddExec(
265 Form(
"evd::TWQMultiTPCProjectionView::MouseDispatch(%d, (void*)%lu)",
267 (
unsigned long)
this));
272 padname =
"fQPadTPC";
283 fPlaneQ.push_back(
new TQPad(padname, padtitle, twx2, twy1, twx3, twy2,
"Q", i, 0));
323 for (
unsigned int i = 0; i <
fPlanes.size(); ++i) {
340 for (
unsigned int i = 0; i <
fPlanes.size(); ++i) {
343 fPlanes[i]->Pad()->GetFrame()->SetBit(TPad::kCannotMove,
true);
345 for (
unsigned int j = 0; j <
fPlaneQ.size(); ++j) {
348 fPlaneQ[j]->Pad()->GetFrame()->SetBit(TPad::kCannotMove,
true);
370 curr_zooming_plane = -1;
373 for (
size_t i = 0; i <
fPlanes.size(); ++i) {
376 fPlanes[i]->Pad()->GetFrame()->SetBit(TPad::kCannotMove,
true);
378 std::vector<double> ZoomParams =
fPlanes[i]->GetCurrentZoom();
402 for (
size_t iplane = 0; iplane <
fPlanes.size(); ++iplane) {
404 double ch = 0, convch = 0;
406 fPlanes[iplane]->RawDataDraw()->GetChargeSum(iplane, ch, convch);
407 mf::LogVerbatim(
"TWQMultiTPCProjectionView") <<
"Warning! Calculating for RawData! ";
410 fPlanes[iplane]->RecoBaseDraw()->GetChargeSum(iplane, ch, convch);
414 <<
"\ncharge collected at collection plane: " << iplane <<
" " << ch <<
" " << convch;
424 int event = gPad->GetEvent();
435 if (shift_lock == 1)
break;
437 case kButton1Down: shift_lock = 0;
449 int event = gPad->GetEvent();
450 int px = gPad->GetEventX();
451 if (
event != 11)
return;
452 TObject* select = gPad->GetSelected();
454 if (!select->InheritsFrom(
"TBox"))
return;
457 float xx = gPad->AbsPixeltoX(px);
458 float x = gPad->PadtoX(xx);
461 kWire = (
unsigned int)TMath::Nint(x);
472 int event = gPad->GetEvent();
474 if (
event != 7)
return;
479 int px = gPad->GetEventX();
480 double w0 = gPad->AbsPixeltoX(px);
481 double x = gPad->PadtoX(w0);
483 int py = gPad->GetEventY();
484 double t0 = gPad->AbsPixeltoY(py);
485 double y = gPad->PadtoY(t0);
488 curr_zooming_plane = -1;
491 int repeat_plane = -1;
492 for (
size_t ii = 0; ii <
ppoints.size(); ++ii)
500 fPlanes[plane]->View()->AddMarker(0.0, 0.0, 2, 1, 0.1);
502 repeat_plane =
ppoints[ii].plane;
508 if (repeat_plane == -1) {
517 fPlanes[plane]->View()->Clear();
519 fPlanes[plane]->View()->AddMarker(ppx.
w, ppx.
t, kRed, 29, 2.0);
521 fPlanes[plane]->View()->AddMarker(0.0, 0.0, 2, 1, 0.1);
522 fPlanes[plane]->View()->Draw();
534 fPlanes[
x]->View()->AddMarker(0.0, 0.0, 2, 1, 0.1);
550 if (
pline.size() >= 2) {
552 double xyz_vertex_fit[3];
554 double xx0 = 0., yy0 = 0., zz0 = 0.;
555 double xx1 = 0., yy1 = 0., zz1 = 0.;
568 int chan1 = wireReadoutGeom.PlaneWireToChannel(
geo::WireID(plane_0,
pline[0].w0));
569 int chan2 = wireReadoutGeom.PlaneWireToChannel(
geo::WireID(plane_1,
pline[1].w0));
571 std::optional<geo::WireIDIntersection> wires_cross{};
572 bool time_good =
false;
575 wires_cross = wireReadoutGeom.ChannelsIntersect(chan1, chan2);
579 TGText*
tt =
new TGText(
"too big");
580 tt->InsLine(1,
"time distance");
587 TGText*
tt =
new TGText(
"wires cross");
590 xyz_vertex_fit[1] = wires_cross->y;
591 xyz_vertex_fit[2] = wires_cross->z;
592 auto pos = wireReadoutGeom.Plane(plane_0).GetBoxCenter();
593 xyz_vertex_fit[0] = (
pline[0].t0 -
trigger_offset(clockData)) * larv * ftimetick + pos.X();
594 pos = wireReadoutGeom.Plane(plane_1).GetBoxCenter();
597 xx0 = (xyz_vertex_fit[0] + second_time) / 2;
598 yy0 = wires_cross->y;
599 zz0 = wires_cross->z;
605 TGText*
tt =
new TGText(
"cross");
606 tt->InsLine(1,
"wires do not");
613 chan1 = wireReadoutGeom.PlaneWireToChannel(
geo::WireID(plane_0,
pline[0].w1));
614 chan2 = wireReadoutGeom.PlaneWireToChannel(
geo::WireID(plane_1,
pline[1].w1));
616 wires_cross = std::nullopt;
620 wires_cross = wireReadoutGeom.ChannelsIntersect(chan1, chan2);
624 TGText*
tt =
new TGText(
"too big");
625 tt->InsLine(1,
"time distance");
632 TGText*
tt =
new TGText(
"wires do cross");
635 xyz_vertex_fit[1] = wires_cross->y;
636 xyz_vertex_fit[2] = wires_cross->z;
638 auto pos = wireReadoutGeom.Plane(
geo::PlaneID(tpcid,
pline[0].plane)).GetBoxCenter();
639 xyz_vertex_fit[0] = (
pline[0].t1 -
trigger_offset(clockData)) * larv * ftimetick + pos.X();
643 xx1 = (xyz_vertex_fit[0] + second_time) / 2;
644 yy1 = wires_cross->y;
645 zz1 = wires_cross->z;
649 TGText*
tt =
new TGText(
"cross");
650 tt->InsLine(1,
"wires do not");
661 length = pow(xx0 - xx1, 2) + pow(yy0 - yy1, 2) + pow(zz0 - zz1, 2);
662 length = pow(length, 0.5);
667 TGText*
tt =
new TGText(
"selected points");
668 tt->InsLine(1,
"not enough");
681 std::cerr <<
"No event available\n";
693 double xyz_vertex_fit[3] = {0.};
694 double second_time = 0.;
701 double larv = detProp.DriftVelocity(detProp.Efield(), detProp.Temperature());
711 std::optional<geo::WireIDIntersection> wires_cross{};
712 bool time_good =
false;
715 wires_cross = wireReadoutGeom.ChannelsIntersect(chan1, chan2);
719 TGText*
tt =
new TGText(
"too big");
720 tt->InsLine(1,
"time distance");
727 xyz_vertex_fit[1] = wires_cross->y;
728 xyz_vertex_fit[2] = wires_cross->z;
729 auto pos = wireReadoutGeom.Plane(plane_0).toWorldCoords(
origin);
731 pos = wireReadoutGeom.Plane(plane_1).toWorldCoords(
origin);
734 TGText*
tt =
new TGText(Form(
"z:%4.1f", wires_cross->z));
735 tt->InsLine(1, Form(
"x:%4.1f,", (xyz_vertex_fit[0] + second_time) / 2));
736 tt->InsLine(1, Form(
"y:%4.1f,", wires_cross->y));
743 TGText*
tt =
new TGText(
"cross");
744 tt->InsLine(1,
"wires do not");
753 unsigned int wplane = 0;
754 unsigned int wirevertex = 0;
759 for (
int yy = 0; yy < 2; ++yy)
769 auto const& planeg = wireReadoutGeom.
Plane(planeID);
770 auto pos = planeg.toWorldCoords(
origin);
771 pos.SetY(xyz_vertex_fit[1]);
772 pos.SetZ(xyz_vertex_fit[2]);
774 wirevertex = planeg.NearestWireID(pos).Wire;
777 ((xyz_vertex_fit[0]) / detProp.DriftVelocity(detProp.Efield(), detProp.Temperature())) *
781 (pos.X() / detProp.DriftVelocity(detProp.Efield(), detProp.Temperature())) *
786 fPlanes[wplane]->View()->Clear();
788 fPlanes[wplane]->View()->AddMarker(wirevertex, timestart, kMagenta, 29, 2.0);
790 fPlanes[wplane]->View()->AddMarker(0.0, 0.0, 2, 1, 0.1);
791 fPlanes[wplane]->Pad()->Update();
792 fPlanes[wplane]->View()->Draw();
800 TGText*
tt =
new TGText(
"selected points");
801 tt->InsLine(1,
"not enough");
813 TObject* select = gPad->GetSelected();
815 if (!select->InheritsFrom(
"TBox"))
return;
817 static Float_t w0 = -1,
t0 = -1, w1 = -1,
t1 = -1;
819 static Int_t pxold, pyold;
820 static Int_t pw0, pt0;
821 static Int_t linedrawn;
825 static int wstart, wend;
826 static float tstart, tend;
828 int event = gPad->GetEvent();
829 int px = gPad->GetEventX();
830 int py = gPad->GetEventY();
835 gVirtualX->SetLineColor(-1);
836 w0 = gPad->AbsPixeltoX(px);
837 t0 = gPad->AbsPixeltoY(py);
843 float x = gPad->PadtoX(w0);
844 tstart = gPad->PadtoY(
t0);
846 wstart = (
unsigned int)TMath::Nint(x);
847 curr_zooming_plane = plane;
850 case kButton1Motion: {
870 if (linedrawn) gVirtualX->DrawBox(lx, ly, hx, hy, TVirtualX::kHollow);
893 gVirtualX->DrawBox(lx, ly, hx, hy, TVirtualX::kHollow);
897 if (px == pw0 && py == pt0)
break;
898 w1 = gPad->AbsPixeltoX(px);
899 t1 = gPad->AbsPixeltoY(py);
900 gPad->Modified(kTRUE);
905 float x = gPad->PadtoX(w1);
906 tend = gPad->PadtoY(
t1);
907 wend = (
unsigned int)TMath::Nint(x);
909 gROOT->SetEditorMode();
912 double xx1, yy1, xx2, yy2;
914 gPad->GetRangeAxis(xx1, yy1, xx2, yy2);
916 if (wstart != 0 && tstart != 0 && (fabs(wend - wstart) > 0.01 * (xx2 - xx1)) &&
917 (fabs(tend - tstart) > 0.01 * (yy2 - yy1) && curr_zooming_plane == plane)) {
919 SetZoom(plane, wstart, wend, tstart, tend);
946 for (
size_t iplane = 0; iplane <
fPlanes.size(); ++iplane) {
947 int minw, maxw, mint, maxt;
951 fPlanes[iplane]->RawDataDraw()->GetRegionOfInterest(iplane, minw, maxw, mint, maxt);
953 fPlanes[iplane]->RecoBaseDraw()->GetRegionOfInterest(iplane, minw, maxw, mint, maxt);
955 if (test == -1)
continue;
959 minw = -0.005 * (wireReadoutGeom.Nwires(planeID) - 1);
960 maxw = 1.005 * (wireReadoutGeom.Nwires(planeID) - 1);
961 mint = -0.005 *
fPlanes[iplane]->RawDataDraw()->TotalClockTicks();
962 maxt = 1.01 *
fPlanes[iplane]->RawDataDraw()->TotalClockTicks();
965 SetZoom(iplane, minw, maxw, mint, maxt,
false);
966 zo.
wmin[iplane] = minw;
967 zo.
tmin[iplane] = mint;
968 zo.
wmax[iplane] = maxw;
969 zo.
tmax[iplane] = maxt;
1003 fZoomInterest->Connect(
"Clicked()",
"evd::TWQMultiTPCProjectionView",
this,
"ZoomInterest()");
1007 "Clicked()",
"evd::TWQMultiTPCProjectionView",
this,
"ZoomInterest(=false)");
1010 fZoomBack->Connect(
"Clicked()",
"evd::TWQMultiTPCProjectionView",
this,
"ZoomBack()");
1015 "Clicked()",
"evd::TWQMultiTPCProjectionView",
this,
"SetZoomInterest()");
1021 fVFrame->AddFrame(
fZoomBack,
new TGLayoutHints(kLHintsTop | kLHintsLeft, 0, 0, 5, 1));
1029 if (parameter == 1 || parameter == 2) {
fToggleZoom->SetState(kButtonUp); }
1040 fFindEndpoint->Connect(
"Clicked()",
"evd::TWQMultiTPCProjectionView",
this,
"FindEndPoint()");
1043 fVFrame, 100, 55, 999, TGView::kNoHSB | TGView::kNoVSB);
1045 TGText*
tt =
new TGText(
"x,y,z");
1050 "Clicked()",
"evd::TWQMultiTPCProjectionView",
this,
"ClearEndPoints()");
1053 new TGCheckButton(
fVFrame,
"ShowMarkers", 0);
1055 "Clicked()",
"evd::TWQMultiTPCProjectionView",
this,
"ToggleEndPointMarkers()");
1074 ThePrevZoomOpt.
wmin[plane],
1075 ThePrevZoomOpt.
wmax[plane],
1076 ThePrevZoomOpt.
tmin[plane],
1077 ThePrevZoomOpt.
tmax[plane],
1081 for (
size_t iplane = 0; iplane !=
fPlanes.size(); ++iplane) {
1083 ThePrevZoomOpt.
wmin[iplane],
1084 ThePrevZoomOpt.
wmax[iplane],
1085 ThePrevZoomOpt.
tmin[iplane],
1086 ThePrevZoomOpt.
tmax[iplane],
1095 <<
"unable to unzoom further - no zoom settings left on stack" << std::endl;
1117 TVirtualPad* ori = gPad;
1121 if (wirehi < wirelow) {
1127 if (timehi < timelow) {
1134 curr_zooming_plane = -1;
1136 fPlanes[plane]->SetZoomRange(wirelow, wirehi, timelow, timehi);
1154 TVirtualPad* ori = gPad;
1162 fWireQ->
Pad()->SetBit(TPad::kCannotMove,
true);
1163 fWireQ->
Pad()->GetFrame()->SetBit(TPad::kCannotMove,
true);
1178 kPlane = (
unsigned int)
fPlaneEntry->GetNumberEntry()->GetNumber();
1186 kWire = (
unsigned int)
fWireEntry->GetNumberEntry()->GetNumber();
1194 kDistance = (double)
fDistance->GetNumberEntry()->GetNumber();
1200 double threshold =
fThresEntry->GetNumberEntry()->GetNumber();
1205 TVirtualPad* ori = gPad;
1221 TGButton* b = (TGButton*)gTQSender;
1222 if (b->GetState() == kButtonDown) { cst->
fColorOrGray = 1; }
1227 TVirtualPad* ori = gPad;
1243 TGButton* b = (TGButton*)gTQSender;
1244 int id = b->WidgetId();
1266 TVirtualPad* ori = gPad;
1288 TGButton* b = (TGButton*)gTQSender;
1289 if (b->GetState() == kButtonDown) {
1298 TVirtualPad* ori = gPad;
code to link reconstructed objects back to the MC truth information
TGRadioButton * fCalibDraw
Draw calibrated information only.
MaybeLogger_< ELseverityLevel::ELsev_info, true > LogVerbatim
const art::Event * GetEvent() const
TQPad * fWireQ
Histogram of charge vs time on selected wire.
int fEnableMCTruthCheckBox
1 to have the check box appear, 0 otherwise
unsigned int fTPC
TPC number to draw, typically set by TWQProjectionView.
static unsigned int kWire
Drawing pad for short summary of an MC event.
Drawing pad showing a single X-Z or Y-Z projection of an event.
TGCompositeFrame * fVFrame
needed for the side frame
int fDrawRawDataOrCalibWires
0 for raw
TGCompositeFrame * fFrame
Graphics frame.
unsigned int NTPC(CryostatID const &cryoid=details::cryostat_zero) const
Returns the total number of TPCs in the specified cryostat.
The data type to uniquely identify a Plane.
Drawing pad for time or charge histograms.
double Temperature() const
In kelvin.
TGNumberEntry * fThresEntry
ADC threshold to display.
std::map< int, double > tmin
cout<< "Opened file "<< fin<< " ixs= "<< ixs<< endl;if(ixs==0) hhh=(TH1F *) fff-> Get("h1")
static unsigned int kPlane
TCanvas * fCanvas
The ROOT drawing canvas.
A collection of drawable 2-D objects.
TGTextButton * fUnZoomInterest
Unzoom on iteresting region.
TGRadioButton * fRawCalibDraw
Draw raw and calibrated information.
TGLayoutHints * fLayout
Layout hints for frame.
void ChangeWire(int plane)
Manage all things related to colors for the event display.
unsigned short fShowMCTruthVectors
std::vector< TWireProjPad * > fPlanes
time vs wire projection for each plane
Singleton to hold the current art::Event for the event display.
void ZoomInterest(bool flag=true)
void Draw(const char *opt="")
MCBriefPad * fMC
Short summary of MC event.
double FindLineLength(detinfo::DetectorClocksData const &clockData, detinfo::DetectorPropertiesData const &detProp)
double Efield(unsigned int planegap=0) const
kV/cm
void RadioButtonsDispatch(int parameter)
TGNumberEntry * fPlaneEntry
Plane number displayed.
int fShowEndPointSection
Show section corresponding to EndPoint finding.
The color scales used by the event display.
HeaderPad * fHeaderPad
Show header information.
std::deque< util::PxPoint > ppoints
list of points in each WireProjPad used for x,y,z finding
TGTextButton * fFindEndpoint
Calculate XYZ position of two points in wire planes.
TGCheckButton * fMCOn
Display MC truth information.
int fShowSideBar
1 to show, 0 don't show
TGTextButton * fZoomBack
Unzoom on iteresting region.
unsigned short fXsize
Size of the canvas;.
A drawing pad for time vs wire.
int fAutoZoomInterest
Set the automatic zoom to the interest region.
void SelectPoint(int plane)
TGCheckButton * fToggleAutoZoom
Toggle the autozoom setting.
TGTextButton * fClearPPoints
Clear current list of End Points.
unsigned int fCryostat
Cryostat number to draw, typically set by TWQProjectionView.
static EventHolder * Instance()
static int curr_zooming_plane
int fShowEndPointMarkers
Draw EndPoint Markers if clicked.
double fMinSignal
minimum ADC count to display a time bin
TGTextView * fXYZPosition
Display the xyz position.
TGRadioButton * fRawDraw
Draw Raw information only.
geo::TPCID CurrentTPC() const
Returns the current TPC as a TPCID.
void DrawPads(const char *opt="")
double DriftVelocity(double efield=0., double temperature=0.) const
cm/us
The data type to uniquely identify a TPC.
PlaneID_t Plane
Index of the plane within its TPC.
TGCompositeFrame * fMetaFrame
needed for the side frame
Class to aid in the rendering of RecoBase objects.
Class to aid in the rendering of RawData objects.
unsigned short fYsize
Size of the canvas;.
void SetMouseZoomRegion(int plane)
std::map< int, double > wmax
TWQMultiTPCProjectionView(TGMainFrame *mf)
TGTextButton * fZoomInterest
Zoom on iteresting region.
static void MouseDispatch(int plane, void *wqpv)
Encapsulate the construction of a single detector plane .
int fChangeWire
1 to click mouse and change wire, 0 don't
Contains all timing reference information for the detector.
TGRadioButton * fToggleZoom
Use zoom setting.
void ToggleEndPointMarkers()
std::vector< TQPad * > fPlaneQ
charge on each plane
TGCheckButton * fGreyScale
Display gray or color scale.
int fColorOrGray
0 = color, 1 = gray
int trigger_offset(DetectorClocksData const &data)
static const char * zoom_opt
std::vector< ZoomOptionsMultiTPC > fPrevZoomOpt
int fPrintTotalCharge
Print out the total charge in an event.
std::deque< util::PxLine > pline
list of lines in each WireProjPad used for calculating 2d and 3d angles
std::map< int, double > wmin
void SetZoom(int plane, int wirelow, int wirehi, int timelo, int timehi, bool StoreZoom=true)
TGNumberEntry * fWireEntry
Wire number displayed.
std::map< int, double > tmax
double sampling_rate(DetectorClocksData const &data)
Returns the period of the TPC readout electronics clock.
ZoomOptionsMultiTPC fZoomOpt
Point3DBase_t< PlaneGeoCoordinatesTag > LocalPoint_t
Type of points in the local GDML wire plane frame.
~TWQMultiTPCProjectionView()
TRootEmbeddedCanvas * fEmbCanvas
Embedded canvas.
art framework interface to geometry description
TGNumberEntry * fDistance
Distance from line to find hits in cluster.
constexpr Point origin()
Returns a origin position with a point of the specified type.
Event finding and building.
TGCheckButton * fToggleShowMarkers
Toggle the ShowEndPointMarkersSetting.
Signal from collection planes.
void SetPlaneWire(unsigned int plane=0, unsigned int wire=0)