// @(#):$Id$ // Author: M.Gheata /************************************************************************* * Copyright (C) 1995-2002, Rene Brun and Fons Rademakers. * * All rights reserved. * * * * For the licensing terms see $ROOTSYS/LICENSE. * * For the list of contributors see $ROOTSYS/README/CREDITS. * *************************************************************************/ ////////////////////////////////////////////////////////////////////////// // // // TGeoTrd2Editor // // // ////////////////////////////////////////////////////////////////////////// //Begin_Html /* */ //End_Html //Begin_Html /* */ //End_Html #include "TGeoTrd2Editor.h" #include "TGeoTabManager.h" #include "TGeoTrd2.h" #include "TGeoManager.h" #include "TVirtualGeoPainter.h" #include "TPad.h" #include "TView.h" #include "TGTab.h" #include "TGComboBox.h" #include "TGButton.h" #include "TGTextEntry.h" #include "TGNumberEntry.h" #include "TGLabel.h" ClassImp(TGeoTrd2Editor) enum ETGeoTrd2Wid { kTRD2_NAME, kTRD2_X1, kTRD2_X2, kTRD2_Y1, kTRD2_Y2, kTRD2_Z, kTRD2_APPLY, kTRD2_UNDO }; //______________________________________________________________________________ TGeoTrd2Editor::TGeoTrd2Editor(const TGWindow *p, Int_t width, Int_t height, UInt_t options, Pixel_t back) : TGeoGedFrame(p, width, height, options | kVerticalFrame, back) { // Constructor for trd2 editor fShape = 0; fDxi1 = fDxi2 = fDyi1 = fDyi2 = fDzi = 0.0; fNamei = ""; fIsModified = kFALSE; fIsShapeEditable = kFALSE; // TextEntry for shape name MakeTitle("Name"); fShapeName = new TGTextEntry(this, new TGTextBuffer(50), kTRD2_NAME); fShapeName->Resize(135, fShapeName->GetDefaultHeight()); fShapeName->SetToolTipText("Enter the box name"); fShapeName->Associate(this); AddFrame(fShapeName, new TGLayoutHints(kLHintsLeft, 3, 1, 2, 5)); TGTextEntry *nef; MakeTitle("Trd2 dimensions"); TGCompositeFrame *compxyz = new TGCompositeFrame(this, 118, 30, kVerticalFrame | kRaisedFrame | kDoubleBorder); // Number entry for dx1 TGCompositeFrame *f1 = new TGCompositeFrame(compxyz, 118, 10, kHorizontalFrame | kLHintsExpandX | kFixedWidth | kOwnBackground); f1->AddFrame(new TGLabel(f1, "DX1"), new TGLayoutHints(kLHintsLeft, 1, 1, 6, 0)); fEDx1 = new TGNumberEntry(f1, 0., 5, kTRD2_X1); fEDx1->SetNumAttr(TGNumberFormat::kNEAPositive); nef = (TGTextEntry*)fEDx1->GetNumberEntry(); nef->SetToolTipText("Enter the half-lenth in X1"); fEDx1->Associate(this); f1->AddFrame(fEDx1, new TGLayoutHints(kLHintsLeft | kLHintsExpandX , 2, 2, 4, 4)); compxyz->AddFrame(f1, new TGLayoutHints(kLHintsLeft | kLHintsExpandX , 2, 2, 4, 4)); // Number entry for dx2 f1 = new TGCompositeFrame(compxyz, 118, 10, kHorizontalFrame | kLHintsExpandX | kFixedWidth | kOwnBackground); f1->AddFrame(new TGLabel(f1, "DX2"), new TGLayoutHints(kLHintsLeft, 1, 1, 6, 0)); fEDx2 = new TGNumberEntry(f1, 0., 5, kTRD2_X2); fEDx2->SetNumAttr(TGNumberFormat::kNEAPositive); nef = (TGTextEntry*)fEDx2->GetNumberEntry(); nef->SetToolTipText("Enter the half-lenth in X2"); fEDx2->Associate(this); f1->AddFrame(fEDx2, new TGLayoutHints(kLHintsLeft | kLHintsExpandX , 2, 2, 4, 4)); compxyz->AddFrame(f1, new TGLayoutHints(kLHintsLeft | kLHintsExpandX , 2, 2, 4, 4)); // Number entry for dy1 TGCompositeFrame *f2 = new TGCompositeFrame(compxyz, 118, 10, kHorizontalFrame | kLHintsExpandX | kFixedWidth | kOwnBackground); f2->AddFrame(new TGLabel(f2, "DY1"), new TGLayoutHints(kLHintsLeft, 1, 1, 6, 0)); fEDy1 = new TGNumberEntry(f2, 0., 5, kTRD2_Y1); fEDy1->SetNumAttr(TGNumberFormat::kNEAPositive); nef = (TGTextEntry*)fEDy1->GetNumberEntry(); nef->SetToolTipText("Enter the half-lenth in Y1"); fEDy1->Associate(this); f2->AddFrame(fEDy1, new TGLayoutHints(kLHintsLeft | kLHintsExpandX , 2, 2, 4, 4)); compxyz->AddFrame(f2, new TGLayoutHints(kLHintsLeft | kLHintsExpandX , 2, 2, 4, 4)); // Number entry for dy2 f2 = new TGCompositeFrame(compxyz, 118, 10, kHorizontalFrame | kLHintsExpandX | kFixedWidth | kOwnBackground); f2->AddFrame(new TGLabel(f2, "DY2"), new TGLayoutHints(kLHintsLeft, 1, 1, 6, 0)); fEDy2 = new TGNumberEntry(f2, 0., 5, kTRD2_Y2); fEDy2->SetNumAttr(TGNumberFormat::kNEAPositive); nef = (TGTextEntry*)fEDy2->GetNumberEntry(); nef->SetToolTipText("Enter the half-lenth in Y2"); fEDy2->Associate(this); f2->AddFrame(fEDy2, new TGLayoutHints(kLHintsLeft | kLHintsExpandX , 2, 2, 4, 4)); compxyz->AddFrame(f2, new TGLayoutHints(kLHintsLeft | kLHintsExpandX , 2, 2, 4, 4)); // Number entry for dz TGCompositeFrame *f3 = new TGCompositeFrame(compxyz, 118, 10, kHorizontalFrame | kLHintsExpandX | kFixedWidth | kOwnBackground); f3->AddFrame(new TGLabel(f3, "DZ"), new TGLayoutHints(kLHintsLeft, 1, 1, 6, 0)); fEDz = new TGNumberEntry(f3, 0., 5, kTRD2_Z); fEDz->SetNumAttr(TGNumberFormat::kNEAPositive); nef = (TGTextEntry*)fEDz->GetNumberEntry(); nef->SetToolTipText("Enter the half-lenth in Z"); fEDz->Associate(this); f3->AddFrame(fEDz, new TGLayoutHints(kLHintsLeft | kLHintsExpandX , 2, 2, 4, 4)); compxyz->AddFrame(f3, new TGLayoutHints(kLHintsLeft | kLHintsExpandX , 2, 2, 4, 4)); compxyz->Resize(150,30); AddFrame(compxyz, new TGLayoutHints(kLHintsLeft, 6, 6, 4, 4)); // Delayed draw f1 = new TGCompositeFrame(this, 155, 10, kHorizontalFrame | kFixedWidth | kSunkenFrame); fDelayed = new TGCheckButton(f1, "Delayed draw"); f1->AddFrame(fDelayed, new TGLayoutHints(kLHintsLeft , 2, 2, 4, 4)); AddFrame(f1, new TGLayoutHints(kLHintsLeft, 6, 6, 4, 4)); // Buttons f1 = new TGCompositeFrame(this, 155, 10, kHorizontalFrame | kFixedWidth); fApply = new TGTextButton(f1, "Apply"); f1->AddFrame(fApply, new TGLayoutHints(kLHintsLeft, 2, 2, 4, 4)); fApply->Associate(this); fUndo = new TGTextButton(f1, "Undo"); f1->AddFrame(fUndo, new TGLayoutHints(kLHintsRight , 2, 2, 4, 4)); fUndo->Associate(this); AddFrame(f1, new TGLayoutHints(kLHintsLeft, 6, 6, 4, 4)); fUndo->SetSize(fApply->GetSize()); } //______________________________________________________________________________ TGeoTrd2Editor::~TGeoTrd2Editor() { // Destructor. TGFrameElement *el; TIter next(GetList()); while ((el = (TGFrameElement *)next())) { if (el->fFrame->IsComposite()) TGeoTabManager::Cleanup((TGCompositeFrame*)el->fFrame); } Cleanup(); } //______________________________________________________________________________ void TGeoTrd2Editor::ConnectSignals2Slots() { // Connect signals to slots. fApply->Connect("Clicked()", "TGeoTrd2Editor", this, "DoApply()"); fUndo->Connect("Clicked()", "TGeoTrd2Editor", this, "DoUndo()"); fShapeName->Connect("TextChanged(const char *)", "TGeoTrd2Editor", this, "DoModified()"); fEDx1->Connect("ValueSet(Long_t)", "TGeoTrd2Editor", this, "DoDx1()"); fEDx2->Connect("ValueSet(Long_t)", "TGeoTrd2Editor", this, "DoDx2()"); fEDy1->Connect("ValueSet(Long_t)", "TGeoTrd2Editor", this, "DoDy1()"); fEDy2->Connect("ValueSet(Long_t)", "TGeoTrd2Editor", this, "DoDy2()"); fEDz->Connect("ValueSet(Long_t)", "TGeoTrd2Editor", this, "DoDz()"); fEDx1->GetNumberEntry()->Connect("TextChanged(const char *)", "TGeoTrd2Editor", this, "DoModified()"); fEDx2->GetNumberEntry()->Connect("TextChanged(const char *)", "TGeoTrd2Editor", this, "DoModified()"); fEDy1->GetNumberEntry()->Connect("TextChanged(const char *)", "TGeoTrd2Editor", this, "DoModified()"); fEDy2->GetNumberEntry()->Connect("TextChanged(const char *)", "TGeoTrd2Editor", this, "DoModified()"); fEDz->GetNumberEntry()->Connect("TextChanged(const char *)", "TGeoTrd2Editor", this, "DoModified()"); fInit = kFALSE; } //______________________________________________________________________________ void TGeoTrd2Editor::SetModel(TObject* obj) { // Connect to the selected object. if (obj == 0 || (obj->IsA()!=TGeoTrd2::Class())) { SetActive(kFALSE); return; } fShape = (TGeoTrd2*)obj; fDxi1 = fShape->GetDx1(); fDxi2 = fShape->GetDx2(); fDyi1 = fShape->GetDy1(); fDyi2 = fShape->GetDy2(); fDzi = fShape->GetDz(); const char *sname = fShape->GetName(); if (!strcmp(sname, fShape->ClassName())) fShapeName->SetText("-no_name"); else { fShapeName->SetText(sname); fNamei = sname; } fEDx1->SetNumber(fDxi1); fEDx2->SetNumber(fDxi2); fEDy1->SetNumber(fDyi1); fEDy2->SetNumber(fDyi2); fEDz->SetNumber(fDzi); fApply->SetEnabled(kFALSE); fUndo->SetEnabled(kFALSE); if (fInit) ConnectSignals2Slots(); SetActive(); } //______________________________________________________________________________ Bool_t TGeoTrd2Editor::IsDelayed() const { // Check if shape drawing is delayed. return (fDelayed->GetState() == kButtonDown); } //______________________________________________________________________________ void TGeoTrd2Editor::DoName() { // Perform name change. DoModified(); } //______________________________________________________________________________ void TGeoTrd2Editor::DoApply() { // Slot for applying modifications. const char *name = fShapeName->GetText(); if (strcmp(name,fShape->GetName())) fShape->SetName(name); Double_t dx1 = fEDx1->GetNumber(); Double_t dx2 = fEDx2->GetNumber(); Double_t dy1 = fEDy1->GetNumber(); Double_t dy2 = fEDy2->GetNumber(); Double_t dz = fEDz->GetNumber(); Double_t param[5]; param[0] = dx1; param[1] = dx2; param[2] = dy1; param[3] = dy2; param[4] = dz; fShape->SetDimensions(param); fShape->ComputeBBox(); fUndo->SetEnabled(); fApply->SetEnabled(kFALSE); if (fPad) { if (gGeoManager && gGeoManager->GetPainter() && gGeoManager->GetPainter()->IsPaintingShape()) { fShape->Draw(); fPad->GetView()->ShowAxis(); } else Update(); } } //______________________________________________________________________________ void TGeoTrd2Editor::DoModified() { // Slot for signaling modifications. fApply->SetEnabled(); } //______________________________________________________________________________ void TGeoTrd2Editor::DoUndo() { // Slot for undoing last operation. fEDx1->SetNumber(fDxi1); fEDx2->SetNumber(fDxi2); fEDy1->SetNumber(fDyi1); fEDy2->SetNumber(fDyi2); fEDz->SetNumber(fDzi); DoApply(); fUndo->SetEnabled(kFALSE); fApply->SetEnabled(kFALSE); } //______________________________________________________________________________ void TGeoTrd2Editor::DoDx1() { // Slot for dx1. Double_t dx1 = fEDx1->GetNumber(); Double_t dx2 = fEDx2->GetNumber(); if (dx1<0) { dx1 = 0; fEDx1->SetNumber(dx1); } if (dx1<1.e-6 && dx2<1.e-6) { dx1 = 0.1; fEDx1->SetNumber(dx1); } DoModified(); if (!IsDelayed()) DoApply(); } //______________________________________________________________________________ void TGeoTrd2Editor::DoDx2() { // Slot for dx2. Double_t dx1 = fEDx1->GetNumber(); Double_t dx2 = fEDx2->GetNumber(); if (dx2<0) { dx2 = 0; fEDx2->SetNumber(dx2); } if (dx1<1.e-6 && dx2<1.e-6) { dx2 = 0.1; fEDx2->SetNumber(dx2); } DoModified(); if (!IsDelayed()) DoApply(); } //______________________________________________________________________________ void TGeoTrd2Editor::DoDy1() { // Slot for dy1. Double_t dy1 = fEDy1->GetNumber(); Double_t dy2 = fEDy2->GetNumber(); if (dy1<0) { dy1 = 0; fEDy1->SetNumber(dy1); } if (dy1<1.e-6 && dy2<1.e-6) { dy1 = 0.1; fEDy1->SetNumber(dy1); } DoModified(); if (!IsDelayed()) DoApply(); } //______________________________________________________________________________ void TGeoTrd2Editor::DoDy2() { // Slot for dy2. Double_t dy1 = fEDy1->GetNumber(); Double_t dy2 = fEDy2->GetNumber(); if (dy2<0) { dy2 = 0; fEDy2->SetNumber(dy2); } if (dy1<1.e-6 && dy2<1.e-6) { dy2 = 0.1; fEDy2->SetNumber(dy2); } DoModified(); if (!IsDelayed()) DoApply(); } //______________________________________________________________________________ void TGeoTrd2Editor::DoDz() { // Slot for dz. Double_t dz = fEDz->GetNumber(); if (dz<=0) { dz = 0.1; fEDz->SetNumber(dz); } DoModified(); if (!IsDelayed()) DoApply(); }