1 | #ifndef _FROG_Prim_TUBE_H__
|
---|
2 | #define _FROG_Prim_TUBE_H__
|
---|
3 |
|
---|
4 | #include "Base.h"
|
---|
5 |
|
---|
6 | namespace FROG{
|
---|
7 |
|
---|
8 | class Prim_Tube : public BaseColl_Id {
|
---|
9 | public :
|
---|
10 | float RadiusIn; float RadiusOut;
|
---|
11 | float PosX; float PosY; float PosZ;
|
---|
12 | float LengthX; float LengthY; float LengthZ;
|
---|
13 | unsigned short NPhi; unsigned char Endcap;
|
---|
14 | float Phi0;
|
---|
15 |
|
---|
16 | virtual unsigned int chunkId(){ return 41041;}
|
---|
17 | virtual bool isCompactible(){ return true; }
|
---|
18 |
|
---|
19 | Prim_Tube(){}
|
---|
20 | Prim_Tube(
|
---|
21 | unsigned int detId, float radiusIn,float radiusOut,
|
---|
22 | float posX, float posY, float posZ,
|
---|
23 | float lengthX, float lengthY, float lengthZ,
|
---|
24 | unsigned short nPhi=10, unsigned char endcap=0, float phi0=0) :
|
---|
25 | BaseColl_Id(detId),
|
---|
26 | RadiusIn(radiusIn), RadiusOut(radiusOut),
|
---|
27 | PosX(posX), PosY(posY), PosZ(posZ),
|
---|
28 | LengthX(lengthX), LengthY(lengthY), LengthZ(lengthZ),
|
---|
29 | NPhi(nPhi), Endcap(endcap), Phi0(phi0){}
|
---|
30 |
|
---|
31 | virtual ByteBuffer writeData(){
|
---|
32 | ByteBuffer toReturn(44);
|
---|
33 | toReturn.putUInt(detId_);
|
---|
34 | toReturn.putFloat(RadiusIn);
|
---|
35 | toReturn.putFloat(RadiusOut);
|
---|
36 | toReturn.putFloat(PosX);
|
---|
37 | toReturn.putFloat(PosY);
|
---|
38 | toReturn.putFloat(PosZ);
|
---|
39 | toReturn.putFloat(LengthX);
|
---|
40 | toReturn.putFloat(LengthY);
|
---|
41 | toReturn.putFloat(LengthZ);
|
---|
42 | toReturn.putUShort(NPhi);
|
---|
43 | toReturn.putUShort(Endcap);
|
---|
44 | toReturn.putFloat(Phi0);
|
---|
45 | return toReturn;
|
---|
46 | }
|
---|
47 | };
|
---|
48 |
|
---|
49 | }//FROG Namespace
|
---|
50 | #endif
|
---|