Logo ROOT  
Reference Guide
TCurlyArc.h
Go to the documentation of this file.
1// @(#)root/graf:$Id$
2// Author: Otto Schaile 20/11/99
3
4/*************************************************************************
5 * Copyright (C) 1995-2000, Rene Brun and Fons Rademakers. *
6 * All rights reserved. *
7 * *
8 * For the licensing terms see $ROOTSYS/LICENSE. *
9 * For the list of contributors see $ROOTSYS/README/CREDITS. *
10 *************************************************************************/
11#ifndef ROOT_TCurlyArc
12#define ROOT_TCurlyArc
13
14#include "GuiTypes.h"
15
16class TPoint;
17
18#include "TCurlyLine.h"
19
20class TCurlyArc : public TCurlyLine {
21
22private:
23 Double_t fR1; ///< Radius of arc
24 Double_t fPhimin; ///< start phi (degrees)
25 Double_t fPhimax; ///< end phi (degrees)
26 Double_t fTheta; ///< used internally
27
28 static Double_t fgDefaultWaveLength; ///< default wavelength
29 static Double_t fgDefaultAmplitude; ///< default amplitude
30 static Bool_t fgDefaultIsCurly; ///< default curly type
31
32public:
33 TCurlyArc();
35 Double_t phimin, Double_t phimax,
36 Double_t wl = .02, Double_t amp = .01);
37 virtual ~TCurlyArc(){;}
38 virtual void Build();
40 void ExecuteEvent(Int_t event, Int_t px, Int_t py);
41 Double_t GetRadius() const {return fR1;}
42 Double_t GetPhimin() const {return fPhimin;}
43 Double_t GetPhimax() const {return fPhimax;}
44 virtual void SetCenter(Double_t x1, Double_t y1); // *MENU* *ARGS={x1=>fX1,y1=>fY1}
45 virtual void SetRadius(Double_t radius); // *MENU* *ARGS={radius=>fR1}
46 virtual void SetPhimin(Double_t phimin); // *MENU* *ARGS={phimin=>fPhimin}
47 virtual void SetPhimax(Double_t phimax); // *MENU* *ARGS={phimax=>fPhimax}
48 virtual void SavePrimitive(std::ostream &out, Option_t * = "");
49
50 static void SetDefaultWaveLength(Double_t WaveLength);
51 static void SetDefaultAmplitude (Double_t Amplitude );
52 static void SetDefaultIsCurly (Bool_t IsCurly );
55 static Bool_t GetDefaultIsCurly ();
56 virtual Rectangle_t GetBBox();
57 virtual TPoint GetBBoxCenter();
58 virtual void SetBBoxCenter(const TPoint &p);
59 virtual void SetBBoxCenterX(const Int_t x);
60 virtual void SetBBoxCenterY(const Int_t y);
61 virtual void SetBBoxX1(const Int_t x);
62 virtual void SetBBoxX2(const Int_t x);
63 virtual void SetBBoxY1(const Int_t y);
64 virtual void SetBBoxY2(const Int_t y);
65
66 ClassDef(TCurlyArc,3) // A curly arc
67};
68
69#endif
70
static const double x1[5]
int Int_t
Definition: RtypesCore.h:41
bool Bool_t
Definition: RtypesCore.h:59
double Double_t
Definition: RtypesCore.h:55
const char Option_t
Definition: RtypesCore.h:62
#define ClassDef(name, id)
Definition: Rtypes.h:326
Implements curly or wavy arcs used to draw Feynman diagrams.
Definition: TCurlyArc.h:20
virtual void SetBBoxX2(const Int_t x)
Set right hand side of BoundingBox to a value (resize in x direction on right)
Definition: TCurlyArc.cxx:585
virtual TPoint GetBBoxCenter()
Return the center of the BoundingBox as TPoint in pixels.
Definition: TCurlyArc.cxx:532
Double_t GetPhimax() const
Definition: TCurlyArc.h:43
virtual void Build()
Create a curly (Gluon) or wavy (Gamma) arc.
Definition: TCurlyArc.cxx:75
virtual void SetRadius(Double_t radius)
Set Curly Arc radius.
Definition: TCurlyArc.cxx:442
static Bool_t GetDefaultIsCurly()
Get default "IsCurly".
Definition: TCurlyArc.cxx:509
virtual void SavePrimitive(std::ostream &out, Option_t *="")
Save primitive as a C++ statement(s) on output stream out.
Definition: TCurlyArc.cxx:412
virtual void SetPhimin(Double_t phimin)
Set Curly Arc minimum Phi.
Definition: TCurlyArc.cxx:451
Double_t fTheta
used internally
Definition: TCurlyArc.h:26
static Double_t GetDefaultWaveLength()
Get default wave length.
Definition: TCurlyArc.cxx:493
virtual void SetBBoxY2(const Int_t y)
Set bottom of BoundingBox to a value (resize in y direction on bottom)
Definition: TCurlyArc.cxx:612
virtual void SetCenter(Double_t x1, Double_t y1)
Set Curly Arc center.
Definition: TCurlyArc.cxx:432
Double_t fPhimax
end phi (degrees)
Definition: TCurlyArc.h:25
void ExecuteEvent(Int_t event, Int_t px, Int_t py)
Execute action corresponding to one event.
Definition: TCurlyArc.cxx:155
Double_t GetRadius() const
Definition: TCurlyArc.h:41
TCurlyArc()
Default constructor.
Definition: TCurlyArc.cxx:45
Int_t DistancetoPrimitive(Int_t px, Int_t py)
Compute distance from point px,py to an arc.
Definition: TCurlyArc.cxx:123
static Double_t fgDefaultWaveLength
default wavelength
Definition: TCurlyArc.h:28
static void SetDefaultWaveLength(Double_t WaveLength)
Set default wave length.
Definition: TCurlyArc.cxx:469
static void SetDefaultAmplitude(Double_t Amplitude)
Set default wave amplitude.
Definition: TCurlyArc.cxx:477
Double_t fPhimin
start phi (degrees)
Definition: TCurlyArc.h:24
Double_t fR1
Radius of arc.
Definition: TCurlyArc.h:23
virtual void SetBBoxY1(const Int_t y)
Set top of BoundingBox to a value (resize in y direction on top)
Definition: TCurlyArc.cxx:597
static Double_t fgDefaultAmplitude
default amplitude
Definition: TCurlyArc.h:29
virtual void SetBBoxCenter(const TPoint &p)
Set center of the BoundingBox.
Definition: TCurlyArc.cxx:543
static Double_t GetDefaultAmplitude()
Get default wave amplitude.
Definition: TCurlyArc.cxx:501
static void SetDefaultIsCurly(Bool_t IsCurly)
Set default "IsCurly".
Definition: TCurlyArc.cxx:485
virtual void SetBBoxCenterY(const Int_t y)
Set Y coordinate of the center of the BoundingBox.
Definition: TCurlyArc.cxx:562
static Bool_t fgDefaultIsCurly
default curly type
Definition: TCurlyArc.h:30
virtual Rectangle_t GetBBox()
Return the bounding Box of the Line.
Definition: TCurlyArc.cxx:517
virtual void SetBBoxCenterX(const Int_t x)
Set X coordinate of the center of the BoundingBox.
Definition: TCurlyArc.cxx:553
Double_t GetPhimin() const
Definition: TCurlyArc.h:42
virtual void SetBBoxX1(const Int_t x)
Set left hand side of BoundingBox to a value (resize in x direction on left)
Definition: TCurlyArc.cxx:572
virtual void SetPhimax(Double_t phimax)
Set Curly Arc maximum Phi.
Definition: TCurlyArc.cxx:460
virtual ~TCurlyArc()
Definition: TCurlyArc.h:37
Implements curly or wavy polylines used to draw Feynman diagrams.
Definition: TCurlyLine.h:21
Definition: TPoint.h:31
Double_t y[n]
Definition: legend1.C:17
Double_t x[n]
Definition: legend1.C:17
static constexpr double rad