8 #include <TRootEmbeddedCanvas.h>
10 #include <TGComboBox.h>
11 #include <TGNumberEntry.h>
12 #include <TGTextView.h>
13 #include <TGTextEntry.h>
15 #include "AliMpSlatMotifMap.h"
16 #include "AliMpSt345Reader.h"
17 #include "AliMpSectorReader.h"
18 #include "AliMpSlat.h"
20 #include "AliMpPCBPainter.h"
21 #include "AliMpSectorReader.h"
22 #include "AliMpSector.h"
24 #include "AliMpVRowSegment.h"
25 #include "AliMpRowPainter.h"
26 #include "AliMpVPainter.h"
27 #include "AliMpMotifPainter.h"
28 #include "AliMpMotifPosition.h"
29 #include "AliMpMotifMap.h"
31 #include "AliMpDEIterator.h"
32 #include "AliMpDEManager.h"
33 #include "AliMpDetElement.h"
34 #include "AliMpStationType.h"
35 #include "AliMpSegmentation.h"
37 #include "AliMpDDLStore.h"
39 #include "AliMpDEVisu.h"
44 // -----------------------
45 // GUI for drawing segmentation
46 // motif manu and associated channels
54 //_________________________________________________________________
55 AliMpDEVisu::AliMpDEVisu(UInt_t w, UInt_t h)
56 : TGFrame(gClient->GetRoot(), w, h),
57 fkMainWindow(gClient->GetRoot()),
58 fMain(new TGMainFrame(gClient->GetRoot(), w, h)),
69 fCurrentPlane(AliMp::kBendingPlane),
73 fDDLStore(AliMpDDLStore::Instance())
77 // Create canvas widget
79 Int_t width = Int_t(w*0.99);
80 Int_t height = Int_t(h*0.99);
82 fEcanvas = new TRootEmbeddedCanvas("Ecanvas",fMain, width, height);
83 fEcanvas->GetCanvas()->Connect("ProcessedEvent(Int_t, Int_t, Int_t, TObject*)",
86 "HandleMovement(Int_t, Int_t, Int_t, TObject*)");
88 // Create a horizontal frame widget with buttons
89 TGHorizontalFrame *hframe = new TGHorizontalFrame(fMain,width,height/6);
91 TGTextButton *draw = new TGTextButton(hframe,"&Draw");
92 draw->Connect("Clicked()","AliMpDEVisu",this,"DrawDE()");
93 hframe->AddFrame(draw, new TGLayoutHints(kLHintsLeft | kLHintsCenterY,15,5,3,4));
95 TGTextButton *exit = new TGTextButton(hframe,"&Exit","gApplication->Terminate(0)");
96 hframe->AddFrame(exit, new TGLayoutHints(kLHintsLeft| kLHintsCenterY,5,5,3,4));
103 TGLabel* chamberLabel = new TGLabel(hframe, "Chamber :");
104 hframe->AddFrame(chamberLabel, new TGLayoutHints(kLHintsCenterX | kLHintsLeft | kLHintsCenterY, 10, 0, 20, 0));
105 fChamberCombo = new TGComboBox(hframe, kChamberCombo);
108 for(i = 0; i < 10; i++)
110 sprintf(text,"%d",i+1);
111 fChamberCombo->AddEntry(text,i);
113 fChamberCombo->Resize(40,20);
114 fChamberCombo->Select(0);
115 fChamberCombo->Associate(this);
116 hframe->AddFrame(fChamberCombo, new TGLayoutHints(kLHintsLeft, 10, 0, 9, 0));
119 TGLabel* detElemLabel = new TGLabel(hframe, "DE :");
120 hframe->AddFrame(detElemLabel, new TGLayoutHints(kLHintsCenterX | kLHintsLeft | kLHintsCenterY, 10, 0, 20, 0));
121 fDECombo = new TGComboBox(hframe, kDECombo);
124 fDECombo->Resize(80,20);
126 fDECombo->Associate(this);
127 hframe->AddFrame(fDECombo, new TGLayoutHints(kLHintsLeft, 10, 0, 9, 0));
131 TGLabel* detElemName = new TGLabel(hframe, "Name :");
132 hframe->AddFrame(detElemName, new TGLayoutHints(kLHintsCenterX | kLHintsLeft | kLHintsCenterY, 10, 0, 20, 0));
134 AliMpDetElement* detElem = AliMpDEManager::GetDetElement(fCurrentDetElem);
135 fCurrentDEName = detElem->GetDEName();
136 fNameDEView = new TGTextView(hframe, 180, 25, fCurrentDEName.Data(), kDEName);
137 hframe->AddFrame(fNameDEView, new TGLayoutHints(kLHintsLeft, 10, 0, 9, 0));
140 fPlaneButton = new TGCheckButton(hframe, "NB Plane", kPlaneType);
141 fPlaneButton->SetState(kButtonUp);
142 fPlaneButton->Associate(this);
143 hframe->AddFrame(fPlaneButton, new TGLayoutHints(kLHintsLeft, 10, 0, 9, 0));
147 TGTextButton* drawManu = new TGTextButton(hframe,"&Search");
148 drawManu->Connect("Clicked()","AliMpDEVisu",this,"DrawManuMotif(Bool_t)");
149 drawManu->SetToolTipText("Search for a given manu number");
150 hframe->AddFrame(drawManu, new TGLayoutHints(kLHintsLeft | kLHintsCenterY,15,5,3,4));
153 fNumberEntry = new TGNumberEntry(hframe, 0, 4, -1,
154 TGNumberFormat::kNESInteger, TGNumberFormat::kNEANonNegative,
155 TGNumberFormat::kNELLimitMinMax, 1, 1500);
156 fNumberEntry->Resize(60,20);
157 hframe->AddFrame(fNumberEntry, new TGLayoutHints(kLHintsLeft | kLHintsCenterY, 10, 0, 9, 0));
160 TGTextButton *resetManu = new TGTextButton(hframe,"&Reset");
161 resetManu->Connect("Clicked()","AliMpDEVisu",this,"ResetManu()");
162 hframe->AddFrame(resetManu, new TGLayoutHints(kLHintsLeft | kLHintsCenterY,10,5,3,4));
164 // delete window button
165 TGTextButton* deletePopup = new TGTextButton(hframe,"&Delete_Popup");
166 deletePopup->Connect("Clicked()","AliMpDEVisu",this,"DeletePopUp()");
167 deletePopup->SetToolTipText("Delete motif popup window");
168 hframe->AddFrame(deletePopup, new TGLayoutHints(kLHintsLeft | kLHintsCenterY,15,5,3,4));
172 TGHorizontalFrame *logFrame = new TGHorizontalFrame(fMain, width/2, height/6);
174 TGLabel* logName = new TGLabel(logFrame, "Log MSG:");
175 logFrame->AddFrame(logName, new TGLayoutHints(kLHintsCenterX | kLHintsLeft | kLHintsCenterY, 10, 0, 2, 0));
177 fLogMessage = new TGTextView(logFrame, width/2, 60);
178 fLogMessage->ShowBottom();
180 logFrame->AddFrame(fLogMessage, new TGLayoutHints(kLHintsLeft, 10, 0, 2, 0));
183 TGTextButton* clearLog = new TGTextButton(logFrame,"&Clear");
184 clearLog->Connect("Clicked()","AliMpDEVisu",this,"ClearLogMessage()");
185 clearLog->SetToolTipText("Clear log message");
186 logFrame->AddFrame(clearLog, new TGLayoutHints(kLHintsLeft | kLHintsCenterY,15,5,3,4));
189 TGTextButton* saveLog = new TGTextButton(logFrame,"&Save");
190 saveLog->Connect("Clicked()","AliMpDEVisu",this,"SaveLogMessage()");
191 saveLog->SetToolTipText("Save log message into file");
192 logFrame->AddFrame(saveLog, new TGLayoutHints(kLHintsLeft | kLHintsCenterY,5,5,3,4));
195 fLogFile = new TGTextEntry(logFrame,"AliMpDEVisu.log");
196 fLogFile->SetToolTipText("Default log file name");
197 logFrame->AddFrame(fLogFile, new TGLayoutHints(kLHintsLeft | kLHintsCenterY, 10, 0, 9, 0));
200 fMain->AddFrame(hframe, new TGLayoutHints(kLHintsLeft | kLHintsCenterY,2,2,10,10));
201 fMain->AddFrame(fEcanvas, new TGLayoutHints(kLHintsCenterX, 10,10,10,10));
203 fMain->AddFrame(logFrame, new TGLayoutHints(kLHintsLeft,2,2,2,10));
205 // Set a name to the main frame
206 fMain->SetWindowName("MUON Detection Element Visualization");
208 // Map all subwindows of main frame
209 fMain->MapSubwindows();
211 // Initialize the layout algorithm
212 fMain->Resize(fMain->GetDefaultSize());
217 // instance segmentation
218 fSegmentation = AliMpSegmentation::Instance()->GetMpSegmentation(fCurrentDetElem,
219 AliMp::GetCathodType(fCurrentPlane));
220 fLogMessage->AddLine("Segmentation loaded");
221 fLogMessage->ShowBottom();
224 //____________________________________________________________
225 AliMpDEVisu::~AliMpDEVisu()
227 // Clean up used widgets: frames, buttons, layouthints
229 fChamberCombo->Delete();
231 fNumberEntry->Delete();
232 fPlaneButton->Delete();
233 fNameDEView->Delete();
234 fLogMessage->Delete();
240 //__________________________________________________________
241 void AliMpDEVisu::HandleMovement(Int_t eventType, Int_t eventX, Int_t eventY, TObject* /*select*/)
243 /// handle cursor mouvement
245 if (eventType == 11) {// 61) {// double click
247 TCanvas *canvas = fEcanvas->GetCanvas();
250 // estimate graphic pad sizes
251 TVector2 ul(gPad->XtoPixel(0.02), gPad->YtoPixel(0.98));
252 TVector2 br(gPad->XtoPixel(1.00), gPad->YtoPixel(0.02));
254 TVector2 padDim = br - ul;
256 fSegmentation = AliMpSegmentation::Instance()
257 ->GetMpSegmentation(fCurrentDetElem, AliMp::GetCathodType(fCurrentPlane));
259 // get DE dimension (half size)
260 TVector2 deDim = fSegmentation-> Dimensions();
263 // calculated in pixel
267 if (fCurrentDetElem >= 500) {
269 x = (eventX - ul.X() - padDim.X()/2.)/(padDim.X())*deDim.X();
270 y = (br.Y() - eventY - padDim.Y()/2.)/(padDim.Y())*deDim.Y();
274 x = (eventX - ul.X())/(padDim.X())*deDim.X();
275 y = (br.Y() - eventY)/(padDim.Y())*deDim.Y();
279 TVector2 padReal(x,y);
283 AliMpPad pad = fSegmentation->PadByPosition(padReal, false);
286 if (!pad.IsValid()) {
287 sprintf(log, "PopupManuMotif: No manu for DE: %d at position (%5.2f, %5.2f)",
288 fCurrentDetElem, x, y);
289 fLogMessage->AddLine(log);
290 fLogMessage->ShowBottom();
295 Int_t manu = pad.GetLocation().GetFirst();
297 fNumberEntry->SetNumber(manu);
299 sprintf(log, "PopupManuMotif: DE: %d, manu: %d at position: %5.2f, %5.2f", fCurrentDetElem, manu, x, y);
300 fLogMessage->AddLine(log);
301 fLogMessage->ShowBottom();
308 //__________________________________________________________
309 void AliMpDEVisu::DrawDE()
311 /// Draws function graphics in randomly choosen interval
315 if (fCurrentDetElem >= 500) {
321 DrawQuadrant("RSMCI");
327 //__________________________________________________________
328 void AliMpDEVisu::DrawManuMotif(Bool_t popup)
330 // Draw manu motif in yellow and popup channel motif window
333 if (!fNumberEntry->GetIntNumber()) return;
337 if (fCurrentDetElem >= 500) {
339 sprintf(command, "%s%d", "PMCI:", (Int_t)fNumberEntry->GetIntNumber());
341 DrawSlat(command, popup);
345 sprintf(command, "%s%d", "RSMCI:", (Int_t)fNumberEntry->GetIntNumber());
347 DrawQuadrant(command, popup);
352 //__________________________________________________________
353 void AliMpDEVisu::DrawSlat(Option_t* option, Bool_t popup)
355 /// draw slat segmentation
357 TCanvas *canvas = fEcanvas->GetCanvas();
360 AliMpDetElement* detElem = AliMpDEManager::GetDetElement(fCurrentDetElem);
361 TString nameType = detElem->GetSegType();
363 AliMpSlatMotifMap mm;
364 AliMpSt345Reader reader(mm);
365 AliMpSlat* slatCurrent = reader.ReadSlat(nameType.Data(), fCurrentPlane);
366 AliMpSlat* slatOther = reader.ReadSlat(nameType.Data(), AliMp::OtherPlaneType(fCurrentPlane));
371 AliMpVPainter* painter = AliMpVPainter::CreatePainter(slatCurrent);
372 painter->Draw(option);
378 Int_t numberOfManu = slatCurrent->GetNofElectronicCards() +
379 slatOther->GetNofElectronicCards();
383 sprintf(log, "DrawSlat: number of manus: %d", numberOfManu);
385 fLogMessage->AddLine(log);
386 fLogMessage->ShowBottom();
389 PopUpManuMotif(slatCurrent);
393 //__________________________________________________________
394 void AliMpDEVisu:: DrawQuadrant(Option_t* option, Bool_t popup)
396 /// draw quadrant segmentation
398 TCanvas *canvas = fEcanvas->GetCanvas();
401 AliMpDetElement* detElem = AliMpDEManager::GetDetElement(fCurrentDetElem);
402 AliMp::StationType station = detElem->GetStationType();
404 AliMpSectorReader readerCurrent(station, fCurrentPlane);
405 AliMpSector* sectorCurrent = readerCurrent.BuildSector();
407 AliMpSectorReader readerOther(station, AliMp::OtherPlaneType(fCurrentPlane));
408 AliMpSector* sectorOther = readerOther.BuildSector();
413 AliMpVPainter *painter = AliMpVPainter::CreatePainter(sectorCurrent);
414 painter->Draw(option);
421 sectorCurrent->GetMotifMap()->GetNofMotifPositions() +
422 sectorOther->GetMotifMap()->GetNofMotifPositions();
426 sprintf(log, "DrawQuadrant: number of manus: %d", numberOfManu);
428 fLogMessage->AddLine(log);
429 fLogMessage->ShowBottom();
432 PopUpManuMotif(sectorCurrent);
435 //__________________________________________________________
436 void AliMpDEVisu::ResetManu()
438 /// reset manu search entry
439 fLogMessage->AddLine("Reset Motif Search Entry:");
440 fLogMessage->ShowBottom();
441 fNumberEntry->SetNumber(0);
445 //__________________________________________________________
446 void AliMpDEVisu::DeletePopUp()
448 /// delete motif popup windows
450 if (fTrashList.GetEntries() > 0) {
451 fLogMessage->AddLine("Delete Motif PopUp Windows:");
452 fLogMessage->ShowBottom();
454 // for (Int_t i = 0; i < fTrashList.GetEntries(); ++i) {
456 // TGTransientFrame* trans = (TGTransientFrame*)fTrashList.At(i);
465 //__________________________________________________________
466 void AliMpDEVisu::SaveLogMessage()
468 /// save log message into log file
470 TString logFile = fLogFile->GetDisplayText();
471 fLogMessage->GetText()->Save(logFile.Data());
474 sprintf(log, "SaveLogMessage: saving log message into logfile: %s", logFile.Data());
475 fLogMessage->AddLine(log);
476 fLogMessage->ShowBottom();
479 //__________________________________________________________
480 void AliMpDEVisu::ClearLogMessage()
482 /// clear log message
483 fLogMessage->GetText()->Clear();
485 sprintf(log, "ClearLogMessage: clear log messages:");
486 fLogMessage->AddLine(log);
487 fLogMessage->ShowBottom();
490 //__________________________________________________________
491 void AliMpDEVisu::InfoDE()
493 /// info concerning the whole DE
495 AliMpDetElement* detElem = fDDLStore->GetDetElement(fCurrentDetElem);
496 Int_t ddlId = detElem->GetDdlId();
497 Int_t numberOfBus = detElem->GetNofBusPatches();
498 Int_t firstBus = detElem->GetBusPatchId(0);
499 Int_t lastBus = detElem->GetBusPatchId(numberOfBus - 1); // expect a continuous numbering
501 detElem = AliMpDEManager::GetDetElement(fCurrentDetElem);
502 Int_t numberOfSerialManu = detElem->GetNofManus(); // number of manu with an identified serial number
505 sprintf(log, "DrawDE: detection element: %d, name: %s", fCurrentDetElem, fCurrentDEName.Data());
506 fLogMessage->AddLine(log);
507 fLogMessage->ShowBottom();
510 sprintf(log, "DrawDE: DDL: %d, number of buspatches %d from %d to %d",
511 ddlId, numberOfBus, firstBus, lastBus);
512 fLogMessage->AddLine(log);
513 fLogMessage->ShowBottom();
515 if (numberOfSerialManu != 0) { // not available yet for all DE
516 sprintf(log, "DrawDE: number of manus with serial number: %d", numberOfSerialManu);
517 fLogMessage->AddLine(log);
518 fLogMessage->ShowBottom();
523 //__________________________________________________________
524 Bool_t AliMpDEVisu::ProcessMessage(Long_t msg, Long_t parm1, Long_t /*parm2*/)
526 /// process message from widgets actions/entries
531 switch (GET_SUBMSG(msg))
548 case kCM_CHECKBUTTON:
549 if (fPlaneButton->GetState() == kButtonDown) {
550 fCurrentPlane = AliMp::kNonBendingPlane;
551 if (fNumberEntry->GetIntNumber() && fNumberEntry->GetIntNumber() <= 1024)
552 fNumberEntry->SetNumber(fNumberEntry->GetIntNumber() + 1024);
554 fCurrentPlane = AliMp::kBendingPlane;
555 if (fNumberEntry->GetIntNumber() && fNumberEntry->GetIntNumber() > 1024)
556 fNumberEntry->SetNumber(fNumberEntry->GetIntNumber() - 1024);
566 //__________________________________________________________
567 void AliMpDEVisu::UpdateComboDE()
569 /// update DE in respect to selected chamber
571 fDECombo->RemoveAll();
577 for ( it.First(fChamberCombo->GetSelected()); ! it.IsDone(); it.Next() ) {
578 sprintf(text,"%d",it.CurrentDE()->GetId());
579 fDECombo->AddEntry(text,i);
580 fDEComboIdx[i++] = it.CurrentDE()->GetId();
585 //__________________________________________________________
586 void AliMpDEVisu::UpdateNameView()
588 /// update DE name in respect to selected DE id.
590 fNameDEView->Clear();
592 fCurrentDetElem = fDEComboIdx[fDECombo->GetSelected()];
593 AliMpDetElement* detElem = AliMpDEManager::GetDetElement(fCurrentDetElem);
594 fCurrentDEName = detElem->GetDEName();
596 fNameDEView->AddLine(fCurrentDEName.Data());
597 fNameDEView->ShowBottom();
600 //__________________________________________________________
601 void AliMpDEVisu::PopUpManuMotif(AliMpSlat* slat)
603 /// pop up manu window motif painter for slat
605 // Create transient frame
606 TGTransientFrame* trans = new TGTransientFrame(fkMainWindow, fMain, 400, 400);
607 trans->DontCallClose();
608 trans->CenterOnParent();
611 fTrashList.Add(trans);
614 sprintf(title,"Manu Motif: %d", (Int_t)fNumberEntry->GetIntNumber());
615 trans->SetWindowName(title);
617 // Create canvas widget
618 TRootEmbeddedCanvas* eTransCanvas =
619 new TRootEmbeddedCanvas("ETransCanvas",trans,400,400);
621 trans->AddFrame(eTransCanvas, new TGLayoutHints(kLHintsLeft | kLHintsCenterY, 10,10,1,10));
625 AliMpMotifPosition* motifPosFound = 0x0;
627 TCanvas *canvas = eTransCanvas->GetCanvas();
630 for ( AliMpSlat::Size_t i = 0; i < slat->GetSize(); ++i ) {
632 AliMpPCB* pcb = slat->GetPCB(i);
633 AliMpPCBPainter* pcbPainter = new AliMpPCBPainter(pcb);
635 for ( AliMpPCB::Size_t j = 0; j < slat->GetPCB(i)->GetSize(); ++j ) {
637 AliMpMotifPosition*motifPos = pcb->GetMotifPosition(j);
639 Int_t manuId = motifPos->GetID();
640 if (manuId == (Int_t)fNumberEntry->GetIntNumber()) {
641 motifPosFound = motifPos;
652 trans->MapSubwindows();
655 AliMpVPainter* painter = AliMpVPainter::CreatePainter(motifPosFound);
664 //__________________________________________________________
665 void AliMpDEVisu::PopUpManuMotif(AliMpSector* sector)
668 /// pop up manu window motif painter for sector
670 // Create transient frame
671 TGTransientFrame* trans = new TGTransientFrame(fkMainWindow, fMain, 400, 400);
672 trans->DontCallClose();
673 trans->CenterOnParent();
676 fTrashList.Add(trans);
679 sprintf(title,"Manu Motif: %d", (Int_t)fNumberEntry->GetIntNumber());
680 trans->SetWindowName(title);
682 // Create canvas widget
683 TRootEmbeddedCanvas* eTransCanvas =
684 new TRootEmbeddedCanvas("ETransCanvas",trans,400,400);
686 trans->AddFrame(eTransCanvas, new TGLayoutHints(kLHintsLeft | kLHintsCenterY,
690 AliMpMotifPosition* motifPosFound = 0x0;
692 TCanvas *canvas = eTransCanvas->GetCanvas();
695 for (Int_t iRow = 0; iRow < sector->GetNofRows(); ++iRow) {
697 AliMpRow* row = sector->GetRow(iRow);
698 AliMpRowPainter* rowPainter = new AliMpRowPainter(row);
700 for (Int_t iRowSeg = 0; iRowSeg < sector->GetRow(iRow)->GetNofRowSegments(); ++iRowSeg){
702 for (Int_t iRowSeg = 0; iRowSeg < row->GetNofRowSegments(); ++iRowSeg) {
703 AliMpVRowSegment *rowSegment = row->GetRowSegment(iRowSeg);
705 for (Int_t iMotif = 0; iMotif < rowSegment->GetNofMotifs(); ++iMotif){
707 Int_t motifPositionId = rowSegment->GetMotifPositionId(iMotif);
708 AliMpMotifPosition *motifPos = rowSegment->GetRow()
709 ->GetMotifMap()->FindMotifPosition(motifPositionId);
711 Int_t manuId = motifPos->GetID();
712 if (manuId == (Int_t)fNumberEntry->GetIntNumber()) {
713 motifPosFound = motifPos;
728 trans->MapSubwindows();
731 AliMpVPainter* painter = AliMpVPainter::CreatePainter(motifPosFound);