#ifndef ROOT_TCurlyLine
#define ROOT_TCurlyLine
#ifndef ROOT_Riosfwd
#include "Riosfwd.h"
#endif
#ifndef ROOT_TPolyLine
#include "TPolyLine.h"
#endif
#ifndef ROOT_TAttBBox2D
#include "TAttBBox2D.h"
#endif
#ifndef ROOT_GuiTypes
#include "GuiTypes.h"
#endif
class TPoint;
class TCurlyLine : public TPolyLine , public TAttBBox2D {
protected:
Double_t fX1;
Double_t fY1;
Double_t fX2;
Double_t fY2;
Double_t fWaveLength;
Double_t fAmplitude;
Int_t fNsteps;
Bool_t fIsCurly;
static Double_t fgDefaultWaveLength;
static Double_t fgDefaultAmplitude;
static Bool_t fgDefaultIsCurly;
public:
TCurlyLine();
TCurlyLine(Double_t x1, Double_t y1, Double_t x2, Double_t y2,
Double_t wl = .02,
Double_t amp = .01);
virtual ~TCurlyLine(){;}
virtual void Build();
Int_t DistancetoPrimitive(Int_t px, Int_t py);
void ExecuteEvent(Int_t event, Int_t px, Int_t py);
Bool_t GetCurly() const {return fIsCurly;}
Double_t GetWaveLength() const{return fWaveLength;}
Double_t GetAmplitude() const {return fAmplitude;}
Double_t GetStartX() const {return fX1;}
Double_t GetEndX() const {return fX2;}
Double_t GetStartY() const {return fY1;}
Double_t GetEndY() const {return fY2;}
virtual void SetCurly();
virtual void SetWavy();
virtual void SetWaveLength(Double_t WaveLength);
virtual void SetAmplitude(Double_t x);
virtual void SetStartPoint(Double_t x1, Double_t y1);
virtual void SetEndPoint (Double_t x2, Double_t y2);
virtual void SavePrimitive(std::ostream &out, Option_t * = "");
static void SetDefaultWaveLength(Double_t WaveLength);
static void SetDefaultAmplitude (Double_t Amplitude );
static void SetDefaultIsCurly (Bool_t IsCurly );
static Double_t GetDefaultWaveLength();
static Double_t GetDefaultAmplitude ();
static Bool_t GetDefaultIsCurly ();
virtual Rectangle_t GetBBox();
virtual TPoint GetBBoxCenter();
virtual void SetBBoxCenter(const TPoint &p);
virtual void SetBBoxCenterX(const Int_t x);
virtual void SetBBoxCenterY(const Int_t y);
virtual void SetBBoxX1(const Int_t x);
virtual void SetBBoxX2(const Int_t x);
virtual void SetBBoxY1(const Int_t y);
virtual void SetBBoxY2(const Int_t y);
ClassDef(TCurlyLine,3)
};
#endif