// @(#)root/g3d:$Id$
// Author: Nenad Buncic   19/09/95

/*************************************************************************
 * Copyright (C) 1995-2000, Rene Brun and Fons Rademakers.               *
 * All rights reserved.                                                  *
 *                                                                       *
 * For the licensing terms see $ROOTSYS/LICENSE.                         *
 * For the list of contributors see $ROOTSYS/README/CREDITS.             *
 *************************************************************************/

#include "TTRAP.h"
#include "TNode.h"
#include "TMath.h"

ClassImp(TTRAP)


//______________________________________________________________________________
// Begin_Html <P ALIGN=CENTER> <IMG SRC="gif/trap.gif"> </P> End_Html
// TRAP is a general trapezoid. The faces perpendicular to z are trapezia and
// their centres are not necessarily on a line parallel to the z axis.
// This shape has 14 parameters.
//
//     - name       name of the shape
//     - title      shape's title
//     - material  (see TMaterial)
//     - dz         half-length along the z axis
//     - theta      polar angle of the line joining the centre of the face
//                  at -DZ to the centre of the one at +DZ
//     - phi        azimuthal angle of the line joining the centre of the face
//                  at -DZ to the centre of the one at +DZ
//     - h1         half-length along y of the face at -DZ
//     - bl1        half-length along x of the side at -H1 in y of the face
//                  at -DZ in z
//     - tl1        half-length along x of the side at +H1 in y of the face
//                  at -DZ in z
//     - alpha1     angle with respect to the y axis from the centre of the
//                  side at -H1 in y to the centre of the side at +H1 in y
//                  of the face at -DZ in z
//     - h2         half-length along y of the face at +DZ
//     - bl2        half-length along x of the side at -H2 in y of the
//                  face at +DZ in z
//     - tl2        half-length along x of the side at +H2 in y of the face
//                  at +DZ in z
//     - alpha2     angle with respect to the y axis from the centre of the side
//                  at -H2 in y to the centre of the side at +H2 in y of the
//                  face at +DZ in z


//______________________________________________________________________________
TTRAP::TTRAP()
{
   // TRAP shape default constructor

   fH1     = 0.;
   fBl1    = 0.;
   fTl1    = 0.;
   fAlpha1 = 0.;
   fH2     = 0.;
   fBl2    = 0.;
   fTl2    = 0.;
   fAlpha2 = 0.;
}


//______________________________________________________________________________
TTRAP::TTRAP(const char *name, const char *title, const char *material, Float_t dz, Float_t theta, Float_t phi,
             Float_t h1, Float_t bl1, Float_t tl1, Float_t alpha1, Float_t h2,
             Float_t bl2, Float_t tl2, Float_t alpha2) : TBRIK(name, title,material,theta,phi,dz)
{
   // TRAP shape normal constructor

   fH1     = h1;
   fBl1    = bl1;
   fTl1    = tl1;
   fAlpha1 = alpha1;
   fH2     = h2;
   fBl2    = bl2;
   fTl2    = tl2;
   fAlpha2 = alpha2;
}


//______________________________________________________________________________
TTRAP::~TTRAP()
{
   // TRAP shape default destructor
}

//______________________________________________________________________________
void TTRAP::SetPoints(Double_t *points) const
{
   // Create TRAP points

   const Float_t pi = Float_t (TMath::Pi());
   Float_t alpha1 = fAlpha1    * pi/180.0;
   Float_t alpha2 = fAlpha2    * pi/180.0;
   Float_t theta  = TBRIK::fDx * pi/180.0;
   Float_t phi    = TBRIK::fDy * pi/180.0;
   Float_t tth    = TMath::Tan(theta);
   Float_t tx     = tth*TMath::Cos(phi);
   Float_t ty     = tth*TMath::Sin(phi);
   Float_t tth1   = TMath::Tan(alpha1);
   Float_t tth2   = TMath::Tan(alpha2);

   if (points) {
      points[ 0] = -fDz*tx-tth1*fH1-fBl1 ; points[ 1] = -fH1-fDz*ty ; points[ 2] = -fDz;
      points[ 3] = -fDz*tx+tth1*fH1-fTl1 ; points[ 4] =  fH1-fDz*ty ; points[ 5] = -fDz;
      points[ 6] = -fDz*tx+tth1*fH1+fTl1 ; points[ 7] =  fH1-fDz*ty ; points[ 8] = -fDz;
      points[ 9] = -fDz*tx-tth1*fH1+fBl1 ; points[10] = -fH1-fDz*ty ; points[11] = -fDz;
      points[12] =  fDz*tx-tth2*fH2-fBl2 ; points[13] = -fH2+fDz*ty ; points[14] = fDz;
      points[15] =  fDz*tx+tth2*fH2-fTl2 ; points[16] =  fH2+fDz*ty ; points[17] = fDz;
      points[18] =  fDz*tx+tth2*fH2+fTl2 ; points[19] =  fH2+fDz*ty ; points[20] = fDz;
      points[21] =  fDz*tx-tth2*fH2+fBl2 ; points[22] = -fH2+fDz*ty ; points[23] = fDz;
   }
   
}
 TTRAP.cxx:1
 TTRAP.cxx:2
 TTRAP.cxx:3
 TTRAP.cxx:4
 TTRAP.cxx:5
 TTRAP.cxx:6
 TTRAP.cxx:7
 TTRAP.cxx:8
 TTRAP.cxx:9
 TTRAP.cxx:10
 TTRAP.cxx:11
 TTRAP.cxx:12
 TTRAP.cxx:13
 TTRAP.cxx:14
 TTRAP.cxx:15
 TTRAP.cxx:16
 TTRAP.cxx:17
 TTRAP.cxx:18
 TTRAP.cxx:19
 TTRAP.cxx:20
 TTRAP.cxx:21
 TTRAP.cxx:22
 TTRAP.cxx:23
 TTRAP.cxx:24
 TTRAP.cxx:25
 TTRAP.cxx:26
 TTRAP.cxx:27
 TTRAP.cxx:28
 TTRAP.cxx:29
 TTRAP.cxx:30
 TTRAP.cxx:31
 TTRAP.cxx:32
 TTRAP.cxx:33
 TTRAP.cxx:34
 TTRAP.cxx:35
 TTRAP.cxx:36
 TTRAP.cxx:37
 TTRAP.cxx:38
 TTRAP.cxx:39
 TTRAP.cxx:40
 TTRAP.cxx:41
 TTRAP.cxx:42
 TTRAP.cxx:43
 TTRAP.cxx:44
 TTRAP.cxx:45
 TTRAP.cxx:46
 TTRAP.cxx:47
 TTRAP.cxx:48
 TTRAP.cxx:49
 TTRAP.cxx:50
 TTRAP.cxx:51
 TTRAP.cxx:52
 TTRAP.cxx:53
 TTRAP.cxx:54
 TTRAP.cxx:55
 TTRAP.cxx:56
 TTRAP.cxx:57
 TTRAP.cxx:58
 TTRAP.cxx:59
 TTRAP.cxx:60
 TTRAP.cxx:61
 TTRAP.cxx:62
 TTRAP.cxx:63
 TTRAP.cxx:64
 TTRAP.cxx:65
 TTRAP.cxx:66
 TTRAP.cxx:67
 TTRAP.cxx:68
 TTRAP.cxx:69
 TTRAP.cxx:70
 TTRAP.cxx:71
 TTRAP.cxx:72
 TTRAP.cxx:73
 TTRAP.cxx:74
 TTRAP.cxx:75
 TTRAP.cxx:76
 TTRAP.cxx:77
 TTRAP.cxx:78
 TTRAP.cxx:79
 TTRAP.cxx:80
 TTRAP.cxx:81
 TTRAP.cxx:82
 TTRAP.cxx:83
 TTRAP.cxx:84
 TTRAP.cxx:85
 TTRAP.cxx:86
 TTRAP.cxx:87
 TTRAP.cxx:88
 TTRAP.cxx:89
 TTRAP.cxx:90
 TTRAP.cxx:91
 TTRAP.cxx:92
 TTRAP.cxx:93
 TTRAP.cxx:94
 TTRAP.cxx:95
 TTRAP.cxx:96
 TTRAP.cxx:97
 TTRAP.cxx:98
 TTRAP.cxx:99
 TTRAP.cxx:100
 TTRAP.cxx:101
 TTRAP.cxx:102
 TTRAP.cxx:103
 TTRAP.cxx:104
 TTRAP.cxx:105
 TTRAP.cxx:106
 TTRAP.cxx:107
 TTRAP.cxx:108
 TTRAP.cxx:109
 TTRAP.cxx:110
 TTRAP.cxx:111
 TTRAP.cxx:112
 TTRAP.cxx:113
 TTRAP.cxx:114
 TTRAP.cxx:115
 TTRAP.cxx:116
 TTRAP.cxx:117
 TTRAP.cxx:118