00001 /* 00002 Copyright (C) 1999 Carsten Winkelholz 00003 00004 Address: FGAN Forschungsgesellschaft fr Angewandte Naturwissenschaften e. V. 00005 Neuenahrer Str. 20 00006 D - 53343 Wachtberg 00007 00008 Email: winkelholz@fgan.de 00009 00010 This program is free software; you can redistribute it and/or 00011 modify it under the terms of the GNU General Public License 00012 as published by the Free Software Foundation; either version 2 00013 of the License, or (at your option) any later version. 00014 00015 This program is distributed in the hope that it will be useful, 00016 but WITHOUT ANY WARRANTY; without even the implied warranty of 00017 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the 00018 GNU General Public License for more details. 00019 00020 You should have received a copy of the GNU General Public License 00021 along with this program; if not, write to the Free Software 00022 Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. 00023 */ 00024 00025 #ifndef CYBPFBOXC_H 00026 #define CYBPFBOXC_H 00027 00028 00029 #include "oaw/ctk/cybboxc.h" 00030 #include "cybpfgeometryc.h" 00031 #include <Performer/pf/pfGeode.h> 00032 00033 class pfNode; 00034 class pfDCS; 00035 00036 class CybPFBoxC : public CybBoxC, 00037 public CybPFGeometryC, 00038 public virtual CybPFGeometryI 00039 { 00040 public: 00041 CybPFBoxC(CybWorldC*,double,double,double); 00042 virtual ~CybPFBoxC(); 00043 CybPFBoxC(const CybPFBoxC&); 00044 CybPFBoxC& operator = (const CybPFBoxC&); 00045 virtual void FinishInit(); 00046 virtual void SetPFGeoState(pfGeoState*); 00047 virtual void* GetImpl(){return this;} 00048 pfNode* GetPFNode(); 00049 int GetSolid(){return 1;} 00050 virtual void SetSize(const VectorC& size); 00051 virtual void SetEvent(long,const void*, BaseI*); 00052 protected: 00053 void SetCoords(); 00054 protected: 00055 pfGeoSet* m_pPFGeoSet; 00056 pfGeode* m_pPFGeode; 00057 pfDCS* m_pPFDcs; 00058 pfVec3* m_coords; 00059 pfVec3* m_normals; 00060 pfVec2* m_texcoords; 00061 unsigned short* m_indexCoord; 00062 unsigned short* m_indexTex; 00063 unsigned short* m_indexNormal; 00064 }; 00065 00066 00067 #endif 00068 00069 00070 00071 00072
1.3-rc2