00001 /************************************************************************* 00002 * * 00003 * Open Physics Abstraction Layer * 00004 * Copyright (C) 2004-2005 * 00005 * Alan Fischer alan.fischer@gmail.com * 00006 * Andres Reinot andres@reinot.com * 00007 * Tyler Streeter tylerstreeter@gmail.com * 00008 * All rights reserved. * 00009 * Web: opal.sourceforge.net * 00010 * * 00011 * This library is free software; you can redistribute it and/or * 00012 * modify it under the terms of EITHER: * 00013 * (1) The GNU Lesser General Public License as published by the Free * 00014 * Software Foundation; either version 2.1 of the License, or (at * 00015 * your option) any later version. The text of the GNU Lesser * 00016 * General Public License is included with this library in the * 00017 * file license-LGPL.txt. * 00018 * (2) The BSD-style license that is included with this library in * 00019 * the file license-BSD.txt. * 00020 * * 00021 * This library is distributed in the hope that it will be useful, * 00022 * but WITHOUT ANY WARRANTY; without even the implied warranty of * 00023 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the files * 00024 * license-LGPL.txt and license-BSD.txt for more details. * 00025 * * 00026 *************************************************************************/ 00027 00028 #ifndef OPAL_PLANE_SHAPE_DATA_H 00029 #define OPAL_PLANE_SHAPE_DATA_H 00030 00031 #include "Defines.h" 00032 #include "ShapeData.h" 00033 00034 namespace opal 00035 { 00037 class PlaneShapeData : public ShapeData 00038 { 00039 public: 00040 OPAL_DECL PlaneShapeData() 00041 : ShapeData() 00042 { 00043 mType = PLANE_SHAPE; 00044 00045 for (int i=0; i<4; ++i) 00046 { 00047 abcd[i] = defaults::shape::planeABCD[i]; 00048 } 00049 } 00050 00052 OPAL_DECL PlaneShapeData(const PlaneShapeData& data) 00053 { 00054 (*this) = data; 00055 } 00056 00057 OPAL_DECL virtual ~PlaneShapeData() 00058 { 00059 } 00060 00062 OPAL_DECL virtual void OPAL_CALL operator=(const PlaneShapeData& data) 00063 { 00064 mType = data.mType; 00065 offset = data.offset; 00066 material = data.material; 00067 contactGroup = data.contactGroup; 00068 00069 for (int i=0; i<4; ++i) 00070 { 00071 abcd[i] = data.abcd[i]; 00072 } 00073 } 00074 00076 OPAL_DECL virtual void OPAL_CALL getLocalAABB(real aabb[6]) 00077 { 00078 // Do nothing. 00079 } 00080 00083 real abcd[4]; 00084 00085 protected: 00086 00087 private: 00088 }; 00089 } 00090 00091 #endif