#include "TEveTrackGL.h"
#include "TEveTrack.h"
#include "TEveTrackPropagator.h"
#include "TGLIncludes.h"
#include "TGLRnrCtx.h"
#include "TGLSelectRecord.h"
ClassImp(TEveTrackGL)
TEveTrackGL::TEveTrackGL() : TEveLineGL()
{
}
Bool_t TEveTrackGL::SetModel(TObject* obj, const Option_t* )
{
if (TEveLineGL::SetModel(obj) == kFALSE) return kFALSE;
if (SetModelCheckClass(obj, TEveTrack::Class())) {
fTrack = dynamic_cast<TEveTrack*>(obj);
return kTRUE;
}
return kFALSE;
}
Bool_t TEveTrackGL::ShouldDLCache(const TGLRnrCtx& rnrCtx) const
{
if (rnrCtx.Selection()) return kFALSE;
return fDLCache;
}
void TEveTrackGL::ProcessSelection(TGLRnrCtx & , TGLSelectRecord & rec)
{
printf("TEveTrackGL::ProcessSelection %d names on the stack (z1=%g, z2=%g).\n",
rec.GetN(), rec.GetMinZ(), rec.GetMaxZ());
printf(" Names: ");
for (Int_t j=0; j<rec.GetN(); ++j) printf ("%d ", rec.GetItem(j));
printf("\n");
((TEveTrack*)fM)->CtrlClicked((TEveTrack*)fM);
}
void TEveTrackGL::DirectDraw(TGLRnrCtx & rnrCtx) const
{
std::vector<TEvePathMark*>& pm = fTrack->fPathMarks;
TEveTrackPropagator& rTP = *fTrack->GetPropagator();
if (pm.size())
{
Float_t* pnts = new Float_t[3*pm.size()];
Int_t n = 0;
Bool_t accept;
for (std::vector<TEvePathMark*>::iterator i=pm.begin(); i!=pm.end(); ++i)
{
accept = kFALSE;
switch ((*i)->fType)
{
case TEvePathMark::kDaughter:
if (rTP.GetRnrDaughters()) accept = kTRUE;
break;
case TEvePathMark::kReference:
if (rTP.GetRnrReferences()) accept = kTRUE;
break;
case TEvePathMark::kDecay:
if (rTP.GetRnrDecay()) accept = kTRUE;
break;
}
if (accept)
{
if ((TMath::Abs((*i)->fV.fZ) < rTP.GetMaxZ()) && ((*i)->fV.Perp() < rTP.GetMaxR()))
{
pnts[3*n ] =(*i)->fV.fX;
pnts[3*n+1] =(*i)->fV.fY;
pnts[3*n+2] =(*i)->fV.fZ;
++n;
}
}
}
TGLUtil::RenderPolyMarkers(rTP.RefPMAtt(), pnts, n,
rnrCtx.GetPickRadius(),
rnrCtx.Selection());
delete [] pnts;
}
if (rTP.GetRnrFV() && fTrack->GetLastPoint())
TGLUtil::RenderPolyMarkers(rTP.RefFVAtt(), fTrack->GetP(), 1,
rnrCtx.GetPickRadius(),
rnrCtx.Selection());
TEveLineGL::DirectDraw(rnrCtx);
}
Last update: Thu Jan 17 08:49:28 2008
This page has been automatically generated. If you have any comments or suggestions about the page layout send a mail to ROOT support, or contact the developers with any questions or problems regarding ROOT.