Cycles: svn merge -r41225:41232 ^/trunk/blender
[blender.git] / intern / cycles / subd / subd_ring.h
1 /*
2  * Copyright 2006, NVIDIA Corporation Ignacio Castano <icastano@nvidia.com>
3  *
4  * Modifications copyright (c) 2011, Blender Foundation.
5  * All rights reserved.
6  * 
7  * Permission is hereby granted, free of charge, to any person obtaining a copy
8  * of this software and associated documentation files (the "Software"), to deal
9  * in the Software without restriction, including without limitation the rights
10  * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
11  * copies of the Software, and to permit persons to whom the Software is
12  * furnished to do so, subject to the following conditions:
13  * 
14  * The above copyright notice and this permission notice shall be included in
15  * all copies or substantial portions of the Software.
16  * 
17  * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
18  * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
19  * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
20  * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
21  * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
22  * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
23  * THE SOFTWARE.
24  */
25
26 #ifndef __SUBD_FACE_RING_H__
27 #define __SUBD_FACE_RING_H__
28
29 CCL_NAMESPACE_BEGIN
30
31 class StencilMask;
32 class SubdVert;
33 class SubdEdge;
34 class SubdFace;
35
36 class SubdFaceRing
37 {
38 public:
39         SubdFaceRing(SubdFace *face, SubdEdge *edge);
40
41         SubdFace *face() { return m_face; }
42         SubdEdge *firstEdge() { return m_firstEdge; }
43
44         int num_verts();
45         SubdVert *vertexAt(int i);
46         int vert_index(SubdVert *vertex);
47
48         void evaluate_stencils(float3 *P, StencilMask *mask, int num);
49
50         bool is_triangle();
51         bool is_quad();
52         int num_edges();
53
54         static bool is_regular(SubdFace *face);
55         static bool is_triangle(SubdFace *face);
56         static bool is_quad(SubdFace *face);
57         static bool is_boundary(SubdFace *face);
58
59 protected:
60         void initVerts();
61         void add_vert(SubdVert *vertex);
62         bool has_vert(SubdVert *vertex);
63
64 protected:
65         SubdFace *m_face;
66         SubdEdge *m_firstEdge;
67
68         int m_num_edges;
69         vector<SubdVert*> m_verts;
70 };
71
72 CCL_NAMESPACE_END
73
74 #endif /* __SUBD_FACE_RING_H__ */
75