Blender V2.61 - r43446

subd_ring.h

Go to the documentation of this file.
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