1 /* *************************************************************************
2 * Copyright(c) 1998-1999, ALICE Experiment at CERN, All rights reserved. *
4 * Author: The ALICE Off-line Project. *
5 * Contributors are mentioned in the code where appropriate. *
7 * Permission to use, copy, modify and distribute this software and its *
8 * documentation strictly for non-commercial purposes is hereby granted *
9 * without fee, provided that the above copyright notice appears in all *
10 * copies and that both the copyright notice and this permission notice *
11 * appear in the supporting documentation. The authors make no claims *
12 * about the suitability of this software for any purpose. It is *
13 * provided "as is" without express or implied warranty. *
14 **************************************************************************/
18 Revision 1.2 2001/07/09 11:48:47 morsch
19 Use AliG3Volume, AliG3Medium, AliG3Material
21 Revision 1.1 2000/07/13 16:19:10 fca
22 Mainly coding conventions + some small bug fixes
24 Revision 1.8 2000/07/12 08:56:32 fca
25 Coding convention correction and warning removal
27 Revision 1.7 2000/06/28 21:27:45 morsch
28 Most coding rule violations corrected.
29 Still to do: Split the file (on file per class) ? Avoid the global variables.
30 Copy constructors and assignment operators (dummy ?)
32 Revision 1.6 2000/04/14 11:07:46 morsch
33 Correct volume to medium assignment in case several media are asigned to the
36 Revision 1.5 2000/03/20 15:11:03 fca
37 Mods to make the code compile on HP
39 Revision 1.4 2000/01/18 16:12:08 morsch
40 Bug in calculation of number of volume divisions and number of positionings corrected
41 Browser for Material and Media properties added
43 Revision 1.3 1999/11/14 14:31:14 fca
44 Correct small error and remove compilation warnings on HP
46 Revision 1.2 1999/11/10 16:53:35 fca
47 The new geometry viewer from A.Morsch
53 #include "AliGUISliders.h"
54 #include "AliG3Volume.h"
56 static Text_t* kLabelText[7] =
57 {"Theta ", "Phi ", "Psi ", "U ", "V ", "UScale", "VScale"};
58 static Int_t IRangeMin[7] = { 0, 0, 0, 0, 0, 0, 0};
59 static Int_t IRangeMax[7] = {36000, 36000, 36000, 2000, 2000, 10, 10};
60 static Int_t DefaultPos[7] = { 3000, 4000, 0, 1000, 1000, 1, 1};
62 AliGUISliders::AliGUISliders(const TGWindow *p, const TGWindow *,
64 TGCompositeFrame(p, w, h,kVerticalFrame)
67 ChangeOptions((GetOptions() & ~kHorizontalFrame) | kVerticalFrame);
68 //--- layout for buttons: top align, equally expand horizontally
69 fBly = new TGLayoutHints(kLHintsTop | kLHintsExpandY, 5, 5, 5, 5);
71 //--- layout for the frame: place at bottom, right aligned
72 fBfly1 = new TGLayoutHints(kLHintsLeft | kLHintsExpandX );
76 for (Int_t i=0; i<7; i++) {
79 fHframe[i] = new TGHorizontalFrame(this, 400, 100, kFixedWidth);
80 fTbh[i] = new TGTextBuffer(10);
81 fTeh[i] = new TGTextEntry(fHframe[i], fTbh[i],idT);
83 sprintf(buf, "%6.2f", Float_t(DefaultPos[i])/100);
84 fTbh[i]->AddText(0, buf);
85 fTeh[i]->Associate(this);
87 fHslider[i] = new TGHSlider(fHframe[i], 400, kSlider1 | kScaleBoth, idS);
88 fHslider[i]->Associate(this);
89 fHslider[i]->SetRange(IRangeMin[i], IRangeMax[i]);
90 fHslider[i]->SetPosition(DefaultPos[i]);
92 fLabel[i] = new TGLabel(fHframe[i], kLabelText[i]);
95 fHframe[i]->AddFrame(fLabel[i], fBfly1);
96 fHframe[i]->AddFrame(fTeh[i], fBfly1);
97 fHframe[i]->AddFrame(fHslider[i], fBfly1);
98 AddFrame(fHframe[i], fBly);
102 AliGUISliders::~AliGUISliders()
105 delete fBfly1; delete fBly;
107 for (Int_t i=1; i<7; i++) {
115 void AliGUISliders::Update()
120 for (Int_t i=0; i<7; i++) {
121 Float_t param = gCurrentVolume->GetParam(i);
123 fHslider[i]->SetPosition(Int_t(param*100.));
124 gClient->NeedRedraw(fHslider[i]);
126 sprintf(buf, "%6.2f", param);
128 fTbh[i]->AddText(0, buf);
129 gClient->NeedRedraw(fTeh[i]);
136 void AliGUISliders::CloseWindow()
138 // Called when window is closed via the window manager.
143 Bool_t AliGUISliders::ProcessMessage(Long_t msg, Long_t parm1, Long_t parm2)
145 // Process slider messages.
149 switch (GET_MSG(msg)) {
151 switch (GET_SUBMSG(msg)) {
152 case kTE_TEXTCHANGED:
153 Int_t idT=Int_t(parm1)-1;
154 fHslider[idT]->SetPosition((Int_t)atof(fTbh[idT]->GetString())*100);
155 gClient->NeedRedraw(fHslider[idT]);
156 gCurrentVolume->SetParam(idT,atof(fTbh[idT]->GetString()));
157 gCurrentVolume->Draw();
161 switch (GET_SUBMSG(msg)) {
163 sprintf(buf, "%6.2f", Float_t(parm2)/100);
164 Int_t idS=Int_t(parm1)-8;
166 fTbh[idS]->AddText(0, buf);
167 gClient->NeedRedraw(fTeh[idS]);
168 gCurrentVolume->SetParam(idS, Float_t(parm2)/100.);
169 gCurrentVolume->Draw();