#include "TEveViewer.h"
#include "TEveEventManager.h"
-//#include "AliHLTTriggerDecision.h"
#include "AliHLTEvePhos.h"
#include "AliHLTEveEmcal.h"
#include "AliHLTEveTPC.h"
#include "AliHLTEveISDD.h"
#include "AliHLTEveTRD.h"
#include "AliHLTEveMuon.h"
+#include "AliHLTEveMultCorr.h"
#include "AliHLTEveAny.h"
#include "AliEveHLTEventManager.h"
#include "TList.h"
#include "TTimer.h"
-
#include "TThread.h"
ClassImp(AliEveHLTEventManager);
fISDDElement(NULL),
fTRDElement(NULL),
fMuonElement(NULL),
+ fMultCorrElement(NULL),
fAnyElement(NULL),
fEventLoopStarted(kFALSE),
fCenterProjectionsAtPrimaryVertex(kFALSE),
fShowBarrel(kTRUE),
fShowMuon(kFALSE),
- fRunNumber(-1)
+ fRunNumber(666),
+ fEventId(-1)
{
// see header file for class documentation
// or
if(fMuonElement)
delete fMuonElement;
fMuonElement = NULL;
+
+ if(fMultCorrElement)
+ delete fMultCorrElement;
+ fMultCorrElement = NULL;
if(fAnyElement)
delete fAnyElement;
gEve->DisableRedraw();
+ event->GetStdContent();
// -- Set EventID in Window Title
TString winTitle("Eve Main Window");
- winTitle += Form("-- Run Number: %d", event->GetRunNumber());
- winTitle += Form("-- Event ID : 0x%016lX ", GetEventBuffer()->GetEventId() );
+ SetRunNumber(event->GetRunNumber());
+ SetEventId(GetEventBuffer()->GetEventId());
+ winTitle += Form("-- Run Number: %d", GetRunNumber());
+ winTitle += Form("-- Event ID : 0x%016lX ", GetEventId() );
GetEveManager()->GetBrowser()->SetWindowName(winTitle);
-
-
- cout << "reset()"<<endl;
-
- ResetDisplay();
-
- cout << "process()"<<endl;
if(!fHLTElement) {
fHLTElement = new AliHLTEveHLT();
fHLTElement->SetEventManager(this);
if(!fEmcalElement) CreateEmcalElement();
fEmcalElement->ProcessEvent(event);
- cout << "update()"<<endl;
- UpdateDisplay();
-
- gEve->Redraw3D(0, 1);
+ gEve->FullRedraw3D(0, 1);
gEve->EnableRedraw();
return 0;
return -1;
}
- cout << "ProcessEvent()::reset ()"<<endl;
- ResetDisplay();
- cout << "ProcessEvent() :: done reset()"<<endl;
+ gEve->DisableRedraw();
+
AliHLTHOMERBlockDesc * block = NULL;
TIter next(blockList);
while ((block = (AliHLTHOMERBlockDesc*)next())) {
cout <<"Process Block"<<endl;
ProcessBlock(block);
}
-
- cout << "update() "<<endl;
- UpdateDisplay();
+
return 0;
}
if(event) {
ProcessEvent(event);
}
+
+ } else if(!(block->GetDataType().CompareTo("ROOTTOBJ"))) {
+
+ if(!fMultCorrElement) CreateMultCorrElement();
+ fMultCorrElement->ProcessBlock(block);
+
} else {
fHLTElement->ProcessBlock(block);
}
else if ( ! block->GetDetector().CompareTo("MUON") ) {
//Do Nothing
+ if(!block->GetDataType().CompareTo("ROOTHIST")) {
+ if(!fMuonElement) {
+ fMuonElement = new AliHLTEveMuon();
+ fMuonElement->SetEventManager(this);
+ gEve->AddElement(fMuonElement);
+ }
+ fMuonElement->ProcessBlock(block);
+ }
+
} else {
if(!fAnyElement) {
fAnyElement = new AliHLTEveAny();
void AliEveHLTEventManager::PrintScreens() {
// //See header file for documentation
-// fEveManager->GetDefaultGLViewer()->SavePicture(Form("%d_0x%lu_3D.gif", fRunNumber, GetEventID(fCurrentEventIdx)));
-// fRhoZViewer->GetGLViewer()->SavePicture(Form("%d_0x%lu_RhoZ.gif", fRunNumber, GetEventID(fCurrentEventIdx)));
-// fRPhiViewer->GetGLViewer()->SavePicture(Form("%d_0x%lu_RPhi.gif", fRunNumber, GetEventID(fCurrentEventIdx)));
+ Float_t scale = 4.f;
+ //Int_t width = 4000;
+ //Int_t height = 2000;
+
+ fEveManager->GetDefaultGLViewer()->SavePictureScale(Form("run_%d_0x%016lX_3D.gif", fRunNumber, GetEventId()), scale);
+ fRhoZViewer->GetGLViewer()->SavePictureScale(Form("run_%d_0x%016lX_RhoZ.gif", fRunNumber, GetEventId()), scale);
+ fRPhiViewer->GetGLViewer()->SavePictureScale(Form("run_%d_0x%016lX_RPhi.gif", fRunNumber, GetEventId()), scale);
return;
}
//fTimer->SetCommand("NextEvent()", "AliEveHLTEventManager", this);
NextEvent();
SetEventLoopStarted(kTRUE);
- fTimer->Start(15000);
+ fTimer->Start(45000);
}
void AliEveHLTEventManager::StopLoop() {
void AliEveHLTEventManager::UpdateDisplay() {
//See header file for documentation
+ cout << "AliHLTEventManager::UpdateDisplay(); " <<endl;
if(fPhosElement) fPhosElement->UpdateElements();
if(fEmcalElement) fEmcalElement->UpdateElements();
if(fTPCElement) fTPCElement->UpdateElements();
if(fTRDElement) fTRDElement->UpdateElements();
if(fAnyElement) fAnyElement->UpdateElements();
if(fMuonElement) fMuonElement->UpdateElements();
+ if(fMultCorrElement) fMultCorrElement->UpdateElements();
//==============================================================================
void AliEveHLTEventManager::SaveEveryThing() {
- GetEventBuffer()->WriteToFile();
- //Save everything to file
- //fEventBuffer->SaveBlockList();
- //fEventBuffer->SaveAsyncBlockList();
-
-
+ //Print the screens
+ PrintScreens();
+ //Save block lists to file
+ GetEventBuffer()->WriteToFile(GetRunNumber());
}
gEve->AddElement(fPhosElement);
}
+void AliEveHLTEventManager::CreateMultCorrElement() {
+ fMultCorrElement = new AliHLTEveMultCorr("MultCorr");
+ fMultCorrElement->SetEventManager(this);
+ gEve->AddElement(fMultCorrElement);
+}
+
void AliEveHLTEventManager::CreateEmcalElement() {
fEmcalElement = new AliHLTEveEmcal();
fEmcalElement->SetEventManager(this);