soc-2008-mxcurioni: first version of lib3ds code. It does NOT work yet and has to...
[blender.git] / source / blender / freestyle / intern / scene_graph / TriangleRep.cpp
1
2 //
3 //  Copyright (C) : Please refer to the COPYRIGHT file distributed 
4 //   with this source distribution. 
5 //
6 //  This program is free software; you can redistribute it and/or
7 //  modify it under the terms of the GNU General Public License
8 //  as published by the Free Software Foundation; either version 2
9 //  of the License, or (at your option) any later version.
10 //
11 //  This program is distributed in the hope that it will be useful,
12 //  but WITHOUT ANY WARRANTY; without even the implied warranty of
13 //  MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
14 //  GNU General Public License for more details.
15 //
16 //  You should have received a copy of the GNU General Public License
17 //  along with this program; if not, write to the Free Software
18 //  Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA  02111-1307, USA.
19 //
20 ///////////////////////////////////////////////////////////////////////////////
21
22 #include "TriangleRep.h"
23
24 void TriangleRep::ComputeBBox()
25 {
26   real XMax = _vertices[0][0];
27   real YMax = _vertices[0][1];
28   real ZMax = _vertices[0][2];
29
30   real XMin = _vertices[0][0];
31   real YMin = _vertices[0][1];
32   real ZMin = _vertices[0][2];
33
34   // parse all the coordinates to find 
35   // the XMax, YMax, ZMax
36   for(int i=0; i<3; ++i)
37   {
38     // X
39     if(_vertices[i][0] > XMax)
40       XMax = _vertices[i][0];
41     if(_vertices[i][0] < XMin)
42       XMin = _vertices[i][0];
43
44     // Y
45     if(_vertices[i][1] > YMax)
46       YMax = _vertices[i][1];
47     if(_vertices[i][1] < YMin)
48       YMin = _vertices[i][1];
49
50     // Z
51     if(_vertices[i][2] > ZMax)
52       ZMax = _vertices[i][2];
53     if(_vertices[i][2] < ZMin)
54       ZMin = _vertices[i][2];
55
56   }
57
58   setBBox(BBox<Vec3r>(Vec3r(XMin, YMin, ZMin), Vec3r(XMax, YMax, ZMax)));
59 }