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 CYBPFINDEXEDFACESETC_H 00026 #define CYBPFINDEXEDFACESETC_H 00027 00028 00029 #include "oaw/ctk/cybindexedfacesetc.h" 00030 #include "cybpfgeometryc.h" 00031 00032 class pfNode; 00033 class pfDCS; 00034 class pfGeode; 00035 class pfVec3; 00036 00037 class CybPFIndexedFaceSetC : public CybIndexedFaceSetC, 00038 public CybPFGeometryC, 00039 public virtual CybPFGeometryI 00040 { 00041 public: 00042 CybPFIndexedFaceSetC(CybWorldC*); 00043 virtual ~CybPFIndexedFaceSetC(); 00044 CybPFIndexedFaceSetC(const CybPFIndexedFaceSetC&); 00045 CybPFIndexedFaceSetC& operator = (const CybPFIndexedFaceSetC&); 00046 //virtual void GetMessageAsObjectI(void*,long,SharedObjectC*); 00047 virtual void EventCascadeEnd(); 00048 virtual void FinishInit(); 00049 virtual void SetPFGeoState(pfGeoState*); 00050 virtual void* GetImpl(){return this;} 00051 pfNode* GetPFNode(); 00052 int GetSolid(){return m_solid;} 00053 protected: 00054 void SetVertices(); 00055 void SetPFGeometryValues(); 00056 protected: 00057 pfGeoSet* m_pPFGeoSet; 00058 pfGeode* m_pPFGeode; 00059 unsigned short* m_PFIndexCoord; 00060 unsigned short* m_PFIndexNormal; 00061 unsigned short* m_PFIndexColor; 00062 unsigned short* m_PFIndexTexCoord; 00063 int* m_primLengths; 00064 long m_primsNum; 00065 00066 }; 00067 00068 00069 00070 #endif 00071 00072 00073 00074 00075
1.3-rc2