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 CYBPFCONEC_H 00026 #define CYBPFCONEC_H 00027 00028 00029 #include "oaw/ctk/cybconec.h" 00030 #include "cybpfgeometryc.h" 00031 00032 class pfNode; 00033 class pfDCS; 00034 class pfGeode; 00035 class pfVec3; 00036 00037 class CybPFConeC : public CybConeC, 00038 public CybPFGeometryC, 00039 public virtual CybPFGeometryI 00040 { 00041 public: 00042 CybPFConeC(CybWorldC*,double,double); 00043 virtual ~CybPFConeC(); 00044 CybPFConeC(const CybPFConeC&); 00045 CybPFConeC& operator = (const CybPFConeC&); 00046 virtual void FinishInit(); 00047 virtual void SetPFGeoState(pfGeoState*); 00048 virtual void* GetImpl(){return this;} 00049 pfNode* GetPFNode(); 00050 int GetSolid(){return m_bottom && m_side;} 00051 protected: 00052 void SetVertices(); 00053 protected: 00054 long m_phic; 00055 pfDCS* m_pPFDcs; 00056 pfGeoSet* m_pPFGeoSet_Bottom; 00057 pfGeoSet* m_pPFGeoSet_Side; 00058 pfGeode* m_pPFGeode; 00059 pfVec3* m_coords; 00060 pfVec3* m_normals; 00061 unsigned short* m_indexCoord_Bottom; 00062 unsigned short* m_indexCoord_Side; 00063 unsigned short* m_indexNormal_Bottom; 00064 unsigned short* m_indexNormal_Side; 00065 int* m_primLengths_Bottom; 00066 }; 00067 00068 00069 00070 #endif 00071 00072 00073 00074 00075
1.3-rc2