ROOT logo
// @(#):$Id: TGeoConeEditor.cxx 20882 2007-11-19 11:31:26Z rdm $
// 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.             *
 *************************************************************************/

//////////////////////////////////////////////////////////////////////////
//                                                                      //
//  TGeoConeEditor                                                      //
//                                                                      //
//////////////////////////////////////////////////////////////////////////
//Begin_Html
/*
<img src="gif/cone_pic.gif">
*/
//End_Html
//Begin_Html
/*
<img src="gif/cone_ed.jpg">
*/
//End_Html

#include "TGeoConeEditor.h"
#include "TGeoTabManager.h"
#include "TGeoCone.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"
#include "TGDoubleSlider.h"

ClassImp(TGeoConeEditor)

enum ETGeoConeWid {
   kCONE_NAME, kCONE_RMIN1, kCONE_RMIN2, kCONE_RMAX1, kCONE_RMAX2, kCONE_Z,
   kCONE_APPLY, kCONE_UNDO
};

//______________________________________________________________________________
TGeoConeEditor::TGeoConeEditor(const TGWindow *p, Int_t width,
                                   Int_t height, UInt_t options, Pixel_t back)
   : TGeoGedFrame(p, width, height, options | kVerticalFrame, back)
{
   // Constructor for volume editor
   fShape   = 0;
   fRmini1 = fRmaxi1 = fRmini2 = fRmaxi2 = fDzi = 0.0;
   fNamei = "";
   fIsModified = kFALSE;
   fIsShapeEditable = kTRUE;

   // TextEntry for shape name
   MakeTitle("Name");
   fShapeName = new TGTextEntry(this, new TGTextBuffer(50), kCONE_NAME);
   fShapeName->Resize(135, fShapeName->GetDefaultHeight());
   fShapeName->SetToolTipText("Enter the cone name");
   fShapeName->Associate(this);
   AddFrame(fShapeName, new TGLayoutHints(kLHintsLeft, 3, 1, 2, 5));

   TGTextEntry *nef;
   MakeTitle("Cone dimensions");
   TGCompositeFrame *compxyz = new TGCompositeFrame(this, 118, 30, kVerticalFrame | kRaisedFrame);
   
   // Number entry for Rmin1
   TGCompositeFrame *f1 = new TGCompositeFrame(compxyz, 155, 30, kHorizontalFrame | kFixedWidth);
   f1->AddFrame(new TGLabel(f1, "Rmin1"), new TGLayoutHints(kLHintsLeft, 1, 1, 6, 0));
   fERmin1 = new TGNumberEntry(f1, 0., 5, kCONE_RMIN1);
   fERmin1->SetNumAttr(TGNumberFormat::kNEANonNegative);
   nef = (TGTextEntry*)fERmin1->GetNumberEntry();
   nef->SetToolTipText("Enter the inner radius");
   fERmin1->Associate(this);
   fERmin1->Resize(100, fERmin1->GetDefaultHeight());
   f1->AddFrame(fERmin1, new TGLayoutHints(kLHintsRight, 2, 2, 2, 2));
   compxyz->AddFrame(f1, new TGLayoutHints(kLHintsLeft, 2, 2, 0, 0));
   
  // Number entry for Rmax1
   f1 = new TGCompositeFrame(compxyz, 155, 30, kHorizontalFrame | kFixedWidth);
   f1->AddFrame(new TGLabel(f1, "Rmax1"), new TGLayoutHints(kLHintsLeft, 1, 1, 6, 0));
   fERmax1 = new TGNumberEntry(f1, 0., 5, kCONE_RMAX1);
   fERmax1->SetNumAttr(TGNumberFormat::kNEANonNegative);
   nef = (TGTextEntry*)fERmax1->GetNumberEntry();
   nef->SetToolTipText("Enter the outer radius");
   fERmax1->Associate(this);
   fERmax1->Resize(100, fERmax1->GetDefaultHeight());
   f1->AddFrame(fERmax1, new TGLayoutHints(kLHintsRight, 2, 2, 2, 2));
   compxyz->AddFrame(f1, new TGLayoutHints(kLHintsLeft, 2, 2, 0, 0));
    
   // Number entry for Rmin2
   f1 = new TGCompositeFrame(compxyz, 155, 30, kHorizontalFrame | kFixedWidth);
   f1->AddFrame(new TGLabel(f1, "Rmin2"), new TGLayoutHints(kLHintsLeft, 1, 1, 6, 0));
   fERmin2 = new TGNumberEntry(f1, 0., 5, kCONE_RMIN2);
   fERmin2->SetNumAttr(TGNumberFormat::kNEANonNegative);
   nef = (TGTextEntry*)fERmin2->GetNumberEntry();
   nef->SetToolTipText("Enter the inner radius");
   fERmin2->Associate(this);
   fERmin2->Resize(100, fERmin2->GetDefaultHeight());
   f1->AddFrame(fERmin2, new TGLayoutHints(kLHintsRight, 2, 2, 2, 2));
   compxyz->AddFrame(f1, new TGLayoutHints(kLHintsLeft, 2, 2, 0, 0));
    
   // Number entry for Rmax2
   f1 = new TGCompositeFrame(compxyz, 155, 30, kHorizontalFrame | kFixedWidth);
   f1->AddFrame(new TGLabel(f1, "Rmax2"), new TGLayoutHints(kLHintsLeft, 1, 1, 6, 0));
   fERmax2 = new TGNumberEntry(f1, 0., 5, kCONE_RMAX2);
   fERmax2->SetNumAttr(TGNumberFormat::kNEANonNegative);
   nef = (TGTextEntry*)fERmax1->GetNumberEntry();
   nef->SetToolTipText("Enter the outer radius");
   fERmax2->Associate(this);
   fERmax2->Resize(100, fERmax2->GetDefaultHeight());
   f1->AddFrame(fERmax2, new TGLayoutHints(kLHintsRight, 2, 2, 2, 2));
   compxyz->AddFrame(f1, new TGLayoutHints(kLHintsLeft, 2, 2, 0, 0));
   
   // Number entry for dz
   f1 = new TGCompositeFrame(compxyz, 155, 30, kHorizontalFrame | kFixedWidth);
   f1->AddFrame(new TGLabel(f1, "DZ"), new TGLayoutHints(kLHintsLeft, 1, 1, 6, 0));
   fEDz = new TGNumberEntry(f1, 0., 5, kCONE_Z);
   fEDz->SetNumAttr(TGNumberFormat::kNEAPositive);
   nef = (TGTextEntry*)fEDz->GetNumberEntry();
   nef->SetToolTipText("Enter the cone half-lenth in Z");
   fEDz->Associate(this);
   fEDz->Resize(100, fEDz->GetDefaultHeight());
   f1->AddFrame(fEDz, new TGLayoutHints(kLHintsRight, 2, 2, 2, 2));
   compxyz->AddFrame(f1, new TGLayoutHints(kLHintsLeft, 2, 2, 0, 0));
   
   compxyz->Resize(150,30);
   AddFrame(compxyz, new TGLayoutHints(kLHintsLeft, 6, 6, 4, 4));
      
   // Delayed draw
   fDFrame = new TGCompositeFrame(this, 155, 10, kHorizontalFrame | kFixedWidth | kSunkenFrame);
   fDelayed = new TGCheckButton(fDFrame, "Delayed draw");
   fDFrame->AddFrame(fDelayed, new TGLayoutHints(kLHintsLeft , 2, 2, 2, 2));
   AddFrame(fDFrame,  new TGLayoutHints(kLHintsLeft, 6, 6, 4, 4));  

   // Buttons
   fBFrame = new TGCompositeFrame(this, 155, 10, kHorizontalFrame | kFixedWidth);
   fApply = new TGTextButton(fBFrame, "Apply");
   fBFrame->AddFrame(fApply, new TGLayoutHints(kLHintsLeft, 2, 2, 4, 4));
   fApply->Associate(this);
   fUndo = new TGTextButton(fBFrame, "Undo");
   fBFrame->AddFrame(fUndo, new TGLayoutHints(kLHintsRight , 2, 2, 4, 4));
   fUndo->Associate(this);
   AddFrame(fBFrame,  new TGLayoutHints(kLHintsLeft, 6, 6, 4, 4));  
   fUndo->SetSize(fApply->GetSize());
}

//______________________________________________________________________________
TGeoConeEditor::~TGeoConeEditor()
{
// Destructor
   TGFrameElement *el;
   TIter next(GetList());
   while ((el = (TGFrameElement *)next())) {
      if (el->fFrame->IsComposite()) 
         TGeoTabManager::Cleanup((TGCompositeFrame*)el->fFrame);
   }
   Cleanup();   
}

//______________________________________________________________________________
void TGeoConeEditor::ConnectSignals2Slots()
{
   // Connect signals to slots.
   fApply->Connect("Clicked()", "TGeoConeEditor", this, "DoApply()");
   fUndo->Connect("Clicked()", "TGeoConeEditor", this, "DoUndo()");
   fShapeName->Connect("TextChanged(const char *)", "TGeoConeEditor", this, "DoModified()");
   fERmin1->Connect("ValueSet(Long_t)", "TGeoConeEditor", this, "DoRmin1()");
   fERmin2->Connect("ValueSet(Long_t)", "TGeoConeEditor", this, "DoRmin2()");
   fERmax1->Connect("ValueSet(Long_t)", "TGeoConeEditor", this, "DoRmax1()");
   fERmax2->Connect("ValueSet(Long_t)", "TGeoConeEditor", this, "DoRmax2()");
   fEDz->Connect("ValueSet(Long_t)", "TGeoConeEditor", this, "DoDz()");
   fERmin1->GetNumberEntry()->Connect("TextChanged(const char *)", "TGeoConeEditor", this, "DoRmin1()");
   fERmin2->GetNumberEntry()->Connect("TextChanged(const char *)", "TGeoConeEditor", this, "DoRmin2()");
   fERmax1->GetNumberEntry()->Connect("TextChanged(const char *)", "TGeoConeEditor", this, "DoRmax1()");
   fERmax2->GetNumberEntry()->Connect("TextChanged(const char *)", "TGeoConeEditor", this, "DoRmax2()");
   fEDz->GetNumberEntry()->Connect("TextChanged(const char *)", "TGeoConeEditor", this, "DoDz()");
   fInit = kFALSE;
}


//______________________________________________________________________________
void TGeoConeEditor::SetModel(TObject* obj)
{
   // Connect to the selected object.
   if (obj == 0 || (obj->IsA()!=TGeoCone::Class())) {
      SetActive(kFALSE);
      return;                 
   } 
   fShape = (TGeoCone*)obj;
   fRmini1 = fShape->GetRmin1();
   fRmini2 = fShape->GetRmin2();
   fRmaxi1 = fShape->GetRmax1();
   fRmaxi2 = fShape->GetRmax2();
   fDzi = fShape->GetDz();
   fNamei = fShape->GetName();
   fShapeName->SetText(fShape->GetName());
   fERmin1->SetNumber(fRmini1);
   fERmin2->SetNumber(fRmini2);
   fERmax1->SetNumber(fRmaxi1);
   fERmax2->SetNumber(fRmaxi2);
   fEDz->SetNumber(fDzi);
   fApply->SetEnabled(kFALSE);
   fUndo->SetEnabled(kFALSE);
   
   if (fInit) ConnectSignals2Slots();
   SetActive();
}

//______________________________________________________________________________
Bool_t TGeoConeEditor::IsDelayed() const
{
// Check if shape drawing is delayed.
   return (fDelayed->GetState() == kButtonDown);
}

//______________________________________________________________________________
void TGeoConeEditor::DoName()
{
   // Slot for name.
   DoModified();
}

//______________________________________________________________________________
void TGeoConeEditor::DoApply()
{
   //Slot for applying current parameters.
   fApply->SetEnabled(kFALSE);
   const char *name = fShapeName->GetText();
   if (strcmp(name,fShape->GetName())) fShape->SetName(name);
   Double_t rmin1 = fERmin1->GetNumber();
   Double_t rmin2 = fERmin2->GetNumber();
   Double_t rmax1 = fERmax1->GetNumber();
   Double_t rmax2 = fERmax2->GetNumber();
   Double_t dz = fEDz->GetNumber();
   if (rmin1<0 || rmin1>rmax1) return; 
   if (rmin2<0 || rmin2>rmax2) return;
   if (dz<=0) return;
   if (rmin1==rmax1 && rmin2==rmax2) return; 
   fShape->SetConeDimensions(dz, rmin1, rmax1, rmin2, rmax2);
   fShape->ComputeBBox();
   fUndo->SetEnabled();
   if (fPad) {
      if (gGeoManager && gGeoManager->GetPainter() && gGeoManager->GetPainter()->IsPaintingShape()) {
         fShape->Draw();
         fPad->GetView()->ShowAxis();
      } else Update();
   }   
}

//______________________________________________________________________________
void TGeoConeEditor::DoModified()
{
   //Slot for modifing current parameters.
   fApply->SetEnabled();
}

//______________________________________________________________________________
void TGeoConeEditor::DoUndo()
{
   // Slot for undoing current operation.
   fERmin1->SetNumber(fRmini1);
   fERmin2->SetNumber(fRmini2);
   fERmax1->SetNumber(fRmaxi1);
   fERmax2->SetNumber(fRmaxi2);
   fEDz->SetNumber(fDzi);
   DoApply();
   fUndo->SetEnabled(kFALSE);
   fApply->SetEnabled(kFALSE);
}
   
//______________________________________________________________________________
void TGeoConeEditor::DoRmin1()
{
   // Slot for Rmin1
   Double_t rmin1 = fERmin1->GetNumber();
   Double_t rmax1 = fERmax1->GetNumber();
   if (rmin1<0) {
      rmin1 = 0;
      fERmin1->SetNumber(rmin1);
   }   
   if (rmin1>rmax1) {
      rmin1 = rmax1;
      fERmin1->SetNumber(rmin1);
   }   
   DoModified();
   if (!IsDelayed()) DoApply();
}

//______________________________________________________________________________
void TGeoConeEditor::DoRmax1()
{
   // Slot for Rmax1
   Double_t rmin1 = fERmin1->GetNumber();
   Double_t rmax1 = fERmax1->GetNumber();
   if (rmax1<rmin1) {
      rmax1 = rmin1;
      fERmax1->SetNumber(rmax1);
   }   
   DoModified();
   if (!IsDelayed()) DoApply();
}

//______________________________________________________________________________
void TGeoConeEditor::DoRmin2()
{
   // Slot for Rmin2
   Double_t rmin2 = fERmin2->GetNumber();
   Double_t rmax2 = fERmax2->GetNumber();
   if (rmin2<0) {
      rmin2 = 0;
      fERmin2->SetNumber(rmin2);
   }   
   if (rmin2>rmax2) {
      rmin2 = rmax2;
      fERmin2->SetNumber(rmin2);
   }   
   DoModified();
   if (!IsDelayed()) DoApply();
}

//______________________________________________________________________________
void TGeoConeEditor::DoRmax2()
{
   // Slot for  Rmax2
   Double_t rmin2 = fERmin2->GetNumber();
   Double_t rmax2 = fERmax2->GetNumber();
   if (rmax2<rmin2) {
      rmax2 = rmin2;
      fERmax2->SetNumber(rmax2);
   }   
   DoModified();
   if (!IsDelayed()) DoApply();
}

//______________________________________________________________________________
void TGeoConeEditor::DoDz()
{
   // Slot for Dz
   Double_t dz = fEDz->GetNumber();
   if (dz<=0) {
      dz = 0.1;
      fEDz->SetNumber(dz);
   }   
   DoModified();
   if (!IsDelayed()) DoApply();
}

//////////////////////////////////////////////////////////////////////////
//                                                                      //
//  TGeoConeSegEditor                                                   //
//                                                                      //
//////////////////////////////////////////////////////////////////////////
//Begin_Html
/*
<img src="gif/cons_pic.gif">
*/
//End_Html
//Begin_Html
/*
<img src="gif/cons_ed.jpg">
*/
//End_Html

ClassImp(TGeoConeSegEditor)

enum ETGeoConeSegWid {
   kCONESEG_PHI1, kCONESEG_PHI2, kCONESEG_PHI
};

//______________________________________________________________________________
TGeoConeSegEditor::TGeoConeSegEditor(const TGWindow *p, Int_t width,
                                   Int_t height, UInt_t options, Pixel_t back)
                 : TGeoConeEditor(p, width, height, options | kVerticalFrame, back)
{
   // Constructor for cone segment editor
   fLock = kFALSE;
   MakeTitle("Phi range");
   TGTextEntry *nef;
   TGCompositeFrame *compxyz = new TGCompositeFrame(this, 155, 110, kHorizontalFrame | kFixedWidth | kFixedHeight | kRaisedFrame);
   // Vertical slider
   fSPhi = new TGDoubleVSlider(compxyz,100);
   fSPhi->SetRange(0.,720.);
   fSPhi->Resize(fSPhi->GetDefaultWidth(), 100);
   compxyz->AddFrame(fSPhi, new TGLayoutHints(kLHintsLeft, 2, 2, 4, 4)); 
   TGCompositeFrame *f1 = new TGCompositeFrame(compxyz, 135, 100, kVerticalFrame | kFixedHeight);
   f1->AddFrame(new TGLabel(f1, "Phi min."), new TGLayoutHints(kLHintsTop | kLHintsLeft, 0, 0, 6, 0));
   fEPhi1 = new TGNumberEntry(f1, 0., 5, kCONESEG_PHI1);
   fEPhi1->Resize(100, fEPhi1->GetDefaultHeight());
   fEPhi1->SetNumAttr(TGNumberFormat::kNEANonNegative);
   nef = (TGTextEntry*)fEPhi1->GetNumberEntry();
   nef->SetToolTipText("Enter the phi1 value");
   fEPhi1->Associate(this);
   f1->AddFrame(fEPhi1, new TGLayoutHints(kLHintsTop | kLHintsRight, 2, 2, 2, 2));

   fEPhi2 = new TGNumberEntry(f1, 0., 5, kCONESEG_PHI2);
   fEPhi2->Resize(100, fEPhi2->GetDefaultHeight());
   fEPhi2->SetNumAttr(TGNumberFormat::kNEANonNegative);
   nef = (TGTextEntry*)fEPhi2->GetNumberEntry();
   nef->SetToolTipText("Enter the phi2 value");
   fEPhi2->Associate(this);
   f1->AddFrame(fEPhi2, new TGLayoutHints(kLHintsBottom | kLHintsRight, 2, 2, 2, 2));
   f1->AddFrame(new TGLabel(f1, "Phi max."), new TGLayoutHints(kLHintsBottom, 0, 0, 6, 2));
   compxyz->AddFrame(f1, new TGLayoutHints(kLHintsLeft, 2, 2, 4, 4));
   
//   compxyz->Resize(150,150);
   AddFrame(compxyz, new TGLayoutHints(kLHintsLeft, 6, 6, 4, 4));
   TGeoTabManager::MoveFrame(fDFrame, this);
   TGeoTabManager::MoveFrame(fBFrame, this);
}

//______________________________________________________________________________
TGeoConeSegEditor::~TGeoConeSegEditor()
{
// Destructor
   TGFrameElement *el;
   TIter next(GetList());
   while ((el = (TGFrameElement *)next())) {
      if (el->fFrame->IsComposite()) 
         TGeoTabManager::Cleanup((TGCompositeFrame*)el->fFrame);
   }
   Cleanup();   
}

//______________________________________________________________________________
void TGeoConeSegEditor::ConnectSignals2Slots()
{
   // Connect signals to slots.
   TGeoConeEditor::ConnectSignals2Slots();
   Disconnect(fApply, "Clicked()",(TGeoConeEditor*)this, "DoApply()");
   Disconnect(fUndo, "Clicked()",(TGeoConeEditor*)this, "DoUndo()");
   fApply->Connect("Clicked()", "TGeoConeSegEditor", this, "DoApply()");
   fUndo->Connect("Clicked()", "TGeoConeSegEditor", this, "DoUndo()");
   fEPhi1->Connect("ValueSet(Long_t)", "TGeoConeSegEditor", this, "DoPhi1()");
   fEPhi2->Connect("ValueSet(Long_t)", "TGeoConeSegEditor", this, "DoPhi2()");
//   fEPhi1->GetNumberEntry()->Connect("TextChanged(const char *)","TGeoConeSegEditor", this, "DoPhi1()");
//   fEPhi2->GetNumberEntry()->Connect("TextChanged(const char *)","TGeoConeSegEditor", this, "DoPhi2()");
   fSPhi->Connect("PositionChanged()","TGeoConeSegEditor", this, "DoPhi()");
}

//______________________________________________________________________________
void TGeoConeSegEditor::SetModel(TObject* obj)
{
   // Connect to the selected object.
   if (obj == 0 || (obj->IsA()!=TGeoConeSeg::Class())) {
      SetActive(kFALSE);
      return;                 
   } 
   fShape = (TGeoCone*)obj;
   fRmini1 = fShape->GetRmin1();
   fRmaxi1 = fShape->GetRmax1();
   fRmini2 = fShape->GetRmin2();
   fRmaxi2 = fShape->GetRmax2();
   fDzi = fShape->GetDz();
   fNamei = fShape->GetName();
   fPmini = ((TGeoConeSeg*)fShape)->GetPhi1();
   fPmaxi = ((TGeoConeSeg*)fShape)->GetPhi2();
   fShapeName->SetText(fShape->GetName());
   fEPhi1->SetNumber(fPmini);
   fEPhi2->SetNumber(fPmaxi);
   fSPhi->SetPosition(fPmini,fPmaxi);
   fERmin1->SetNumber(fRmini1);
   fERmax1->SetNumber(fRmaxi1);
   fERmin2->SetNumber(fRmini2);
   fERmax2->SetNumber(fRmaxi2);
   fEDz->SetNumber(fDzi);
   fApply->SetEnabled(kFALSE);
   fUndo->SetEnabled(kFALSE);
   
   if (fInit) ConnectSignals2Slots();
   SetActive();
}

//______________________________________________________________________________
void TGeoConeSegEditor::DoPhi1()
{
   //Slot for Phi1
   Double_t phi1 = fEPhi1->GetNumber();
   Double_t phi2 = fEPhi2->GetNumber();
   if (phi1 > 360-1.e-10) {
      phi1 = 0.;
      fEPhi1->SetNumber(phi1);
   }   
   if (phi2<phi1+1.e-10) {
      phi1 = phi2 - 0.1;
      fEPhi1->SetNumber(phi1);
   }   
   if (!fLock) {
      DoModified();
      fLock = kTRUE;
      fSPhi->SetPosition(phi1,phi2);
   } else fLock = kFALSE;
   if (!IsDelayed()) DoApply();
}

//______________________________________________________________________________
void TGeoConeSegEditor::DoPhi2()
{
   // Slot for Phi2
   Double_t phi1 = fEPhi1->GetNumber();
   Double_t phi2 = fEPhi2->GetNumber();
   if (phi2-phi1 > 360.) {
      phi2 -= 360.;
      fEPhi2->SetNumber(phi2);
   }   
   if (phi2<phi1+1.e-10) {
      phi2 = phi1 + 0.1;
      fEPhi2->SetNumber(phi2);
   }   
   if (!fLock) {
      DoModified();
      fLock = kTRUE;
      fSPhi->SetPosition(phi1,phi2);
   } else fLock = kFALSE;
   if (!IsDelayed()) DoApply();
}

//______________________________________________________________________________
void TGeoConeSegEditor::DoPhi()
{
   // Slot for Phi
   if (!fLock) {
      DoModified();
      fLock = kTRUE;
      fEPhi1->SetNumber(fSPhi->GetMinPosition());
      fLock = kTRUE;
      fEPhi2->SetNumber(fSPhi->GetMaxPosition());
   } else fLock = kFALSE;   
   if (!IsDelayed()) DoApply();
}

//______________________________________________________________________________
void TGeoConeSegEditor::DoApply()
{
   // Slot for applying current parameters.
   fApply->SetEnabled(kFALSE);
   const char *name = fShapeName->GetText();
   if (strcmp(name,fShape->GetName())) fShape->SetName(name);
   Double_t rmin1 = fERmin1->GetNumber();
   Double_t rmax1 = fERmax1->GetNumber();
   if (rmin1<0 || rmax1<rmin1) return;
   Double_t rmin2 = fERmin2->GetNumber();
   Double_t rmax2 = fERmax2->GetNumber();
   if (rmin2<0 || rmax2<rmin2) return;
   Double_t dz = fEDz->GetNumber();
   Double_t phi1 = fEPhi1->GetNumber();
   Double_t phi2 = fEPhi2->GetNumber();
   if ((phi2-phi1) > 360.001) {
      phi1 = 0.;
      phi2 = 360.;
      fEPhi1->SetNumber(phi1);
      fEPhi2->SetNumber(phi2);
      fLock = kTRUE;
      fSPhi->SetPosition(phi1,phi2);
      fLock = kFALSE;
   }   
   ((TGeoConeSeg*)fShape)->SetConsDimensions(dz, rmin1, rmax1, rmin2,rmax2, phi1, phi2);
   fShape->ComputeBBox();
   fUndo->SetEnabled();
   if (fPad) {
      if (gGeoManager && gGeoManager->GetPainter() && gGeoManager->GetPainter()->IsPaintingShape()) {
         fShape->Draw();
         fPad->GetView()->ShowAxis();
      } else Update();
   }   
}

//______________________________________________________________________________
void TGeoConeSegEditor::DoUndo()
{
   // Slot for undoing last operation.
   fERmin1->SetNumber(fRmini1);
   fERmin2->SetNumber(fRmini2);
   fERmax1->SetNumber(fRmaxi1);
   fERmax2->SetNumber(fRmaxi2);
   fEDz->SetNumber(fDzi);
   fEPhi1->SetNumber(fPmini);
   fEPhi2->SetNumber(fPmaxi);
   fSPhi->SetPosition(fPmini,fPmaxi);
   DoApply();
   fUndo->SetEnabled(kFALSE);
   fApply->SetEnabled(kFALSE);
}



   
 TGeoConeEditor.cxx:1
 TGeoConeEditor.cxx:2
 TGeoConeEditor.cxx:3
 TGeoConeEditor.cxx:4
 TGeoConeEditor.cxx:5
 TGeoConeEditor.cxx:6
 TGeoConeEditor.cxx:7
 TGeoConeEditor.cxx:8
 TGeoConeEditor.cxx:9
 TGeoConeEditor.cxx:10
 TGeoConeEditor.cxx:11
 TGeoConeEditor.cxx:12
 TGeoConeEditor.cxx:13
 TGeoConeEditor.cxx:14
 TGeoConeEditor.cxx:15
 TGeoConeEditor.cxx:16
 TGeoConeEditor.cxx:17
 TGeoConeEditor.cxx:18
 TGeoConeEditor.cxx:19
 TGeoConeEditor.cxx:20
 TGeoConeEditor.cxx:21
 TGeoConeEditor.cxx:22
 TGeoConeEditor.cxx:23
 TGeoConeEditor.cxx:24
 TGeoConeEditor.cxx:25
 TGeoConeEditor.cxx:26
 TGeoConeEditor.cxx:27
 TGeoConeEditor.cxx:28
 TGeoConeEditor.cxx:29
 TGeoConeEditor.cxx:30
 TGeoConeEditor.cxx:31
 TGeoConeEditor.cxx:32
 TGeoConeEditor.cxx:33
 TGeoConeEditor.cxx:34
 TGeoConeEditor.cxx:35
 TGeoConeEditor.cxx:36
 TGeoConeEditor.cxx:37
 TGeoConeEditor.cxx:38
 TGeoConeEditor.cxx:39
 TGeoConeEditor.cxx:40
 TGeoConeEditor.cxx:41
 TGeoConeEditor.cxx:42
 TGeoConeEditor.cxx:43
 TGeoConeEditor.cxx:44
 TGeoConeEditor.cxx:45
 TGeoConeEditor.cxx:46
 TGeoConeEditor.cxx:47
 TGeoConeEditor.cxx:48
 TGeoConeEditor.cxx:49
 TGeoConeEditor.cxx:50
 TGeoConeEditor.cxx:51
 TGeoConeEditor.cxx:52
 TGeoConeEditor.cxx:53
 TGeoConeEditor.cxx:54
 TGeoConeEditor.cxx:55
 TGeoConeEditor.cxx:56
 TGeoConeEditor.cxx:57
 TGeoConeEditor.cxx:58
 TGeoConeEditor.cxx:59
 TGeoConeEditor.cxx:60
 TGeoConeEditor.cxx:61
 TGeoConeEditor.cxx:62
 TGeoConeEditor.cxx:63
 TGeoConeEditor.cxx:64
 TGeoConeEditor.cxx:65
 TGeoConeEditor.cxx:66
 TGeoConeEditor.cxx:67
 TGeoConeEditor.cxx:68
 TGeoConeEditor.cxx:69
 TGeoConeEditor.cxx:70
 TGeoConeEditor.cxx:71
 TGeoConeEditor.cxx:72
 TGeoConeEditor.cxx:73
 TGeoConeEditor.cxx:74
 TGeoConeEditor.cxx:75
 TGeoConeEditor.cxx:76
 TGeoConeEditor.cxx:77
 TGeoConeEditor.cxx:78
 TGeoConeEditor.cxx:79
 TGeoConeEditor.cxx:80
 TGeoConeEditor.cxx:81
 TGeoConeEditor.cxx:82
 TGeoConeEditor.cxx:83
 TGeoConeEditor.cxx:84
 TGeoConeEditor.cxx:85
 TGeoConeEditor.cxx:86
 TGeoConeEditor.cxx:87
 TGeoConeEditor.cxx:88
 TGeoConeEditor.cxx:89
 TGeoConeEditor.cxx:90
 TGeoConeEditor.cxx:91
 TGeoConeEditor.cxx:92
 TGeoConeEditor.cxx:93
 TGeoConeEditor.cxx:94
 TGeoConeEditor.cxx:95
 TGeoConeEditor.cxx:96
 TGeoConeEditor.cxx:97
 TGeoConeEditor.cxx:98
 TGeoConeEditor.cxx:99
 TGeoConeEditor.cxx:100
 TGeoConeEditor.cxx:101
 TGeoConeEditor.cxx:102
 TGeoConeEditor.cxx:103
 TGeoConeEditor.cxx:104
 TGeoConeEditor.cxx:105
 TGeoConeEditor.cxx:106
 TGeoConeEditor.cxx:107
 TGeoConeEditor.cxx:108
 TGeoConeEditor.cxx:109
 TGeoConeEditor.cxx:110
 TGeoConeEditor.cxx:111
 TGeoConeEditor.cxx:112
 TGeoConeEditor.cxx:113
 TGeoConeEditor.cxx:114
 TGeoConeEditor.cxx:115
 TGeoConeEditor.cxx:116
 TGeoConeEditor.cxx:117
 TGeoConeEditor.cxx:118
 TGeoConeEditor.cxx:119
 TGeoConeEditor.cxx:120
 TGeoConeEditor.cxx:121
 TGeoConeEditor.cxx:122
 TGeoConeEditor.cxx:123
 TGeoConeEditor.cxx:124
 TGeoConeEditor.cxx:125
 TGeoConeEditor.cxx:126
 TGeoConeEditor.cxx:127
 TGeoConeEditor.cxx:128
 TGeoConeEditor.cxx:129
 TGeoConeEditor.cxx:130
 TGeoConeEditor.cxx:131
 TGeoConeEditor.cxx:132
 TGeoConeEditor.cxx:133
 TGeoConeEditor.cxx:134
 TGeoConeEditor.cxx:135
 TGeoConeEditor.cxx:136
 TGeoConeEditor.cxx:137
 TGeoConeEditor.cxx:138
 TGeoConeEditor.cxx:139
 TGeoConeEditor.cxx:140
 TGeoConeEditor.cxx:141
 TGeoConeEditor.cxx:142
 TGeoConeEditor.cxx:143
 TGeoConeEditor.cxx:144
 TGeoConeEditor.cxx:145
 TGeoConeEditor.cxx:146
 TGeoConeEditor.cxx:147
 TGeoConeEditor.cxx:148
 TGeoConeEditor.cxx:149
 TGeoConeEditor.cxx:150
 TGeoConeEditor.cxx:151
 TGeoConeEditor.cxx:152
 TGeoConeEditor.cxx:153
 TGeoConeEditor.cxx:154
 TGeoConeEditor.cxx:155
 TGeoConeEditor.cxx:156
 TGeoConeEditor.cxx:157
 TGeoConeEditor.cxx:158
 TGeoConeEditor.cxx:159
 TGeoConeEditor.cxx:160
 TGeoConeEditor.cxx:161
 TGeoConeEditor.cxx:162
 TGeoConeEditor.cxx:163
 TGeoConeEditor.cxx:164
 TGeoConeEditor.cxx:165
 TGeoConeEditor.cxx:166
 TGeoConeEditor.cxx:167
 TGeoConeEditor.cxx:168
 TGeoConeEditor.cxx:169
 TGeoConeEditor.cxx:170
 TGeoConeEditor.cxx:171
 TGeoConeEditor.cxx:172
 TGeoConeEditor.cxx:173
 TGeoConeEditor.cxx:174
 TGeoConeEditor.cxx:175
 TGeoConeEditor.cxx:176
 TGeoConeEditor.cxx:177
 TGeoConeEditor.cxx:178
 TGeoConeEditor.cxx:179
 TGeoConeEditor.cxx:180
 TGeoConeEditor.cxx:181
 TGeoConeEditor.cxx:182
 TGeoConeEditor.cxx:183
 TGeoConeEditor.cxx:184
 TGeoConeEditor.cxx:185
 TGeoConeEditor.cxx:186
 TGeoConeEditor.cxx:187
 TGeoConeEditor.cxx:188
 TGeoConeEditor.cxx:189
 TGeoConeEditor.cxx:190
 TGeoConeEditor.cxx:191
 TGeoConeEditor.cxx:192
 TGeoConeEditor.cxx:193
 TGeoConeEditor.cxx:194
 TGeoConeEditor.cxx:195
 TGeoConeEditor.cxx:196
 TGeoConeEditor.cxx:197
 TGeoConeEditor.cxx:198
 TGeoConeEditor.cxx:199
 TGeoConeEditor.cxx:200
 TGeoConeEditor.cxx:201
 TGeoConeEditor.cxx:202
 TGeoConeEditor.cxx:203
 TGeoConeEditor.cxx:204
 TGeoConeEditor.cxx:205
 TGeoConeEditor.cxx:206
 TGeoConeEditor.cxx:207
 TGeoConeEditor.cxx:208
 TGeoConeEditor.cxx:209
 TGeoConeEditor.cxx:210
 TGeoConeEditor.cxx:211
 TGeoConeEditor.cxx:212
 TGeoConeEditor.cxx:213
 TGeoConeEditor.cxx:214
 TGeoConeEditor.cxx:215
 TGeoConeEditor.cxx:216
 TGeoConeEditor.cxx:217
 TGeoConeEditor.cxx:218
 TGeoConeEditor.cxx:219
 TGeoConeEditor.cxx:220
 TGeoConeEditor.cxx:221
 TGeoConeEditor.cxx:222
 TGeoConeEditor.cxx:223
 TGeoConeEditor.cxx:224
 TGeoConeEditor.cxx:225
 TGeoConeEditor.cxx:226
 TGeoConeEditor.cxx:227
 TGeoConeEditor.cxx:228
 TGeoConeEditor.cxx:229
 TGeoConeEditor.cxx:230
 TGeoConeEditor.cxx:231
 TGeoConeEditor.cxx:232
 TGeoConeEditor.cxx:233
 TGeoConeEditor.cxx:234
 TGeoConeEditor.cxx:235
 TGeoConeEditor.cxx:236
 TGeoConeEditor.cxx:237
 TGeoConeEditor.cxx:238
 TGeoConeEditor.cxx:239
 TGeoConeEditor.cxx:240
 TGeoConeEditor.cxx:241
 TGeoConeEditor.cxx:242
 TGeoConeEditor.cxx:243
 TGeoConeEditor.cxx:244
 TGeoConeEditor.cxx:245
 TGeoConeEditor.cxx:246
 TGeoConeEditor.cxx:247
 TGeoConeEditor.cxx:248
 TGeoConeEditor.cxx:249
 TGeoConeEditor.cxx:250
 TGeoConeEditor.cxx:251
 TGeoConeEditor.cxx:252
 TGeoConeEditor.cxx:253
 TGeoConeEditor.cxx:254
 TGeoConeEditor.cxx:255
 TGeoConeEditor.cxx:256
 TGeoConeEditor.cxx:257
 TGeoConeEditor.cxx:258
 TGeoConeEditor.cxx:259
 TGeoConeEditor.cxx:260
 TGeoConeEditor.cxx:261
 TGeoConeEditor.cxx:262
 TGeoConeEditor.cxx:263
 TGeoConeEditor.cxx:264
 TGeoConeEditor.cxx:265
 TGeoConeEditor.cxx:266
 TGeoConeEditor.cxx:267
 TGeoConeEditor.cxx:268
 TGeoConeEditor.cxx:269
 TGeoConeEditor.cxx:270
 TGeoConeEditor.cxx:271
 TGeoConeEditor.cxx:272
 TGeoConeEditor.cxx:273
 TGeoConeEditor.cxx:274
 TGeoConeEditor.cxx:275
 TGeoConeEditor.cxx:276
 TGeoConeEditor.cxx:277
 TGeoConeEditor.cxx:278
 TGeoConeEditor.cxx:279
 TGeoConeEditor.cxx:280
 TGeoConeEditor.cxx:281
 TGeoConeEditor.cxx:282
 TGeoConeEditor.cxx:283
 TGeoConeEditor.cxx:284
 TGeoConeEditor.cxx:285
 TGeoConeEditor.cxx:286
 TGeoConeEditor.cxx:287
 TGeoConeEditor.cxx:288
 TGeoConeEditor.cxx:289
 TGeoConeEditor.cxx:290
 TGeoConeEditor.cxx:291
 TGeoConeEditor.cxx:292
 TGeoConeEditor.cxx:293
 TGeoConeEditor.cxx:294
 TGeoConeEditor.cxx:295
 TGeoConeEditor.cxx:296
 TGeoConeEditor.cxx:297
 TGeoConeEditor.cxx:298
 TGeoConeEditor.cxx:299
 TGeoConeEditor.cxx:300
 TGeoConeEditor.cxx:301
 TGeoConeEditor.cxx:302
 TGeoConeEditor.cxx:303
 TGeoConeEditor.cxx:304
 TGeoConeEditor.cxx:305
 TGeoConeEditor.cxx:306
 TGeoConeEditor.cxx:307
 TGeoConeEditor.cxx:308
 TGeoConeEditor.cxx:309
 TGeoConeEditor.cxx:310
 TGeoConeEditor.cxx:311
 TGeoConeEditor.cxx:312
 TGeoConeEditor.cxx:313
 TGeoConeEditor.cxx:314
 TGeoConeEditor.cxx:315
 TGeoConeEditor.cxx:316
 TGeoConeEditor.cxx:317
 TGeoConeEditor.cxx:318
 TGeoConeEditor.cxx:319
 TGeoConeEditor.cxx:320
 TGeoConeEditor.cxx:321
 TGeoConeEditor.cxx:322
 TGeoConeEditor.cxx:323
 TGeoConeEditor.cxx:324
 TGeoConeEditor.cxx:325
 TGeoConeEditor.cxx:326
 TGeoConeEditor.cxx:327
 TGeoConeEditor.cxx:328
 TGeoConeEditor.cxx:329
 TGeoConeEditor.cxx:330
 TGeoConeEditor.cxx:331
 TGeoConeEditor.cxx:332
 TGeoConeEditor.cxx:333
 TGeoConeEditor.cxx:334
 TGeoConeEditor.cxx:335
 TGeoConeEditor.cxx:336
 TGeoConeEditor.cxx:337
 TGeoConeEditor.cxx:338
 TGeoConeEditor.cxx:339
 TGeoConeEditor.cxx:340
 TGeoConeEditor.cxx:341
 TGeoConeEditor.cxx:342
 TGeoConeEditor.cxx:343
 TGeoConeEditor.cxx:344
 TGeoConeEditor.cxx:345
 TGeoConeEditor.cxx:346
 TGeoConeEditor.cxx:347
 TGeoConeEditor.cxx:348
 TGeoConeEditor.cxx:349
 TGeoConeEditor.cxx:350
 TGeoConeEditor.cxx:351
 TGeoConeEditor.cxx:352
 TGeoConeEditor.cxx:353
 TGeoConeEditor.cxx:354
 TGeoConeEditor.cxx:355
 TGeoConeEditor.cxx:356
 TGeoConeEditor.cxx:357
 TGeoConeEditor.cxx:358
 TGeoConeEditor.cxx:359
 TGeoConeEditor.cxx:360
 TGeoConeEditor.cxx:361
 TGeoConeEditor.cxx:362
 TGeoConeEditor.cxx:363
 TGeoConeEditor.cxx:364
 TGeoConeEditor.cxx:365
 TGeoConeEditor.cxx:366
 TGeoConeEditor.cxx:367
 TGeoConeEditor.cxx:368
 TGeoConeEditor.cxx:369
 TGeoConeEditor.cxx:370
 TGeoConeEditor.cxx:371
 TGeoConeEditor.cxx:372
 TGeoConeEditor.cxx:373
 TGeoConeEditor.cxx:374
 TGeoConeEditor.cxx:375
 TGeoConeEditor.cxx:376
 TGeoConeEditor.cxx:377
 TGeoConeEditor.cxx:378
 TGeoConeEditor.cxx:379
 TGeoConeEditor.cxx:380
 TGeoConeEditor.cxx:381
 TGeoConeEditor.cxx:382
 TGeoConeEditor.cxx:383
 TGeoConeEditor.cxx:384
 TGeoConeEditor.cxx:385
 TGeoConeEditor.cxx:386
 TGeoConeEditor.cxx:387
 TGeoConeEditor.cxx:388
 TGeoConeEditor.cxx:389
 TGeoConeEditor.cxx:390
 TGeoConeEditor.cxx:391
 TGeoConeEditor.cxx:392
 TGeoConeEditor.cxx:393
 TGeoConeEditor.cxx:394
 TGeoConeEditor.cxx:395
 TGeoConeEditor.cxx:396
 TGeoConeEditor.cxx:397
 TGeoConeEditor.cxx:398
 TGeoConeEditor.cxx:399
 TGeoConeEditor.cxx:400
 TGeoConeEditor.cxx:401
 TGeoConeEditor.cxx:402
 TGeoConeEditor.cxx:403
 TGeoConeEditor.cxx:404
 TGeoConeEditor.cxx:405
 TGeoConeEditor.cxx:406
 TGeoConeEditor.cxx:407
 TGeoConeEditor.cxx:408
 TGeoConeEditor.cxx:409
 TGeoConeEditor.cxx:410
 TGeoConeEditor.cxx:411
 TGeoConeEditor.cxx:412
 TGeoConeEditor.cxx:413
 TGeoConeEditor.cxx:414
 TGeoConeEditor.cxx:415
 TGeoConeEditor.cxx:416
 TGeoConeEditor.cxx:417
 TGeoConeEditor.cxx:418
 TGeoConeEditor.cxx:419
 TGeoConeEditor.cxx:420
 TGeoConeEditor.cxx:421
 TGeoConeEditor.cxx:422
 TGeoConeEditor.cxx:423
 TGeoConeEditor.cxx:424
 TGeoConeEditor.cxx:425
 TGeoConeEditor.cxx:426
 TGeoConeEditor.cxx:427
 TGeoConeEditor.cxx:428
 TGeoConeEditor.cxx:429
 TGeoConeEditor.cxx:430
 TGeoConeEditor.cxx:431
 TGeoConeEditor.cxx:432
 TGeoConeEditor.cxx:433
 TGeoConeEditor.cxx:434
 TGeoConeEditor.cxx:435
 TGeoConeEditor.cxx:436
 TGeoConeEditor.cxx:437
 TGeoConeEditor.cxx:438
 TGeoConeEditor.cxx:439
 TGeoConeEditor.cxx:440
 TGeoConeEditor.cxx:441
 TGeoConeEditor.cxx:442
 TGeoConeEditor.cxx:443
 TGeoConeEditor.cxx:444
 TGeoConeEditor.cxx:445
 TGeoConeEditor.cxx:446
 TGeoConeEditor.cxx:447
 TGeoConeEditor.cxx:448
 TGeoConeEditor.cxx:449
 TGeoConeEditor.cxx:450
 TGeoConeEditor.cxx:451
 TGeoConeEditor.cxx:452
 TGeoConeEditor.cxx:453
 TGeoConeEditor.cxx:454
 TGeoConeEditor.cxx:455
 TGeoConeEditor.cxx:456
 TGeoConeEditor.cxx:457
 TGeoConeEditor.cxx:458
 TGeoConeEditor.cxx:459
 TGeoConeEditor.cxx:460
 TGeoConeEditor.cxx:461
 TGeoConeEditor.cxx:462
 TGeoConeEditor.cxx:463
 TGeoConeEditor.cxx:464
 TGeoConeEditor.cxx:465
 TGeoConeEditor.cxx:466
 TGeoConeEditor.cxx:467
 TGeoConeEditor.cxx:468
 TGeoConeEditor.cxx:469
 TGeoConeEditor.cxx:470
 TGeoConeEditor.cxx:471
 TGeoConeEditor.cxx:472
 TGeoConeEditor.cxx:473
 TGeoConeEditor.cxx:474
 TGeoConeEditor.cxx:475
 TGeoConeEditor.cxx:476
 TGeoConeEditor.cxx:477
 TGeoConeEditor.cxx:478
 TGeoConeEditor.cxx:479
 TGeoConeEditor.cxx:480
 TGeoConeEditor.cxx:481
 TGeoConeEditor.cxx:482
 TGeoConeEditor.cxx:483
 TGeoConeEditor.cxx:484
 TGeoConeEditor.cxx:485
 TGeoConeEditor.cxx:486
 TGeoConeEditor.cxx:487
 TGeoConeEditor.cxx:488
 TGeoConeEditor.cxx:489
 TGeoConeEditor.cxx:490
 TGeoConeEditor.cxx:491
 TGeoConeEditor.cxx:492
 TGeoConeEditor.cxx:493
 TGeoConeEditor.cxx:494
 TGeoConeEditor.cxx:495
 TGeoConeEditor.cxx:496
 TGeoConeEditor.cxx:497
 TGeoConeEditor.cxx:498
 TGeoConeEditor.cxx:499
 TGeoConeEditor.cxx:500
 TGeoConeEditor.cxx:501
 TGeoConeEditor.cxx:502
 TGeoConeEditor.cxx:503
 TGeoConeEditor.cxx:504
 TGeoConeEditor.cxx:505
 TGeoConeEditor.cxx:506
 TGeoConeEditor.cxx:507
 TGeoConeEditor.cxx:508
 TGeoConeEditor.cxx:509
 TGeoConeEditor.cxx:510
 TGeoConeEditor.cxx:511
 TGeoConeEditor.cxx:512
 TGeoConeEditor.cxx:513
 TGeoConeEditor.cxx:514
 TGeoConeEditor.cxx:515
 TGeoConeEditor.cxx:516
 TGeoConeEditor.cxx:517
 TGeoConeEditor.cxx:518
 TGeoConeEditor.cxx:519
 TGeoConeEditor.cxx:520
 TGeoConeEditor.cxx:521
 TGeoConeEditor.cxx:522
 TGeoConeEditor.cxx:523
 TGeoConeEditor.cxx:524
 TGeoConeEditor.cxx:525
 TGeoConeEditor.cxx:526
 TGeoConeEditor.cxx:527
 TGeoConeEditor.cxx:528
 TGeoConeEditor.cxx:529
 TGeoConeEditor.cxx:530
 TGeoConeEditor.cxx:531
 TGeoConeEditor.cxx:532
 TGeoConeEditor.cxx:533
 TGeoConeEditor.cxx:534
 TGeoConeEditor.cxx:535
 TGeoConeEditor.cxx:536
 TGeoConeEditor.cxx:537
 TGeoConeEditor.cxx:538
 TGeoConeEditor.cxx:539
 TGeoConeEditor.cxx:540
 TGeoConeEditor.cxx:541
 TGeoConeEditor.cxx:542
 TGeoConeEditor.cxx:543
 TGeoConeEditor.cxx:544
 TGeoConeEditor.cxx:545
 TGeoConeEditor.cxx:546
 TGeoConeEditor.cxx:547
 TGeoConeEditor.cxx:548
 TGeoConeEditor.cxx:549
 TGeoConeEditor.cxx:550
 TGeoConeEditor.cxx:551
 TGeoConeEditor.cxx:552
 TGeoConeEditor.cxx:553
 TGeoConeEditor.cxx:554
 TGeoConeEditor.cxx:555
 TGeoConeEditor.cxx:556
 TGeoConeEditor.cxx:557
 TGeoConeEditor.cxx:558
 TGeoConeEditor.cxx:559
 TGeoConeEditor.cxx:560
 TGeoConeEditor.cxx:561
 TGeoConeEditor.cxx:562
 TGeoConeEditor.cxx:563
 TGeoConeEditor.cxx:564
 TGeoConeEditor.cxx:565
 TGeoConeEditor.cxx:566
 TGeoConeEditor.cxx:567
 TGeoConeEditor.cxx:568
 TGeoConeEditor.cxx:569
 TGeoConeEditor.cxx:570
 TGeoConeEditor.cxx:571
 TGeoConeEditor.cxx:572
 TGeoConeEditor.cxx:573
 TGeoConeEditor.cxx:574
 TGeoConeEditor.cxx:575
 TGeoConeEditor.cxx:576
 TGeoConeEditor.cxx:577
 TGeoConeEditor.cxx:578
 TGeoConeEditor.cxx:579
 TGeoConeEditor.cxx:580
 TGeoConeEditor.cxx:581
 TGeoConeEditor.cxx:582
 TGeoConeEditor.cxx:583
 TGeoConeEditor.cxx:584
 TGeoConeEditor.cxx:585
 TGeoConeEditor.cxx:586
 TGeoConeEditor.cxx:587
 TGeoConeEditor.cxx:588
 TGeoConeEditor.cxx:589
 TGeoConeEditor.cxx:590
 TGeoConeEditor.cxx:591
 TGeoConeEditor.cxx:592
 TGeoConeEditor.cxx:593
 TGeoConeEditor.cxx:594