ROOT  6.07/01
Reference Guide
 All Classes Namespaces Files Functions Variables Typedefs Enumerations Enumerator Properties Friends Macros Groups Pages
robot.C
Go to the documentation of this file.
1 #include "TGeoManager.h"
2 
3 void robot()
4 {
5  // Drawing a famous Korean robot, TaekwonV, using ROOT geometry class.
6  // Name: robot.C
7  // Author: Jin Hui Hwang, Dept. of Physics, Univ. of Seoul
8  // Reviewed by Sunman Kim (sunman98@hanmail.net)
9  // Supervisor: Prof. Inkyu Park (icpark@physics.uos.ac.kr)
10  //
11  // How to run: .x robot.C in ROOT terminal, then use OpenGL
12  //
13  // This macro was created for the evaluation of Computational Physics course in 2006.
14  // We thank to Prof. Inkyu Park for his special lecture on ROOT and to all of ROOT team
15  //
16 
17  TGeoManager *Robot = new TGeoManager("Robot","This is Taegwon V");
18 
19  TGeoMaterial *vacuum=new TGeoMaterial("vacuum",0,0,0);
20  TGeoMaterial *Fe=new TGeoMaterial("Fe",55.845,26,7.87);
21 
22  TGeoMedium *Air=new TGeoMedium("Vacuum",0,vacuum);
23  TGeoMedium *Iron=new TGeoMedium("Iron",1,Fe);
24 
25  // create volume
26 
27  TGeoVolume *top=Robot->MakeBox("top",Air,1000,1000,1000);
28  Robot->SetTopVolume(top);
29  Robot->SetTopVisible(0);
30  // If you want to see the boundary, please input the number, 1 instead of 0.
31  // Like this, geom->SetTopVisible(1);
32 
33 
34 
35  // head
36  TGeoVolume *Band=Robot->MakeEltu("Band",Iron,20,20,2.5);
37  Band->SetLineColor(12);
38  Band->SetFillColor(12);
39  TGeoVolume *Band_b=Robot->MakeSphere("Band_b",Iron,0,2,0,180,180,360);
40  Band_b->SetLineColor(2);
41  Band_b->SetFillColor(2);
42  TGeoVolume *Head=Robot->MakeSphere("Head",Iron,0,19,0,180,180,360);
43  Head->SetLineColor(17);
44  Head->SetFillColor(17);
45  TGeoVolume *Horn=Robot->MakeSphere("Horn",Iron,0,10,60,180,240,300);
46 
47  // drawing head
48  top->AddNodeOverlap(Band,1,new TGeoTranslation(0,0,90));
49  float Phi = 3.14;
50  int N = 10;
51 
52  for (int i=0; i<=N;i++){
53  top->AddNodeOverlap(Band_b,1,new TGeoCombiTrans(sin(2*Phi/N*i)*19,-cos(2*Phi/N*i)*19,90,
54  new TGeoRotation("R1",-90+(360/N*i),-90,90)));
55  }
56  top->AddNodeOverlap(Head,1,new TGeoCombiTrans(0,0,87.5,new TGeoRotation("R2",0,-90,0)));
57 
58  char name[50];
59  float pcs = 30;
60  for (int i=1; i<pcs; i++){
61  sprintf(name,"Horn%d",i);
62  Horn=Robot->MakeSphere(name,Iron,
63  10- 10/pcs*i ,10,180-(120/pcs)*i,180-((120/pcs) * (i-1)),240,300);
64  Horn->SetLineColor(2);
65  Horn->SetFillColor(2);
66  top->AddNodeOverlap(Horn,1,new TGeoCombiTrans(0,8,102,new TGeoRotation("R2",0,140,0)));
67  top->AddNodeOverlap(Horn,1,new TGeoCombiTrans(0,-8,102,new TGeoRotation("R2",180,140,0)));
68  }
69 
70  // face
71  TGeoVolume *Migan=Robot->MakeGtra("Migan",Iron,3,0,0,0,3,2,11,0,3,3,11,0);
72  Migan->SetLineColor(17);
73  Migan->SetFillColor(17);
74  TGeoVolume *Ko=Robot->MakeGtra("Ko",Iron,7,0,0,0,3,1,5,0,3,2,5,0);
75  Ko->SetLineColor(17);
76  Ko->SetFillColor(17);
77  TGeoVolume *Ko_m=Robot->MakeBox("Ko_m",Iron,2,8,4);
78  Ko_m->SetLineColor(17);
79  Ko_m->SetFillColor(17);
80  TGeoVolume *Bol_1=Robot->MakeBox("Bol_1",Iron,7,5.5,7);
81  Bol_1->SetLineColor(17);
82  Bol_1->SetFillColor(17);
83  TGeoVolume *Bol_2=Robot->MakeGtra("Bol_2",Iron,1,0,0,0,7,0,9,0,7,0,9,0);
84  Bol_2->SetLineColor(17);
85  Bol_2->SetFillColor(17);
86  TGeoVolume *Noon=Robot->MakeBox("Noon",Iron,1,10,5);
87  Noon->SetLineColor(12);
88  Noon->SetFillColor(12);
89  TGeoVolume *Tuck=Robot->MakeBox("Tuck",Iron,2,10,5.5);
90  Tuck->SetLineColor(2);
91  Tuck->SetFillColor(2);
92  TGeoVolume *Tuck_1=Robot->MakeBox("Tuck_1",Iron,2,9,1);
93  Tuck_1->SetLineColor(2);
94  Tuck_1->SetFillColor(2);
95  TGeoVolume *Tuck_2=Robot->MakeBox("Tuck_2",Iron,3,1,14);
96  Tuck_2->SetLineColor(2);
97  Tuck_2->SetFillColor(2);
98  TGeoVolume *Tuck_j=Robot->MakeSphere("Tuck_j",Iron,0,3.5,0,180,0,360);
99  Tuck_j->SetLineColor(5);
100  Tuck_j->SetFillColor(5);
101  TGeoVolume *Ear=Robot->MakeCons("Ear",Iron,1,0,3,0,3,0,360);
102  Ear->SetLineColor(5);
103  Ear->SetFillColor(5);
104  TGeoVolume *Ear_2=Robot->MakeCone("Ear_2",Iron,5,0,0,0,3);
105  Ear_2->SetLineColor(5);
106  Ear_2->SetFillColor(5);
107 
108  // drawing face
109  top->AddNodeOverlap(Migan,1,new TGeoCombiTrans(-15,0,88,new TGeoRotation("R2",-90,40,0)));
110  top->AddNodeOverlap(Ko,1,new TGeoCombiTrans(-15,0,76.5,new TGeoRotation("R2",-90,-20,0)));
111  top->AddNodeOverlap(Ko_m,1,new TGeoTranslation(-9,0,68));
112  top->AddNodeOverlap(Bol_1,1,new TGeoCombiTrans(-7,2,76,new TGeoRotation("R2",-30,-10,0)));
113  top->AddNodeOverlap(Bol_1,1,new TGeoCombiTrans(-7,-2,76,new TGeoRotation("R2",30,10,0)));
114  top->AddNodeOverlap(Bol_2,1,new TGeoCombiTrans(-6.5,-10.5,76,new TGeoRotation("R2",-15,-90,-30)));
115  top->AddNodeOverlap(Bol_2,1,new TGeoCombiTrans(-4,-12.5,82.5,new TGeoRotation("R2",-20,-90,-95)));
116  top->AddNodeOverlap(Bol_2,1,new TGeoCombiTrans(-7.5,10.5,76,new TGeoRotation("R2",20,-90,-30)));
117  top->AddNodeOverlap(Bol_2,1,new TGeoCombiTrans(-4,12.5,82.5,new TGeoRotation("R2",20,-90,-95)));
118  top->AddNodeOverlap(Noon,1,new TGeoCombiTrans(-5,-7,86,new TGeoRotation("R2",60,0,0)));
119  top->AddNodeOverlap(Noon,1,new TGeoCombiTrans(-5,7,86,new TGeoRotation("R2",-60,0,0)));
120  top->AddNodeOverlap(Tuck,1,new TGeoTranslation(-12,0,62.5));
121  for (int i=0; i<10;i++) {
122  top->AddNodeOverlap(Tuck_1,1,new TGeoCombiTrans(-4.2,11,61+i,new TGeoRotation("R2",90,-20,20)));
123  top->AddNodeOverlap(Tuck_1,1,new TGeoCombiTrans(-4.2,-11,61+i,new TGeoRotation("R2",90,-20,-20)));
124  }
125  top->AddNodeOverlap(Tuck_2,1,new TGeoTranslation(2,-15.1,76));
126  top->AddNodeOverlap(Tuck_2,1,new TGeoTranslation(2,15.1,76));
127  top->AddNodeOverlap(Tuck_j,1,new TGeoTranslation(-13,0,62.5));
128  top->AddNodeOverlap(Ear,1,new TGeoCombiTrans(2,-16.5,80,new TGeoRotation("R2",0,-90,0)));
129  top->AddNodeOverlap(Ear,1,new TGeoCombiTrans(2,16.5,80,new TGeoRotation("R2",0,90,0)));
130  top->AddNodeOverlap(Ear_2,1,new TGeoCombiTrans(2,-20,80,new TGeoRotation("R2",0,-90,0)));
131  top->AddNodeOverlap(Ear_2,1,new TGeoCombiTrans(2,20,80,new TGeoRotation("R2",0,90,0)));
132 
133 
134  for (int i=1; i<28; i+=1) {
135  float a=i*0.2;
136  TGeoVolume *Hear=Robot->MakeCons("Hear",Iron,3,13+a,16+a,13+a,16+a,-60-a,60+a);
137  if (i<27) {
138  Hear->SetLineColor(12);
139  Hear->SetFillColor(12);
140  }
141  else {
142  Hear->SetLineColor(2);
143  Hear->SetFillColor(2);
144  }
145  top->AddNodeOverlap(Hear,1,new TGeoTranslation(0,0,89-i));
146  }
147  for (int i=1; i<28; i+=1) {
148  float a=i*0.2;
149  TGeoVolume *Hear=Robot->MakeCons("Hear",Iron,3,13+a,16+a,13+a,16+a,-70-a,-60-a);
150  Hear->SetLineColor(2);
151  Hear->SetFillColor(2);
152  top->AddNodeOverlap(Hear,1,new TGeoTranslation(0,0,89-i));
153  }
154  for (int i=1; i<28; i+=1) {
155  float a=i*0.2;
156  TGeoVolume *Hear=Robot->MakeCons("Hear",Iron,3,13+a,16+a,13+a,16+a,60+a,70+a);
157  Hear->SetLineColor(2);
158  Hear->SetFillColor(2);
159  top->AddNodeOverlap(Hear,1,new TGeoTranslation(0,0,89-i));
160  }
161 
162  // neck
163  TGeoVolume *Mock=Robot->MakeTrd2("Mock",Iron,1,1,7,6.5,20);
164  Mock->SetLineColor(17);
165  Mock->SetFillColor(17);
166  TGeoVolume *Mock_1=Robot->MakeTrd2("Mock_1",Iron,1,1,6,5,20);
167  Mock_1->SetLineColor(17);
168  Mock_1->SetFillColor(17);
169  TGeoVolume *Mock_s=Robot->MakeTrd2("Mock_s",Iron,1,1,5,4.5,20);
170  Mock_s->SetLineColor(17);
171  Mock_s->SetFillColor(17);
172 
173  // drawing neck
174  top->AddNodeOverlap(Mock,1,new TGeoCombiTrans(-5,4.7,50,new TGeoRotation("R2",-30,0,-10)));
175  top->AddNodeOverlap(Mock,1,new TGeoCombiTrans(-5,-4.7,50,new TGeoRotation("R2",30,0,10)));
176  top->AddNodeOverlap(Mock_1,1,new TGeoCombiTrans(11,-4,50,new TGeoRotation("R2",130,-8,10)));
177  top->AddNodeOverlap(Mock_1,1,new TGeoCombiTrans(11,4,50,new TGeoRotation("R2",-130,8,-10)));
178  top->AddNodeOverlap(Mock_s,1,new TGeoCombiTrans(2.5,9,50,new TGeoRotation("R2",90,0,0)));
179  top->AddNodeOverlap(Mock_s,1,new TGeoCombiTrans(2.5,-9,50,new TGeoRotation("R2",90,0,0)));
180 
181 
182  // chest
183  TGeoVolume *Gasem=Robot->MakeBox("Gasem",Iron,16,50,20);
184  Gasem->SetLineColor(12);
185  Gasem->SetFillColor(12);
186  TGeoVolume *Gasem_b1=Robot->MakeSphere("Gasem_b1",Iron,0,15,0,180,0,360);
187  Gasem_b1->SetLineColor(12);
188  Gasem_b1->SetFillColor(12);
189  TGeoVolume *Gasem_b2=Robot->MakeSphere("Gasem_b2",Iron,0,13,0,180,0,360);
190  Gasem_b2->SetLineColor(12);
191  Gasem_b2->SetFillColor(12);
192  TGeoVolume *Gasem_1=Robot->MakeEltu("Gasem_1",Iron,13,13,20);
193  Gasem_1->SetLineColor(12);
194  Gasem_1->SetFillColor(12);
195  TGeoVolume *Gasem_2=Robot->MakeEltu("Gasem_2",Iron,13,13,19);
196  Gasem_2->SetLineColor(12);
197  Gasem_2->SetFillColor(12);
198  TGeoVolume *Gasem_3=Robot->MakeCone("Gasem_3",Iron,19,0,13,0,15);
199  Gasem_3->SetLineColor(12);
200  Gasem_3->SetFillColor(12);
201  TGeoVolume *Gasem_4=Robot->MakeEltu("Gasem_4",Iron,15,15,16);
202  Gasem_4->SetLineColor(12);
203  Gasem_4->SetFillColor(12);
204  TGeoVolume *Gasem_5=Robot->MakeEltu("Gasem_5",Iron,13,13,16);
205  Gasem_5->SetLineColor(12);
206  Gasem_5->SetFillColor(12);
207  TGeoVolume *Gasem_m1=Robot->MakeBox("Gasem_m1",Iron,19,19,5);
208  Gasem_m1->SetLineColor(12);
209  Gasem_m1->SetFillColor(12);
210  TGeoVolume *Gasem_m2=Robot->MakeTrd2("Gasem_m2",Iron,13,15,2,2,19);
211  Gasem_m2->SetLineColor(12);
212  Gasem_m2->SetFillColor(12);
213  TGeoVolume *V=Robot->MakeTrd2("V",Iron,2,2,22,30,4);
214  V->SetLineColor(2);
215  V->SetFillColor(2);
216  TGeoVolume *V_m=Robot->MakeBox("V_m",Iron,2,7,1);
217  V_m->SetLineColor(2);
218  V_m->SetFillColor(2);
219 
220  // drawing chest
221  top->AddNodeOverlap(Gasem,1,new TGeoTranslation(4,0,19));
222  top->AddNodeOverlap(Gasem_b1,1,new TGeoTranslation(-12,50,35));
223  top->AddNodeOverlap(Gasem_b1,1,new TGeoTranslation(-12,-50,35));
224  top->AddNodeOverlap(Gasem_b1,1,new TGeoTranslation(20,50,35));
225  top->AddNodeOverlap(Gasem_b1,1,new TGeoTranslation(20,-50,35));
226  top->AddNodeOverlap(Gasem_b2,1,new TGeoTranslation(-12,50,-5));
227  top->AddNodeOverlap(Gasem_b2,1,new TGeoTranslation(-12,-50,-5));
228  top->AddNodeOverlap(Gasem_b2,1,new TGeoTranslation(20,50,-5));
229  top->AddNodeOverlap(Gasem_b2,1,new TGeoTranslation(20,-50,-5));
230  top->AddNodeOverlap(Gasem_b2,1,new TGeoTranslation(20,10,-5));
231  top->AddNodeOverlap(Gasem_b2,1,new TGeoTranslation(20,-10,-5));
232  top->AddNodeOverlap(Gasem_b2,1,new TGeoTranslation(-12,10,-5));
233  top->AddNodeOverlap(Gasem_b2,1,new TGeoTranslation(-12,-10,-5));
234  top->AddNodeOverlap(Gasem_b2,1,new TGeoTranslation(20,10,35));
235  top->AddNodeOverlap(Gasem_b2,1,new TGeoTranslation(20,-10,35));
236  top->AddNodeOverlap(Gasem_b2,1,new TGeoTranslation(-12,10,35));
237  top->AddNodeOverlap(Gasem_b2,1,new TGeoTranslation(-12,-10,35));
238  top->AddNodeOverlap(Gasem_1,1,new TGeoCombiTrans(20,31,-5,new TGeoRotation("R2",0,90,0)));
239  top->AddNodeOverlap(Gasem_1,1,new TGeoCombiTrans(20,-31,-5,new TGeoRotation("R2",0,90,0)));
240  top->AddNodeOverlap(Gasem_1,1,new TGeoCombiTrans(-12,31,-5,new TGeoRotation("R2",0,90,0)));
241  top->AddNodeOverlap(Gasem_1,1,new TGeoCombiTrans(-12,-31,-5,new TGeoRotation("R2",0,90,0)));
242  top->AddNodeOverlap(Gasem_2,1,new TGeoCombiTrans(20,10,13,new TGeoRotation("R2",0,0,0)));
243  top->AddNodeOverlap(Gasem_2,1,new TGeoCombiTrans(20,-10,13,new TGeoRotation("R2",0,0,0)));
244  top->AddNodeOverlap(Gasem_2,1,new TGeoCombiTrans(-12,10,13,new TGeoRotation("R2",0,0,0)));
245  top->AddNodeOverlap(Gasem_2,1,new TGeoCombiTrans(-12,-10,13,new TGeoRotation("R2",0,0,0)));
246  top->AddNodeOverlap(Gasem_3,1,new TGeoCombiTrans(-12,50,16,new TGeoRotation("R2",0,0,0)));
247  top->AddNodeOverlap(Gasem_3,1,new TGeoCombiTrans(-12,-50,16,new TGeoRotation("R2",0,0,0)));
248  top->AddNodeOverlap(Gasem_3,1,new TGeoCombiTrans(20,50,16,new TGeoRotation("R2",0,0,0)));
249  top->AddNodeOverlap(Gasem_3,1,new TGeoCombiTrans(20,-50,16,new TGeoRotation("R2",0,0,0)));
250  top->AddNodeOverlap(Gasem_3,1,new TGeoCombiTrans(-12,31,35,new TGeoRotation("R2",0,-90,0)));
251  top->AddNodeOverlap(Gasem_3,1,new TGeoCombiTrans(-12,-31,35,new TGeoRotation("R2",0,90,0)));
252  top->AddNodeOverlap(Gasem_3,1,new TGeoCombiTrans(20,31,35,new TGeoRotation("R2",0,-90,0)));
253  top->AddNodeOverlap(Gasem_3,1,new TGeoCombiTrans(20,-31,35,new TGeoRotation("R2",0,90,0)));
254  top->AddNodeOverlap(Gasem_4,1,new TGeoCombiTrans(4,-50,35,new TGeoRotation("R2",90,90,0)));
255  top->AddNodeOverlap(Gasem_4,1,new TGeoCombiTrans(4,50,35,new TGeoRotation("R2",90,90,0)));
256  top->AddNodeOverlap(Gasem_5,1,new TGeoCombiTrans(4,-50,-5,new TGeoRotation("R2",90,90,0)));
257  top->AddNodeOverlap(Gasem_5,1,new TGeoCombiTrans(4,50,-5,new TGeoRotation("R2",90,90,0)));
258  top->AddNodeOverlap(Gasem_m1,1,new TGeoCombiTrans(-22,30,16,new TGeoRotation("R2",90,88,0)));
259  top->AddNodeOverlap(Gasem_m1,1,new TGeoCombiTrans(-22,-30,16,new TGeoRotation("R2",90,88,0)));
260  top->AddNodeOverlap(Gasem_m1,1,new TGeoCombiTrans(29,30,16,new TGeoRotation("R2",90,92,0)));
261  top->AddNodeOverlap(Gasem_m1,1,new TGeoCombiTrans(29,-30,16,new TGeoRotation("R2",90,92,0)));
262  top->AddNodeOverlap(Gasem_m2,1,new TGeoCombiTrans(2,-62,16,new TGeoRotation("R2",0,3,0)));
263  top->AddNodeOverlap(Gasem_m2,1,new TGeoCombiTrans(2,62,16,new TGeoRotation("R2",0,-3,0)));
264  top->AddNodeOverlap(Gasem_m2,1,new TGeoCombiTrans(2,-30,47.5,new TGeoRotation("R2",0,87,0)));
265  top->AddNodeOverlap(Gasem_m2,1,new TGeoCombiTrans(2,30,47.5,new TGeoRotation("R2",0,-87,0)));
266  top->AddNodeOverlap(Gasem_m2,1,new TGeoCombiTrans(2,-30,-16,new TGeoRotation("R2",0,90,0)));
267  top->AddNodeOverlap(Gasem_m2,1,new TGeoCombiTrans(2,30,-16,new TGeoRotation("R2",0,-90,0)));
268  top->AddNodeOverlap(V,1,new TGeoCombiTrans(-30,18.3,16,new TGeoRotation("R2",0,-135,0)));
269  top->AddNodeOverlap(V,1,new TGeoCombiTrans(-30,-18.3,16,new TGeoRotation("R2",0,135,0)));
270  top->AddNodeOverlap(V_m,1,new TGeoTranslation(-30,-37,35));
271  top->AddNodeOverlap(V_m,1,new TGeoTranslation(-30,37,35));
272 
273  // abdomen
274  TGeoVolume *Bea=Robot->MakeEltu("Bea",Iron,20,37,25);
275  Bea->SetLineColor(17);
276  Bea->SetFillColor(17);
277  TGeoVolume *Bea_d=Robot->MakeEltu("Bea_d",Iron,21,36,5);
278  Bea_d->SetLineColor(12);
279  Bea_d->SetFillColor(12);
280  TGeoVolume *Beakop=Robot->MakeEltu("Beakop",Iron,15,25,5);
281  Beakop->SetLineColor(10);
282  Beakop->SetFillColor(10);
283 
284  // drawing abdomen
285  top->AddNodeOverlap(Bea,1,new TGeoTranslation(3,0,-30));
286  top->AddNodeOverlap(Bea_d,1,new TGeoTranslation(3,0,-10));
287  top->AddNodeOverlap(Beakop,1,new TGeoCombiTrans(-12.1,0,-50, new TGeoRotation("R2",90,90,0)));
288 
289  // Gungdi
290  TGeoVolume *Gungdi=Robot->MakeEltu("Gungdi",Iron,25,50,18);
291  Gungdi->SetLineColor(12);
292  Gungdi->SetFillColor(12);
293  TGeoVolume *Gungdi_d=Robot->MakeEltu("Gungdi_d",Iron,5,5,5);
294  Gungdi_d->SetLineColor(2);
295  Gungdi_d->SetFillColor(2);
296 
297  // drawing Gungdi
298  top->AddNodeOverlap(Gungdi,1,new TGeoTranslation(3,0,-70));
299  for (int i=0; i<30; i++) {
300  TGeoVolume *Gungdi_j=Robot->MakeEltu("Gungdi_j",Iron,24-0.2*i,49-0.5*i,1);
301  Gungdi_j->SetLineColor(12);
302  Gungdi_j->SetFillColor(12);
303  top->AddNodeOverlap(Gungdi_j,1,new TGeoTranslation(3,0,-51+0.5*i));
304  }
305  for (int i=0; i<40; i++) {
306  if (i<16) {
307  TGeoVolume *Gungdi_h=Robot->MakeEltu("Gungdi_h",Iron,24-0.1*i,49-0.3*i,1);
308  Gungdi_h->SetLineColor(12);
309  Gungdi_h->SetFillColor(12);
310  top->AddNodeOverlap(Gungdi_h,1,new TGeoTranslation(3,0,-88-0.5*i));
311  }
312  else {
313  TGeoVolume *Gungdi_h=Robot->MakeEltu("Gungdi_h",Iron,27-0.3*i,52-0.5*i,1);
314  Gungdi_h->SetLineColor(12);
315  Gungdi_h->SetFillColor(12);
316  top->AddNodeOverlap(Gungdi_h,1,new TGeoTranslation(3,0,-89-0.5*i));
317  }
318  }
319  top->AddNodeOverlap(Gungdi_d,1,new TGeoCombiTrans(3,-45,-62,new TGeoRotation("R2",0,90,0)));
320  top->AddNodeOverlap(Gungdi_d,1,new TGeoCombiTrans(3,-45,-78,new TGeoRotation("R2",0,90,0)));
321  top->AddNodeOverlap(Gungdi_d,1,new TGeoCombiTrans(3,45,-62,new TGeoRotation("R2",0,90,0)));
322  top->AddNodeOverlap(Gungdi_d,1,new TGeoCombiTrans(3,45,-78,new TGeoRotation("R2",0,90,0)));
323 
324  // feet
325  TGeoVolume *Jang=Robot->MakeEltu("Jang",Iron,18,18,50);
326  Jang->SetLineColor(17);
327  Jang->SetFillColor(17);
328  TGeoVolume *Jong=Robot->MakeEltu("Jong",Iron,22,22,50);
329  Jong->SetLineColor(12);
330  Jong->SetFillColor(12);
331  TGeoVolume *Bal=Robot->MakeSphere("Bal",Iron,0,22,0,180,180,360);
332  Bal->SetLineColor(12);
333  Bal->SetFillColor(12);
334 
335  // drawing Dary
336  top->AddNodeOverlap(Jang,1,new TGeoCombiTrans(3,-25,-120,new TGeoRotation("R2",0,0,0)));
337  top->AddNodeOverlap(Jang,1,new TGeoCombiTrans(3,25,-120,new TGeoRotation("R2",0,0,0)));
338  top->AddNodeOverlap(Jong,1,new TGeoCombiTrans(3,-25,-220,new TGeoRotation("R2",0,0,0)));
339  top->AddNodeOverlap(Jong,1,new TGeoCombiTrans(3,25,-220,new TGeoRotation("R2",0,0,0)));
340  for (int i=0; i<30; i++) {
341  TGeoVolume *Mu=Robot->MakeCons("Mu",Iron,1,0,22.1,0,22.1,120+2*i,-120-2*i);
342  Mu->SetLineColor(4);
343  Mu->SetFillColor(4);
344  top->AddNodeOverlap(Mu,1,new TGeoTranslation(3,-25,-171-i));
345  top->AddNodeOverlap(Mu,1,new TGeoTranslation(3,25,-171-i));
346 
347  }
348  top->AddNodeOverlap(Bal,1,new TGeoCombiTrans(-10,-25,-270,new TGeoRotation("R2",270,-90,0)));
349  top->AddNodeOverlap(Bal,1,new TGeoCombiTrans(-10,25,-270,new TGeoRotation("R2",270,-90,0)));
350 
351  // arms
352  TGeoVolume *S=Robot->MakeSphere("S",Iron,0,25,0,180,180,360);
353  S->SetLineColor(17);
354  S->SetFillColor(17);
355  TGeoVolume *S_1=Robot->MakeSphere("S_1",Iron,0,15,0,180,0,360);
356  S_1->SetLineColor(17);
357  S_1->SetFillColor(17);
358  TGeoVolume *Pal=Robot->MakeEltu("Pal",Iron,15,15,30);
359  Pal->SetLineColor(17);
360  Pal->SetFillColor(17);
361  TGeoVolume *Fal=Robot->MakeEltu("Fal",Iron,17,17,30);
362  Fal->SetLineColor(4);
363  Fal->SetFillColor(4);
364  TGeoVolume *Bbul=Robot->MakeCone("Bbul",Iron,8,0,0,0,5);
365  Bbul->SetLineColor(17);
366  Bbul->SetFillColor(17);
367 
368  // drawing arms
369  top->AddNodeOverlap(S,1,new TGeoCombiTrans(3,73,30,new TGeoRotation("R2",0,-30,0)));
370  top->AddNodeOverlap(S,1,new TGeoCombiTrans(3,-73,30,new TGeoRotation("R2",0,210,0)));
371  top->AddNodeOverlap(S_1,1,new TGeoCombiTrans(3,-73,27,new TGeoRotation("R2",0,0,0)));
372  top->AddNodeOverlap(S_1,1,new TGeoCombiTrans(3,73,27,new TGeoRotation("R2",0,0,0)));
373  top->AddNodeOverlap(Pal,1,new TGeoCombiTrans(3,-73,-5,new TGeoRotation("R2",0,0,0)));
374  top->AddNodeOverlap(Pal,1,new TGeoCombiTrans(3,73,-5,new TGeoRotation("R2",0,0,0)));
375  top->AddNodeOverlap(Fal,1,new TGeoCombiTrans(3,-73,-60,new TGeoRotation("R2",0,0,0)));
376  top->AddNodeOverlap(Fal,1,new TGeoCombiTrans(3,73,-60,new TGeoRotation("R2",0,0,0)));
377  top->AddNodeOverlap(Bbul,1,new TGeoCombiTrans(3,-97,-72,new TGeoRotation("R2",0,-90,0)));
378  top->AddNodeOverlap(Bbul,1,new TGeoCombiTrans(3,-97,-48,new TGeoRotation("R2",0,-90,0)));
379  top->AddNodeOverlap(Bbul,1,new TGeoCombiTrans(3,97,-72,new TGeoRotation("R2",0,90,0)));
380  top->AddNodeOverlap(Bbul,1,new TGeoCombiTrans(3,97,-48,new TGeoRotation("R2",0,90,0)));
381 
382  // hands
383  TGeoVolume *Son_d=Robot->MakeBox("Son_d",Iron,15,15,7);
384  Son_d->SetLineColor(4);
385  Son_d->SetFillColor(4);
386  TGeoVolume *Son_g=Robot->MakeBox("Son_g",Iron,4,10,4);
387  Son_g->SetLineColor(4);
388  Son_g->SetFillColor(4);
389  TGeoVolume *Son_g1=Robot->MakeBox("Son_g1",Iron,6,6,6);
390  Son_g1->SetLineColor(4);
391  Son_g1->SetFillColor(4);
392  TGeoVolume *Son_g2=Robot->MakeBox("Son_g2",Iron,8,3,3);
393  Son_g2->SetLineColor(4);
394  Son_g2->SetFillColor(4);
395  TGeoVolume *Last_b=Robot->MakeCone("Last_b",Iron,10,0,0,0,4);
396  Last_b->SetLineColor(17);
397  Last_b->SetFillColor(17);
398  TGeoVolume *Last=Robot->MakeSphere("Last",Iron,0,3,0,180,0,360);
399  Last->SetLineColor(2);
400  Last->SetFillColor(2);
401 
402  //drawing hands
403  top->AddNodeOverlap(Son_d,1,new TGeoCombiTrans(3,-80,-105,new TGeoRotation("R2",0,90,0)));
404  for (int i=0; i<4; i++) {
405  top->AddNodeOverlap(Son_g,1,new TGeoCombiTrans(-6+6*i,-72,-118,new TGeoRotation("R2",0,-10,0)));
406  }
407  for (int i=0; i<4; i++) {
408  top->AddNodeOverlap(Son_g,1,new TGeoCombiTrans(-6+6*i,-67,-113,new TGeoRotation("R2",0,110,0)));
409  }
410  top->AddNodeOverlap(Son_g1,1,new TGeoCombiTrans(-5,-70,-98,new TGeoRotation("R2",0,0,0)));
411  top->AddNodeOverlap(Son_g2,1,new TGeoCombiTrans(-5,-65,-102,new TGeoRotation("R2",0,60,0)));
412  top->AddNodeOverlap(Son_d,1,new TGeoCombiTrans(3,80,-105,new TGeoRotation("R2",0,90,0)));
413  for (int i=0; i<4; i++) {
414  top->AddNodeOverlap(Son_g,1,new TGeoCombiTrans(-6+6*i,72,-118,new TGeoRotation("R2",0,10,0)));
415  }
416  for (int i=0; i<4; i++) {
417  top->AddNodeOverlap(Son_g,1,new TGeoCombiTrans(-6+6*i,67,-113,new TGeoRotation("R2",0,70,0)));
418  }
419  top->AddNodeOverlap(Son_g1,1,new TGeoCombiTrans(-5,70,-98,new TGeoRotation("R2",0,0,0)));
420  top->AddNodeOverlap(Son_g2,1,new TGeoCombiTrans(-5,65,-102,new TGeoRotation("R2",0,60,0)));
421  top->AddNodeOverlap(Last_b,1,new TGeoCombiTrans(3,-88,-103,new TGeoRotation("R2",0,180,0)));
422  top->AddNodeOverlap(Last_b,1,new TGeoCombiTrans(12,-88,-103,new TGeoRotation("R2",0,180,0)));
423  top->AddNodeOverlap(Last_b,1,new TGeoCombiTrans(-7,-88,-103,new TGeoRotation("R2",0,180,0)));
424  top->AddNodeOverlap(Last_b,1,new TGeoCombiTrans(3,88,-103,new TGeoRotation("R2",0,180,0)));
425  top->AddNodeOverlap(Last_b,1,new TGeoCombiTrans(12,88,-103,new TGeoRotation("R2",0,180,0)));
426  top->AddNodeOverlap(Last_b,1,new TGeoCombiTrans(-7,88,-103,new TGeoRotation("R2",0,180,0)));
427  top->AddNodeOverlap(Last,1,new TGeoCombiTrans(3,-88,-112,new TGeoRotation("R2",0,180,0)));
428  top->AddNodeOverlap(Last,1,new TGeoCombiTrans(12,-88,-112,new TGeoRotation("R2",0,180,0)));
429  top->AddNodeOverlap(Last,1,new TGeoCombiTrans(-7,-88,-112,new TGeoRotation("R2",0,180,0)));
430  top->AddNodeOverlap(Last,1,new TGeoCombiTrans(3,88,-112,new TGeoRotation("R2",0,180,0)));
431  top->AddNodeOverlap(Last,1,new TGeoCombiTrans(12,88,-112,new TGeoRotation("R2",0,180,0)));
432  top->AddNodeOverlap(Last,1,new TGeoCombiTrans(-7,88,-112,new TGeoRotation("R2",0,180,0)));
433 
434 for (int i=1; i<20; i+=1) {
435  if (i<7) {
436  TGeoVolume *Effect=Robot->MakeCons("Effect",Iron,3,20/sin(i),21/sin(i),20/sin(i),21/sin(i),0,70);
437  Effect->SetLineColor(9);
438  Effect->SetFillColor(9);
439  top->AddNodeOverlap(Effect,1,new TGeoTranslation(3,0,-280));
440  }
441  if (6<i && i<10) {
442  TGeoVolume *Effect=Robot->MakeCons("Effect",Iron,5,20/sin(i),21/sin(i),20/sin(i),21/sin(i),50,120);
443  Effect->SetLineColor(38);
444  Effect->SetFillColor(38);
445  top->AddNodeOverlap(Effect,1,new TGeoTranslation(3,0,-280));
446  }
447  if (9<i && i<20) {
448  TGeoVolume *Effect=Robot->MakeCons("Effect",Iron,4,20/sin(i),21/sin(i),20/sin(i),21/sin(i),200,330);
449  Effect->SetLineColor(33);
450  Effect->SetFillColor(33);
451  top->AddNodeOverlap(Effect,1,new TGeoTranslation(3,0,-280));
452  }
453 }
454 
455 
456  //close geometry
457  top->SetVisibility(0);
458  Robot->CloseGeometry();
459 
460  // in GL viewer
461  top->Draw("ogl");
462 }
void SetTopVisible(Bool_t vis=kTRUE)
make top volume visible on screen
TGeoVolume * MakeGtra(const char *name, TGeoMedium *medium, Double_t dz, Double_t theta, Double_t phi, Double_t twist, Double_t h1, Double_t bl1, Double_t tl1, Double_t alpha1, Double_t h2, Double_t bl2, Double_t tl2, Double_t alpha2)
Make in one step a volume pointing to a twisted trapezoid shape with given medium.
TGeoVolume * MakeCone(const char *name, TGeoMedium *medium, Double_t dz, Double_t rmin1, Double_t rmax1, Double_t rmin2, Double_t rmax2)
Make in one step a volume pointing to a cone shape with given medium.
TGeoVolume * MakeCons(const char *name, TGeoMedium *medium, Double_t dz, Double_t rmin1, Double_t rmax1, Double_t rmin2, Double_t rmax2, Double_t phi1, Double_t phi2)
Make in one step a volume pointing to a cone segment shape with given medium.
virtual void AddNodeOverlap(TGeoVolume *vol, Int_t copy_no, TGeoMatrix *mat=0, Option_t *option="")
Add a TGeoNode to the list of nodes.
virtual void Draw(Option_t *option="")
draw top volume according to option
#define N
void SetTopVolume(TGeoVolume *vol)
Set the top volume and corresponding node as starting point of the geometry.
TArc * a
Definition: textangle.C:12
double cos(double)
TGeoVolume * MakeSphere(const char *name, TGeoMedium *medium, Double_t rmin, Double_t rmax, Double_t themin=0, Double_t themax=180, Double_t phimin=0, Double_t phimax=360)
Make in one step a volume pointing to a sphere shape with given medium.
TGeoVolume * MakeBox(const char *name, TGeoMedium *medium, Double_t dx, Double_t dy, Double_t dz)
Make in one step a volume pointing to a box shape with given medium.
TGeoVolume * MakeEltu(const char *name, TGeoMedium *medium, Double_t a, Double_t b, Double_t dz)
Make in one step a volume pointing to a tube shape with given medium.
double sin(double)
virtual void SetFillColor(Color_t fcolor)
Definition: TAttFill.h:50
void CloseGeometry(Option_t *option="d")
Closing geometry implies checking the geometry validity, fixing shapes with negative parameters (run-...
void robot()
Definition: robot.C:3
TGeoVolume * MakeTrd2(const char *name, TGeoMedium *medium, Double_t dx1, Double_t dx2, Double_t dy1, Double_t dy2, Double_t dz)
Make in one step a volume pointing to a TGeoTrd2 shape with given medium.
virtual void SetVisibility(Bool_t vis=kTRUE)
set visibility of this volume
static const float S
Definition: mandel.cpp:113
virtual void SetLineColor(Color_t lcolor)
Set the line color.
#define name(a, b)
Definition: linkTestLib0.cpp:5