// @(#)root/eve:$Id$
// Authors: Matevz Tadel & Alja Mrak-Tadel: 2006, 2007

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

#ifndef ROOT_TEveTriangleSet
#define ROOT_TEveTriangleSet

#include "TEveElement.h"
#include "TNamed.h"
#include "TAttBBox.h"
#include "TAtt3D.h"

#include "TEveTrans.h"

class TGeoMatrix;

class TEveTriangleSet : public TEveElementList,
                        public TAtt3D,
                        public TAttBBox
{
   friend class TEveTriangleSetEditor;
   friend class TEveTriangleSetGL;

   TEveTriangleSet(const TEveTriangleSet&);            // Not implemented
   TEveTriangleSet& operator=(const TEveTriangleSet&); // Not implemented

protected:
   // Vertex data
   Int_t    fNVerts;
   Float_t* fVerts;        //[3*fNVerts]

   // Triangle data
   Int_t    fNTrings;
   Int_t*   fTrings;       //[3*fNTrings]
   Float_t* fTringNorms;   //[3*fNTrings]
   UChar_t* fTringCols;    //[3*fNTrings]

public:
   TEveTriangleSet(Int_t nv, Int_t nt, Bool_t norms=kFALSE, Bool_t cols=kFALSE);
   ~TEveTriangleSet();

   virtual Bool_t CanEditMainTransparency() const { return kTRUE; }

   Int_t GetNVerts()  const { return fNVerts;  }
   Int_t GetNTrings() const { return fNTrings; }

   Float_t* Vertex(Int_t i)         { return &(fVerts[3*i]);      }
   Int_t*   Triangle(Int_t i)       { return &(fTrings[3*i]);     }
   Float_t* TriangleNormal(Int_t i) { return &(fTringNorms[3*i]); }
   UChar_t* TriangleColor(Int_t i)  { return &(fTringCols[3*i]);  }

   void SetVertex(Int_t i, Float_t x, Float_t y, Float_t z)
   { Float_t* v = Vertex(i); v[0] = x; v[1] = y; v[2] = z; }
   void SetTriangle(Int_t i, Int_t v0, Int_t v1, Int_t v2)
   { Int_t* t = Triangle(i); t[0] = v0; t[1] = v1; t[2] = v2; }
   void SetTriangleColor(Int_t i, UChar_t r, UChar_t g, UChar_t b, UChar_t a=255)
   { UChar_t* c = TriangleColor(i); c[0] = r; c[1] = g; c[2] = b; c[3] = a; }

   void GenerateTriangleNormals();
   void GenerateRandomColors();
   void GenerateZNormalColors(Float_t fac=20, Int_t min=-20, Int_t max=20,
                              Bool_t interp=kFALSE, Bool_t wrap=kFALSE);

   virtual void ComputeBBox();
   virtual void Paint(Option_t* option="");

   void SetTransparency(Char_t tr) { SetMainTransparency(tr); } // *MENU*

   static TEveTriangleSet* ReadTrivialFile(const char* file);

   ClassDef(TEveTriangleSet, 0); // Generic mesh or soup of triangles with per-triangle normals and colors.
};

#endif
 TEveTriangleSet.h:1
 TEveTriangleSet.h:2
 TEveTriangleSet.h:3
 TEveTriangleSet.h:4
 TEveTriangleSet.h:5
 TEveTriangleSet.h:6
 TEveTriangleSet.h:7
 TEveTriangleSet.h:8
 TEveTriangleSet.h:9
 TEveTriangleSet.h:10
 TEveTriangleSet.h:11
 TEveTriangleSet.h:12
 TEveTriangleSet.h:13
 TEveTriangleSet.h:14
 TEveTriangleSet.h:15
 TEveTriangleSet.h:16
 TEveTriangleSet.h:17
 TEveTriangleSet.h:18
 TEveTriangleSet.h:19
 TEveTriangleSet.h:20
 TEveTriangleSet.h:21
 TEveTriangleSet.h:22
 TEveTriangleSet.h:23
 TEveTriangleSet.h:24
 TEveTriangleSet.h:25
 TEveTriangleSet.h:26
 TEveTriangleSet.h:27
 TEveTriangleSet.h:28
 TEveTriangleSet.h:29
 TEveTriangleSet.h:30
 TEveTriangleSet.h:31
 TEveTriangleSet.h:32
 TEveTriangleSet.h:33
 TEveTriangleSet.h:34
 TEveTriangleSet.h:35
 TEveTriangleSet.h:36
 TEveTriangleSet.h:37
 TEveTriangleSet.h:38
 TEveTriangleSet.h:39
 TEveTriangleSet.h:40
 TEveTriangleSet.h:41
 TEveTriangleSet.h:42
 TEveTriangleSet.h:43
 TEveTriangleSet.h:44
 TEveTriangleSet.h:45
 TEveTriangleSet.h:46
 TEveTriangleSet.h:47
 TEveTriangleSet.h:48
 TEveTriangleSet.h:49
 TEveTriangleSet.h:50
 TEveTriangleSet.h:51
 TEveTriangleSet.h:52
 TEveTriangleSet.h:53
 TEveTriangleSet.h:54
 TEveTriangleSet.h:55
 TEveTriangleSet.h:56
 TEveTriangleSet.h:57
 TEveTriangleSet.h:58
 TEveTriangleSet.h:59
 TEveTriangleSet.h:60
 TEveTriangleSet.h:61
 TEveTriangleSet.h:62
 TEveTriangleSet.h:63
 TEveTriangleSet.h:64
 TEveTriangleSet.h:65
 TEveTriangleSet.h:66
 TEveTriangleSet.h:67
 TEveTriangleSet.h:68
 TEveTriangleSet.h:69
 TEveTriangleSet.h:70
 TEveTriangleSet.h:71
 TEveTriangleSet.h:72
 TEveTriangleSet.h:73
 TEveTriangleSet.h:74
 TEveTriangleSet.h:75
 TEveTriangleSet.h:76
 TEveTriangleSet.h:77
 TEveTriangleSet.h:78
 TEveTriangleSet.h:79
 TEveTriangleSet.h:80
 TEveTriangleSet.h:81