/* wavefront.h
*
* A Wavefront object defined from a .OBJ file. This can represent
* only a subset of all Wavefront objects.
*/
#ifndef WAVEFRONT_H
#define WAVEFRONT_H
#include “headers.h”
#include “seq.h”
#include “linalg.h”
#include “shadeMode.h”
#include “gpuProgram.h”
#include “linalg.h”
/* A material with lighting properties and perhaps a texture map
*/
enum { NEAREST, LINEAR, MIPMAP_NEAREST, MIPMAP_LINEAR };
typedef int TextureMode;
class wfMaterial {
unsigned char *readP6( char *filename ); /* read a P6 PPM file */
unsigned char *readPNG( char *filename ); /* read a P6 PPM file */
static unsigned char defaultTexmap[];
public:
char *name; /* name of material */
GLfloat diffuse[4]; /* diffuse component */
GLfloat ambient[4]; /* ambient component */
GLfloat specular[4]; /* specular component */
GLfloat emissive[4]; /* emmissive component */
GLfloat shininess; /* specular exponent */
GLubyte *texmap; /* texture map */
unsigned int width, height; /* texmap dimensions */
GLuint textureID; /* the OpenGL ID for this texture */
bool hasAlpha; /* texmap has alpha component */
wfMaterial() {}
wfMaterial( char *n ) {
name = new char[ strlen(n)+1 ];
strcpy( name, n );
diffuse[0] = 1.0; diffuse[1] = 1.0; diffuse[2] = 1.0; diffuse[3] = 1.0;
ambient[0] = 0.1; ambient[1] = 0.1; ambient[2] = 0.1; ambient[3] = 1.0;
specular[0] = 0.3; specular[1] = 0.3; specular[2] = 0.3; specular[3] = 1.0;
emissive[0] = 0.0; emissive[1] = 0.0; emissive[2] = 0.0; emissive[3] = 1.0;
shininess = 200;
texmap = NULL;
textureID = 0;
width = height = 0;
}
~wfMaterial() {
delete [] name;
}
void loadTexmap( char *filename ); /* read a ppm texture map */
void storeTexture( TextureMode tm ); /* record texture with OpenGL */
void setMaterial( bool useTex, bool useMat, GPUProgram * gpuProg ); /* set the current OpenGL context */
void unsetMaterial( bool useTextures, bool useMaterial, GPUProgram * gpuProg );
};
/* A triangle with vertices, vertex normals, texture coordinates, and
* a face normal
*/
class wfTriangle {
public:
GLuint vindices[3]; /* array of triangle vertex indices */
GLuint nindices[3]; /* array of triangle normal indices */
GLuint tindices[3]; /* array of triangle texcoord indices*/
GLuint findex; /* index of triangle facet normal */
};
/* A group of triangles sharing the same material
*/
class wfGroup {
public:
char *name; /* name of this group */
seq
wfMaterial *material; /* material for group */
GLuint VAO;
bool VAOinitialized;
wfGroup() {}
wfGroup( char *gname ) {
name = new char[ strlen(gname)+1 ];
strcpy( name, gname );
VAOinitialized = false;
}
~wfGroup() {
delete [] name;
}
wfGroup( const wfGroup & source ) { // copy constructor
name = strdup(source.name);
triangles = source.triangles;
material = source.material;
}
wfGroup const &operator=( wfGroup const &src ) { // assignment operator
if (this != &src) {
name = strdup(src.name);
triangles = src.triangles;
material = src.material;
}
return *this;
}
};
/* A model consisting of groups
*/
class wfModel {
char* pathname; /* path to this model */
char* mtllibname; /* name of the material library */
seq
seq
seq
seq
seq
seq
bool hasVertexNormals; /* ALL vertices have normals */
bool hasVertexTexCoords; /* ALL vertices have texture coordinates */
bool texturesInitialized;
wfMaterial* findMaterial( char *name ); /* find a named material */
wfGroup* findGroup( char *name ); /* find a named group */
void readMaterialLibrary( char *filename ); /* read all materials */
int lineNum;
public:
mat4 objToWorldTransform;
vec3 centre; /* centre of point cloud */
float radius; /* radius of point cloud */
// Global vars controlling the rendering
static bool newGroupWithNewMaterial; /* create a new group each time the material changes */
static bool verticesAreCW; /* calculate opposite-to-usual face normals */
vec3 min, max; /* extents */
wfModel() {
texturesInitialized = false;
pathname = mtllibname = NULL;
objToWorldTransform = identity4();
}
wfModel( char *filename, TextureMode textureMode ) {
texturesInitialized = false;
pathname = mtllibname = NULL;
objToWorldTransform = identity4();
read( filename );
setupVAO( textureMode );
}
~wfModel() {
}
void read( char *filename ); /* instantiate this model from a file */
void draw( GPUProgram * gpuProg );
void setupVAO( TextureMode textureMode );
void initTextures( TextureMode tm ); /* assign texture IDs and store all textures */
void checkVindex( int v ) {
if (v < 0 || v >= vertices.size()) {
cerr << "error on line " << lineNum
<< ": vertex index " << v+1 << " is too large. There are only "
<< vertices.size() << " vertices." << endl;
abort();
}
}
};
#endif