PixelLightAPI
.
|
00001 /*********************************************************\ 00002 * File: VertexWeights.h * 00003 * 00004 * Copyright (C) 2002-2011 The PixelLight Team (http://www.pixellight.org/) 00005 * 00006 * This file is part of PixelLight. 00007 * 00008 * PixelLight is free software: you can redistribute it and/or modify 00009 * it under the terms of the GNU Lesser General Public License as published by 00010 * the Free Software Foundation, either version 3 of the License, or 00011 * (at your option) any later version. 00012 * 00013 * PixelLight is distributed in the hope that it will be useful, 00014 * but WITHOUT ANY WARRANTY; without even the implied warranty of 00015 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the 00016 * GNU Lesser General Public License for more details. 00017 * 00018 * You should have received a copy of the GNU Lesser General Public License 00019 * along with PixelLight. If not, see <http://www.gnu.org/licenses/>. 00020 \*********************************************************/ 00021 00022 00023 #ifndef __PLMESH_VERTEXWEIGHTS_H__ 00024 #define __PLMESH_VERTEXWEIGHTS_H__ 00025 #pragma once 00026 00027 00028 //[-------------------------------------------------------] 00029 //[ Includes ] 00030 //[-------------------------------------------------------] 00031 #include <PLCore/Container/Array.h> 00032 #include "PLMesh/PLMesh.h" 00033 00034 00035 //[-------------------------------------------------------] 00036 //[ Namespace ] 00037 //[-------------------------------------------------------] 00038 namespace PLMesh { 00039 00040 00041 //[-------------------------------------------------------] 00042 //[ Classes ] 00043 //[-------------------------------------------------------] 00044 /** 00045 * @brief 00046 * Vertex weights class for managing a list of weights per vertex 00047 * 00048 * @note 00049 * - A vertex can have multiple weights 00050 */ 00051 class VertexWeights { 00052 00053 00054 //[-------------------------------------------------------] 00055 //[ Public functions ] 00056 //[-------------------------------------------------------] 00057 public: 00058 /** 00059 * @brief 00060 * Constructor 00061 */ 00062 PLMESH_API VertexWeights(); 00063 00064 /** 00065 * @brief 00066 * Destructor 00067 */ 00068 PLMESH_API ~VertexWeights(); 00069 00070 /** 00071 * @brief 00072 * Get the vertex weight indices array 00073 * 00074 * @return 00075 * Vertex weight indices array 00076 * 00077 * @note 00078 * - This array holds the vertex weight indices per vertex 00079 * (see Mesh::GetVertexWeights()) 00080 */ 00081 PLMESH_API PLCore::Array<PLCore::uint32> &GetWeights(); 00082 PLMESH_API const PLCore::Array<PLCore::uint32> &GetWeights() const; 00083 00084 /** 00085 * @brief 00086 * Copy operator 00087 * 00088 * @param[in] cSource 00089 * Source to copy from 00090 * 00091 * @return 00092 * This vertex weights 00093 */ 00094 PLMESH_API VertexWeights &operator =(const VertexWeights &cSource); 00095 00096 /** 00097 * @brief 00098 * Compares two vertex weights 00099 * 00100 * @param[in] cVertexWeights 00101 * Vertex weights to compare with 00102 * 00103 * @return 00104 * 'true' if both vertex weights are equal, else 'false' 00105 */ 00106 PLMESH_API bool operator ==(const VertexWeights &cVertexWeights) const; 00107 00108 00109 //[-------------------------------------------------------] 00110 //[ Private data ] 00111 //[-------------------------------------------------------] 00112 private: 00113 PLCore::Array<PLCore::uint32> m_lstWeights; /**< Vertex weights */ 00114 00115 00116 }; 00117 00118 00119 //[-------------------------------------------------------] 00120 //[ Namespace ] 00121 //[-------------------------------------------------------] 00122 } // PLMesh 00123 00124 00125 #endif // __PLMESH_VERTEXWEIGHTS_H__
|