80 fName =
"TPolyMarker3D";
88 fName =
"TPolyMarker3D";
110 fName =
"TPolyMarker3D";
138 fName =
"TPolyMarker3D";
183 if (
fP)
delete []
fP;
227 const Int_t inaxis = 7;
236 if (px < puxmin - inaxis)
return dist;
237 if (py > puymin + inaxis)
return dist;
238 if (px > puxmax + inaxis)
return dist;
239 if (py < puymax - inaxis)
return dist;
242 if (!view)
return dist;
247 for (i=0;i<
Size();i++) {
251 if (u < gPad->GetUxmin() || u >
gPad->GetUxmax())
continue;
252 if (v < gPad->GetUymin() ||
v >
gPad->GetUymax())
continue;
253 x1 =
gPad->XtoAbsPixel(u);
254 y1 =
gPad->YtoAbsPixel(
v);
278 newpolymarker->
fN =
n;
294 if (
gPad->GetView())
gPad->GetView()->ExecuteRotateView(event, px, py);
303 std::cout <<
" TPolyMarker3D N=" <<
Size() <<
" Option="<<option<<std::endl;
319 Error(
"Add",
"Attempt to add object of class: %s to a %s",pm->
ClassName(),this->ClassName());
322 npoints += pm->
Size();
334 for (
Int_t i = 0; i < np; i++) {
347 if (
Size() <= 0)
return;
362 if (!viewer3D)
return;
387 dlocal[0] = buffer.
fPnts[3*j];
388 dlocal[1] = buffer.
fPnts[3*j+1];
389 dlocal[2] = buffer.
fPnts[3*j+2];
391 buffer.
fPnts[3*j] = dmaster[0];
392 buffer.
fPnts[3*j+1] = dmaster[1];
393 buffer.
fPnts[3*j+2] = dmaster[2];
417 const Int_t kMaxEntry = 100000;
418 Int_t in, bin, binx, biny, binz;
420 TAxis *xaxis =
h->GetXaxis();
421 TAxis *yaxis =
h->GetYaxis();
422 TAxis *zaxis =
h->GetZaxis();
424 for (binz=zaxis->
GetFirst();binz<=zaxis->GetLast();binz++) {
425 for (biny=yaxis->
GetFirst();biny<=yaxis->GetLast();biny++) {
426 for (binx=xaxis->
GetFirst();binx<=xaxis->GetLast();binx++) {
427 bin =
h->GetBin(binx,biny,binz);
428 entry +=
h->GetBinContent(bin);
437 if (entry > kMaxEntry) scale = kMaxEntry/
Double_t(entry);
442 gPad->Range(-1,-1,1,1);
455 if (entry == 0)
return;
466 for (binz=zaxis->
GetFirst();binz<=zaxis->GetLast();binz++) {
469 for (biny=yaxis->
GetFirst();biny<=yaxis->GetLast();biny++) {
472 for (binx=xaxis->
GetFirst();binx<=xaxis->GetLast();binx++) {
475 bin =
h->GetBin(binx,biny,binz);
476 ncounts =
Int_t(
h->GetBinContent(bin)*scale+0.5);
477 for (in=0;in<ncounts;in++) {
496 printf(
"TPolyMarker3D N=%d, Option=%s\n",
fN,option);
502 printf(
" x[%d]=%g, y[%d]=%g, z[%d]=%g\n",i,
fP[3*i],i,
fP[3*i+1],i,
fP[3*i+2]);
517 out<<
" TPolyMarker3D *";
520 out<<
" pmarker3D->SetName("<<quote<<
GetName()<<quote<<
");"<<std::endl;
525 out<<
" pmarker3D->SetPoint("<<i<<
","<<
fP[3*i]<<
","<<
fP[3*i+1]<<
","<<
fP[3*i+2]<<
");"<<std::endl;
527 out<<
" pmarker3D->Draw();"<<std::endl;
561 if (!
fP ||
n >=
fN) {
595 if (
fP)
delete []
fP;
598 for (
Int_t i = 0; i <
fN; i++) {
600 fP[3*i+1] = p[3*i+1];
601 fP[3*i+2] = p[3*i+2];
625 if (
fP)
delete []
fP;
628 for (
Int_t i = 0; i <
fN; i++) {
642void TPolyMarker3D::Streamer(
TBuffer &
b)
647 if (R__v > 2)
b.ClassBegin(TPolyMarker3D::IsA());
648 if (R__v > 2)
b.ClassMember(
"TObject");
649 TObject::Streamer(
b);
650 if (R__v > 2)
b.ClassMember(
"TAttMarker");
651 TAttMarker::Streamer(
b);
652 if (R__v > 2)
b.ClassMember(
"fN",
"Int_t");
660 if (R__v > 2)
b.ClassMember(
"fOption",
"TString");
662 if (R__v > 2)
b.ClassMember(
"fName",
"TString");
663 if (R__v > 1)
fName.Streamer(
b);
664 if (R__v > 2)
b.ClassEnd(TPolyMarker3D::IsA());
665 b.CheckByteCount(R__s, R__c, TPolyMarker3D::IsA());
667 R__c =
b.WriteVersion(TPolyMarker3D::IsA(),
kTRUE);
668 b.ClassBegin(TPolyMarker3D::IsA());
669 b.ClassMember(
"TObject");
670 TObject::Streamer(
b);
671 b.ClassMember(
"TAttMarker");
672 TAttMarker::Streamer(
b);
673 b.ClassMember(
"fN",
"Int_t");
680 b.ClassMember(
"fOption",
"TString");
682 b.ClassMember(
"fName",
"TString");
684 b.ClassEnd(TPolyMarker3D::IsA());
685 b.SetByteCount(R__c,
kTRUE);
695 if (n < 0 || n >=
Size())
return;
708 if (n < 0 || n >=
Size())
return;
static const double x1[5]
R__EXTERN TGeometry * gGeometry
constexpr Int_t kDimension
Binding & operator=(OUT(*fun)(void))
R__EXTERN TRandom * gRandom
Use this attribute class when an object should have 3D capabilities.
virtual void SaveMarkerAttributes(std::ostream &out, const char *name, Int_t coldef=1, Int_t stydef=1, Int_t sizdef=1)
Save line attributes as C++ statement(s) on output stream out.
virtual void Modify()
Change current marker attributes if necessary.
virtual Style_t GetMarkerStyle() const
Return the marker style.
virtual void SetMarkerColor(Color_t mcolor=1)
Set the marker color.
virtual Color_t GetMarkerColor() const
Return the marker color.
virtual void SetMarkerStyle(Style_t mstyle=1)
Set the marker style.
virtual void SetMarkerSize(Size_t msize=1)
Set the marker size.
Class to manage histogram axis.
virtual Double_t GetBinLowEdge(Int_t bin) const
Return low edge of bin.
Int_t GetLast() const
Return last bin on the axis i.e.
virtual Double_t GetBinWidth(Int_t bin) const
Return bin width.
virtual Double_t GetBinUpEdge(Int_t bin) const
Return up edge of bin.
Int_t GetFirst() const
Return first bin on the axis i.e.
Generic 3D primitive description class.
Bool_t SectionsValid(UInt_t mask) const
void ClearSectionsValid()
Clear any sections marked valid.
void SetSectionsValid(UInt_t mask)
Bool_t SetRawSizes(UInt_t reqPnts, UInt_t reqPntsCapacity, UInt_t reqSegs, UInt_t reqSegsCapacity, UInt_t reqPols, UInt_t reqPolsCapacity)
Set kRaw tessellation section of buffer with supplied sizes.
Buffer base class used for serializing objects.
Collection abstract base class.
virtual void Local2Master(Double_t *local, Double_t *master)
Convert one point from local system to master reference system.
Mother of all ROOT objects.
TObject & operator=(const TObject &rhs)
TObject assignment operator.
R__ALWAYS_INLINE Bool_t TestBit(UInt_t f) const
virtual const char * ClassName() const
Returns name of class to which the object belongs.
virtual void AppendPad(Option_t *option="")
Append graphics object to current pad.
void SetBit(UInt_t f, Bool_t set)
Set or unset the user status bits as specified in f.
virtual Bool_t InheritsFrom(const char *classname) const
Returns kTRUE if object inherits from class "classname".
virtual void Copy(TObject &object) const
Copy this to obj.
virtual void Error(const char *method, const char *msgfmt,...) const
Issue error message.
@ kCanDelete
if object in a list can be deleted
@ kMustCleanup
if object destructor must call RecursiveRemove()
static void PaintH3(TH1 *h, Option_t *option)
Paint 3-d histogram h with 3-d polymarkers.
virtual Int_t Merge(TCollection *list)
Merge polymarkers in the collection in this polymarker.
virtual void SavePrimitive(std::ostream &out, Option_t *option="")
Save primitive as a C++ statement(s) on output stream.
virtual void DrawPolyMarker(Int_t n, Float_t *p, Marker_t marker, Option_t *option="")
Draw this 3-D polymarker with new coordinates.
void SetPoint(Int_t n, Double_t x, Double_t y, Double_t z)
Set point n to x, y, z.
virtual void GetPoint(Int_t n, Float_t &x, Float_t &y, Float_t &z) const
Fills the parameters x, y, z with the coordinate of the n-th point n must be between 0 and Size() - 1...
virtual void SetPolyMarker(Int_t n, Float_t *p, Marker_t marker, Option_t *option="")
Re-initialize polymarker with n points from p.
virtual ~TPolyMarker3D()
3-D polymarker destructor.
virtual Int_t Size() const
virtual const char * GetName() const
Returns name of object.
virtual void ExecuteEvent(Int_t event, Int_t px, Int_t py)
Execute action corresponding to one event.
virtual void SetName(const char *name)
Change (i.e.
TPolyMarker3D & operator=(const TPolyMarker3D &)
assignment operator
virtual void Paint(Option_t *option="")
Paint a TPolyMarker3D.
virtual Float_t * GetP() const
virtual void Copy(TObject &polymarker) const
Copy polymarker to polymarker obj.
virtual Int_t SetNextPoint(Double_t x, Double_t y, Double_t z)
Set point following LastPoint to x, y, z.
virtual void Print(Option_t *option="") const
Print 3-D polymarker with its attributes on stdout.
virtual void ls(Option_t *option="") const
List this 3-D polymarker.
Int_t DistancetoPrimitive(Int_t px, Int_t py)
Compute distance from point px,py to a 3-D polymarker.
virtual void Draw(Option_t *option="")
Draws 3-D polymarker with its current attributes.
TPolyMarker3D()
3-D polymarker default constructor.
static void IndentLevel()
Functions used by ls() to indent an object hierarchy.
virtual Double_t Rndm()
Machine independent random number generator.
void ToLower()
Change string to lower-case.
Bool_t Contains(const char *pat, ECaseCompare cmp=kExact) const
virtual void WCtoNDC(const Float_t *pw, Float_t *pn)=0
static TView * CreateView(Int_t system=1, const Double_t *rmin=0, const Double_t *rmax=0)
Create a concrete default 3-d view via the plug-in manager.
virtual void PadRange(Int_t rback)=0
virtual void SetRange(const Double_t *min, const Double_t *max)=0
Abstract 3D shapes viewer.
virtual Int_t AddObject(const TBuffer3D &buffer, Bool_t *addChildren=0)=0
double dist(Rotation3D const &r1, Rotation3D const &r2)
Short_t Max(Short_t a, Short_t b)
Double_t Sqrt(Double_t x)
Short_t Min(Short_t a, Short_t b)