//Begin_Html
/*
<img src="gif/TCurlyArcEditor.gif">
*/
//End_Html
#include "TCurlyArcEditor.h"
#include "TGComboBox.h"
#include "TGLabel.h"
#include "TGNumberEntry.h"
#include "TCurlyArc.h"
#include "TVirtualPad.h"
#include "iostream"
#include "TClass.h"
ClassImp(TCurlyArcEditor)
enum ECurlyArcWid {
kCRLA_RAD,
kCRLA_FMIN,
kCRLA_FMAX,
kCRLA_CX,
kCRLA_CY
};
TCurlyArcEditor::TCurlyArcEditor(const TGWindow *p, Int_t width,
Int_t height, UInt_t options, Pixel_t back)
: TGedFrame(p, width, height, options | kVerticalFrame, back)
{
fCurlyArc = 0;
MakeTitle("Curly Arc");
TGCompositeFrame *f3 = new TGCompositeFrame(this, 80, 20, kHorizontalFrame);
AddFrame(f3, new TGLayoutHints(kLHintsTop, 1, 1, 3, 0));
TGLabel *fRadiusLabel = new TGLabel(f3, "Radius:");
f3->AddFrame(fRadiusLabel, new TGLayoutHints(kLHintsLeft | kLHintsCenterY, 8, 0, 1, 1));
fRadiusEntry = new TGNumberEntry(f3, 0.02, 7, kCRLA_RAD,
TGNumberFormat::kNESRealThree,
TGNumberFormat::kNEANonNegative,
TGNumberFormat::kNELNoLimits);
fRadiusEntry->GetNumberEntry()->SetToolTipText("Set radius of arc.");
f3->AddFrame(fRadiusEntry, new TGLayoutHints(kLHintsLeft, 18, 1, 1, 1));
TGCompositeFrame *f4 = new TGCompositeFrame(this, 80, 20, kHorizontalFrame);
AddFrame(f4, new TGLayoutHints(kLHintsTop, 1, 1, 3, 0));
TGLabel *fPhiminLabel = new TGLabel(f4, "Phimin:");
f4->AddFrame(fPhiminLabel, new TGLayoutHints(kLHintsLeft | kLHintsCenterY, 8, 0, 1, 1));
fPhiminEntry = new TGNumberEntry(f4, 0, 7, kCRLA_FMIN,
TGNumberFormat::kNESInteger,
TGNumberFormat::kNEANonNegative,
TGNumberFormat::kNELLimitMinMax, 0, 360);
fPhiminEntry->GetNumberEntry()->SetToolTipText("Set Phimin in degrees.");
f4->AddFrame(fPhiminEntry, new TGLayoutHints(kLHintsLeft, 19, 1, 1, 1));
TGCompositeFrame *f5 = new TGCompositeFrame(this, 80, 20, kHorizontalFrame);
AddFrame(f5, new TGLayoutHints(kLHintsTop, 1, 1, 3, 0));
TGLabel *fPhimaxLabel = new TGLabel(f5, "Phimax:");
f5->AddFrame(fPhimaxLabel, new TGLayoutHints(kLHintsLeft | kLHintsCenterY, 8, 0, 1, 1));
fPhimaxEntry = new TGNumberEntry(f5, 0, 7, kCRLA_FMAX,
TGNumberFormat::kNESInteger,
TGNumberFormat::kNEANonNegative,
TGNumberFormat::kNELLimitMinMax, 0, 360);
fPhimaxEntry->GetNumberEntry()->SetToolTipText("Set Phimax in degrees.");
f5->AddFrame(fPhimaxEntry, new TGLayoutHints(kLHintsLeft, 16, 1, 1, 1));
TGCompositeFrame *f6 = new TGCompositeFrame(this, 80, 20, kHorizontalFrame);
AddFrame(f6, new TGLayoutHints(kLHintsTop, 1, 1, 3, 0));
TGLabel *fCenterXLabel = new TGLabel(f6, "Center X:");
f6->AddFrame(fCenterXLabel, new TGLayoutHints(kLHintsLeft | kLHintsCenterY, 8, 0, 1, 1));
fCenterXEntry = new TGNumberEntry(f6, 0.0, 7, kCRLA_CX,
TGNumberFormat::kNESRealThree,
TGNumberFormat::kNEANonNegative,
TGNumberFormat::kNELNoLimits);
fCenterXEntry->GetNumberEntry()->SetToolTipText("Set center X coordinate.");
f6->AddFrame(fCenterXEntry, new TGLayoutHints(kLHintsLeft, 6, 1, 1, 1));
TGCompositeFrame *f7 = new TGCompositeFrame(this, 80, 20, kHorizontalFrame);
AddFrame(f7, new TGLayoutHints(kLHintsTop, 1, 1, 3, 0));
TGLabel *fCenterYLabel = new TGLabel(f7, "Y:");
f7->AddFrame(fCenterYLabel, new TGLayoutHints(kLHintsLeft | kLHintsCenterY, 48, 0, 1, 1));
fCenterYEntry = new TGNumberEntry(f7, 0.0, 7, kCRLA_CY,
TGNumberFormat::kNESRealThree,
TGNumberFormat::kNEANonNegative,
TGNumberFormat::kNELNoLimits);
fCenterYEntry->GetNumberEntry()->SetToolTipText("Set center Y coordinate.");
f7->AddFrame(fCenterYEntry, new TGLayoutHints(kLHintsLeft, 7, 1, 1, 1));
}
TCurlyArcEditor::~TCurlyArcEditor()
{
}
void TCurlyArcEditor::ConnectSignals2Slots()
{
fCenterXEntry->Connect("ValueSet(Long_t)", "TCurlyArcEditor", this, "DoCenterXY()");
(fCenterXEntry->GetNumberEntry())->Connect("ReturnPressed()", "TCurlyArcEditor", this, "DoCenterXY()");
fCenterYEntry->Connect("ValueSet(Long_t)", "TCurlyArcEditor", this, "DoCenterXY()");
(fCenterYEntry->GetNumberEntry())->Connect("ReturnPressed()", "TCurlyArcEditor", this, "DoCenterXY()");
fRadiusEntry->Connect("ValueSet(Long_t)", "TCurlyArcEditor", this, "DoRadius()");
(fRadiusEntry->GetNumberEntry())->Connect("ReturnPressed()", "TCurlyArcEditor", this, "DoRadius()");
fPhiminEntry->Connect("ValueSet(Long_t)", "TCurlyArcEditor", this, "DoPhimin()");
(fPhiminEntry->GetNumberEntry())->Connect("ReturnPressed()", "TCurlyArcEditor", this, "DoPhimin()");
fPhimaxEntry->Connect("ValueSet(Long_t)", "TCurlyArcEditor", this, "DoPhimax()");
(fPhimaxEntry->GetNumberEntry())->Connect("ReturnPressed()", "TCurlyArcEditor", this, "DoPhimax()");
fInit = kFALSE;
}
void TCurlyArcEditor::SetModel(TObject* obj)
{
fCurlyArc = (TCurlyArc *)obj;
fAvoidSignal = kTRUE;
Double_t val = fCurlyArc->GetRadius();
fRadiusEntry->SetNumber(val);
val = fCurlyArc->GetPhimin();
fPhiminEntry->SetNumber(val);
val = fCurlyArc->GetPhimax();
fPhimaxEntry->SetNumber(val);
val = fCurlyArc->GetStartX();
fCenterXEntry->SetNumber(val);
val = fCurlyArc->GetStartY();
fCenterYEntry->SetNumber(val);
if (fInit) ConnectSignals2Slots();
fAvoidSignal = kFALSE;
}
void TCurlyArcEditor::DoCenterXY()
{
if (fAvoidSignal) return;
fCurlyArc->SetCenter((Double_t)fCenterXEntry->GetNumber(), (Double_t)fCenterYEntry->GetNumber());
fCurlyArc->Paint(fCurlyArc->GetDrawOption());
Update();
}
void TCurlyArcEditor::DoRadius()
{
if (fAvoidSignal) return;
fCurlyArc->SetRadius((Double_t)fRadiusEntry->GetNumber());
fCurlyArc->Paint(fCurlyArc->GetDrawOption());
Update();
}
void TCurlyArcEditor::DoPhimin()
{
if (fAvoidSignal) return;
fCurlyArc->SetPhimin((Double_t)fPhiminEntry->GetNumber());
fCurlyArc->Paint(fCurlyArc->GetDrawOption());
Update();
}
void TCurlyArcEditor::DoPhimax()
{
if (fAvoidSignal) return;
fCurlyArc->SetPhimax((Double_t)fPhimaxEntry->GetNumber());
fCurlyArc->Paint(fCurlyArc->GetDrawOption());
Update();
}
ROOT page - Class index - Class Hierarchy - Top of the page
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.