Blender V2.61 - r43446
|
00001 /* 00002 * Copyright 2006, NVIDIA Corporation Ignacio Castano <icastano@nvidia.com> 00003 * 00004 * Modifications copyright (c) 2011, Blender Foundation. 00005 * All rights reserved. 00006 * 00007 * Permission is hereby granted, free of charge, to any person obtaining a copy 00008 * of this software and associated documentation files (the "Software"), to deal 00009 * in the Software without restriction, including without limitation the rights 00010 * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell 00011 * copies of the Software, and to permit persons to whom the Software is 00012 * furnished to do so, subject to the following conditions: 00013 * 00014 * The above copyright notice and this permission notice shall be included in 00015 * all copies or substantial portions of the Software. 00016 * 00017 * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR 00018 * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, 00019 * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE 00020 * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER 00021 * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, 00022 * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN 00023 * THE SOFTWARE. 00024 */ 00025 00026 #ifndef __SUBD_FACE_RING_H__ 00027 #define __SUBD_FACE_RING_H__ 00028 00029 CCL_NAMESPACE_BEGIN 00030 00031 class StencilMask; 00032 class SubdVert; 00033 class SubdEdge; 00034 class SubdFace; 00035 00036 class SubdFaceRing 00037 { 00038 public: 00039 SubdFaceRing(SubdFace *face, SubdEdge *edge); 00040 00041 SubdFace *face() { return m_face; } 00042 SubdEdge *firstEdge() { return m_firstEdge; } 00043 00044 int num_verts(); 00045 SubdVert *vertexAt(int i); 00046 int vert_index(SubdVert *vertex); 00047 00048 void evaluate_stencils(float3 *P, StencilMask *mask, int num); 00049 00050 bool is_triangle(); 00051 bool is_quad(); 00052 int num_edges(); 00053 00054 static bool is_regular(SubdFace *face); 00055 static bool is_triangle(SubdFace *face); 00056 static bool is_quad(SubdFace *face); 00057 static bool is_boundary(SubdFace *face); 00058 00059 protected: 00060 void initVerts(); 00061 void add_vert(SubdVert *vertex); 00062 bool has_vert(SubdVert *vertex); 00063 00064 protected: 00065 SubdFace *m_face; 00066 SubdEdge *m_firstEdge; 00067 00068 int m_num_edges; 00069 vector<SubdVert*> m_verts; 00070 }; 00071 00072 CCL_NAMESPACE_END 00073 00074 #endif /* __SUBD_FACE_RING_H__ */ 00075