svn merge ^/trunk/blender -r48592:HEAD
[blender.git] / intern / dualcon / intern / ModelReader.h
1 /*
2  * ***** BEGIN GPL LICENSE BLOCK *****
3  *
4  * This program is free software; you can redistribute it and/or
5  * modify it under the terms of the GNU General Public License
6  * as published by the Free Software Foundation; either version 2
7  * of the License, or (at your option) any later version.
8  *
9  * This program is distributed in the hope that it will be useful,
10  * but WITHOUT ANY WARRANTY; without even the implied warranty of
11  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
12  * GNU General Public License for more details.
13  *
14  * You should have received a copy of the GNU General Public License
15  * along with this program; if not, write to the Free Software Foundation,
16  * Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
17  *
18  * Contributor(s): Tao Ju
19  *
20  * ***** END GPL LICENSE BLOCK *****
21  */
22
23 #ifndef MODELREADER_H
24 #define MODELREADER_H
25
26 #include "GeoCommon.h"
27
28 /*
29  * Virtual class for input file readers
30  *
31  * @author Tao Ju
32  */
33 class ModelReader
34 {
35 public:
36 /// Constructor
37 ModelReader(){
38 };
39
40 /// Get next triangle
41 virtual Triangle *getNextTriangle( ) = 0;
42 virtual int getNextTriangle(int t[3]) = 0;
43
44 /// Get bounding box
45 virtual float getBoundingBox(float origin[3]) = 0;
46
47 /// Get number of triangles
48 virtual int getNumTriangles( ) = 0;
49
50 /// Get storage size
51 virtual int getMemory( ) = 0;
52
53 /// Reset file reading location
54 virtual void reset( ) = 0;
55
56 /// For explicit vertex models
57 virtual int getNumVertices( ) = 0;
58
59 virtual void getNextVertex(float v[3]) = 0;
60
61 virtual void printInfo( ) = 0;
62 };
63
64
65 #endif