dungeon_crawler

changeset 11:e5567ddbf2ef

- Texture set (texture manager) - materials
author John Tsiombikas <nuclear@member.fsf.org>
date Sun, 19 Aug 2012 03:11:36 +0300 (2012-08-19)
parents 22562582c82d
children e95462632f9a
files prototype/Makefile prototype/src/material.cc prototype/src/material.h prototype/src/mesh.cc prototype/src/mesh.h prototype/src/texman.cc prototype/src/texman.h prototype/src/tile.cc prototype/src/tile.h prototype/src/tileset.cc prototype/src/tileset.h
diffstat 11 files changed, 202 insertions(+), 2 deletions(-) [+]
line diff
     1.1 --- a/prototype/Makefile	Sat Aug 18 03:47:13 2012 +0300
     1.2 +++ b/prototype/Makefile	Sun Aug 19 03:11:36 2012 +0300
     1.3 @@ -6,7 +6,7 @@
     1.4  
     1.5  CFLAGS = -pedantic -Wall -g -Ivmath
     1.6  CXXFLAGS = $(CFLAGS) -std=c++11
     1.7 -LDFLAGS = $(libgl) -lm -lassimp
     1.8 +LDFLAGS = $(libgl) -lm -lassimp -limago
     1.9  
    1.10  ifeq ($(shell uname -s), Darwin)
    1.11  	libgl = -framework OpenGL -framework GLUT -lglew
     2.1 --- /dev/null	Thu Jan 01 00:00:00 1970 +0000
     2.2 +++ b/prototype/src/material.cc	Sun Aug 19 03:11:36 2012 +0300
     2.3 @@ -0,0 +1,71 @@
     2.4 +#include <assert.h>
     2.5 +#include <assimp/material.h>
     2.6 +#include "opengl.h"
     2.7 +#include "material.h"
     2.8 +
     2.9 +Material::Material()
    2.10 +	: kd(1.0, 1.0, 1.0), ks(0.0, 0.0, 0.0)
    2.11 +{
    2.12 +	shin = 1.0;
    2.13 +	memset(tex, 0, sizeof tex);
    2.14 +}
    2.15 +
    2.16 +void Material::load(const aiMaterial *assmat, TextureSet *texset)
    2.17 +{
    2.18 +	aiColor4D col;
    2.19 +	float val;
    2.20 +
    2.21 +	aiGetMaterialColor(assmat, AI_MATKEY_COLOR_DIFFUSE, &col);
    2.22 +	kd = Color(col[0], col[1], col[2]);
    2.23 +	aiGetMaterialColor(assmat, AI_MATKEY_COLOR_SPECULAR, &col);
    2.24 +	ks = Color(col[0], col[1], col[2]);
    2.25 +
    2.26 +	unsigned int sz = 1;
    2.27 +	val = 60.0;
    2.28 +	aiGetMaterialFloatArray(assmat, AI_MATKEY_SHININESS, &val, &sz);
    2.29 +	if(val > 127) {
    2.30 +		printf("GOT SHININESS: %f\n", val);
    2.31 +		val = 127;
    2.32 +	}
    2.33 +	shin = val;
    2.34 +
    2.35 +	sz = 1;
    2.36 +	val = 1.0;
    2.37 +	aiGetMaterialFloatArray(assmat, AI_MATKEY_SHININESS_STRENGTH, &val, &sz);
    2.38 +	ks *= val;
    2.39 +
    2.40 +	// must match TEXTYPE enum in material.h
    2.41 +	unsigned int asstypes[] = {
    2.42 +		aiTextureType_DIFFUSE,
    2.43 +		aiTextureType_NORMALS,
    2.44 +		aiTextureType_SPECULAR
    2.45 +	};
    2.46 +
    2.47 +	for(int i=0; i<NUM_TEXTURE_TYPES; i++) {
    2.48 +		aiString tex_name;
    2.49 +		if(aiGetMaterialString(assmat, AI_MATKEY_TEXTURE(asstypes[i], 0), &tex_name) == 0) {
    2.50 +			tex[i] = texset->get_texture(tex_name.data);
    2.51 +		} else {
    2.52 +			tex[i] = 0;
    2.53 +		}
    2.54 +	}
    2.55 +}
    2.56 +
    2.57 +void Material::setup() const
    2.58 +{
    2.59 +	float dcol[] = {kd.x, kd.y, kd.z, 1.0};
    2.60 +	float scol[] = {ks.x, ks.y, ks.z, 1.0};
    2.61 +
    2.62 +	glMaterialfv(GL_FRONT_AND_BACK, GL_AMBIENT_AND_DIFFUSE, dcol);
    2.63 +	glMaterialfv(GL_FRONT_AND_BACK, GL_SPECULAR, scol);
    2.64 +	glMaterialf(GL_FRONT_AND_BACK, GL_SHININESS, shin);
    2.65 +
    2.66 +	if(tex[TEXTYPE_DIFFUSE]) {
    2.67 +		glActiveTextureARB(GL_TEXTURE0);
    2.68 +		glBindTexture(GL_TEXTURE_2D, tex[TEXTYPE_DIFFUSE]);
    2.69 +		glEnable(GL_TEXTURE_2D);
    2.70 +	} else {
    2.71 +		glDisable(GL_TEXTURE_2D);
    2.72 +	}
    2.73 +	glActiveTextureARB(GL_TEXTURE0);
    2.74 +}
     3.1 --- /dev/null	Thu Jan 01 00:00:00 1970 +0000
     3.2 +++ b/prototype/src/material.h	Sun Aug 19 03:11:36 2012 +0300
     3.3 @@ -0,0 +1,29 @@
     3.4 +#ifndef MATERIAL_H_
     3.5 +#define MATERIAL_H_
     3.6 +
     3.7 +#include "color.h"
     3.8 +#include "texman.h"
     3.9 +
    3.10 +enum {
    3.11 +	TEXTYPE_DIFFUSE,
    3.12 +	TEXTYPE_NORMAL,
    3.13 +	TEXTYPE_SPECULAR,
    3.14 +
    3.15 +	NUM_TEXTURE_TYPES
    3.16 +};
    3.17 +
    3.18 +class Material {
    3.19 +private:
    3.20 +	Color kd, ks;
    3.21 +	double shin;
    3.22 +	unsigned int tex[NUM_TEXTURE_TYPES];
    3.23 +
    3.24 +public:
    3.25 +	Material();
    3.26 +
    3.27 +	void load(const aiMaterial *assmat, TextureSet *texset = 0);
    3.28 +
    3.29 +	void setup() const;
    3.30 +};
    3.31 +
    3.32 +#endif	// MATERIAL_H_
     4.1 --- a/prototype/src/mesh.cc	Sat Aug 18 03:47:13 2012 +0300
     4.2 +++ b/prototype/src/mesh.cc	Sun Aug 19 03:11:36 2012 +0300
     4.3 @@ -105,6 +105,16 @@
     4.4  	return xform;
     4.5  }
     4.6  
     4.7 +void Mesh::set_material(const Material &mat)
     4.8 +{
     4.9 +	this->mat = mat;
    4.10 +}
    4.11 +
    4.12 +const Material &Mesh::get_material() const
    4.13 +{
    4.14 +	return mat;
    4.15 +}
    4.16 +
    4.17  void Mesh::set_attrib_location(int attr, int loc)
    4.18  {
    4.19  	if(attr == MESH_ATTR_TANGENT) {
    4.20 @@ -119,6 +129,8 @@
    4.21  
    4.22  void Mesh::draw() const
    4.23  {
    4.24 +	mat.setup();
    4.25 +
    4.26  	glMatrixMode(GL_MODELVIEW);
    4.27  	glPushMatrix();
    4.28  	mult_matrix(xform);
     5.1 --- a/prototype/src/mesh.h	Sat Aug 18 03:47:13 2012 +0300
     5.2 +++ b/prototype/src/mesh.h	Sun Aug 19 03:11:36 2012 +0300
     5.3 @@ -4,6 +4,7 @@
     5.4  #include <string>
     5.5  #include <assimp/scene.h>
     5.6  #include "vmath.h"
     5.7 +#include "material.h"
     5.8  
     5.9  enum {
    5.10  	MESH_ATTR_VERTEX,
    5.11 @@ -26,6 +27,7 @@
    5.12  
    5.13  	int tang_loc;
    5.14  
    5.15 +	Material mat;
    5.16  	Matrix4x4 xform;
    5.17  
    5.18  public:
    5.19 @@ -41,6 +43,9 @@
    5.20  	void set_xform(const Matrix4x4 &mat);
    5.21  	const Matrix4x4 &get_xform() const;
    5.22  
    5.23 +	void set_material(const Material &mat);
    5.24 +	const Material &get_material() const;
    5.25 +
    5.26  	void set_attrib_location(int attr, int loc);
    5.27  	int get_attrib_location(int attr) const;
    5.28  
     6.1 --- /dev/null	Thu Jan 01 00:00:00 1970 +0000
     6.2 +++ b/prototype/src/texman.cc	Sun Aug 19 03:11:36 2012 +0300
     6.3 @@ -0,0 +1,35 @@
     6.4 +#include <string.h>
     6.5 +#include "opengl.h"
     6.6 +#include "imago2.h"
     6.7 +#include "texman.h"
     6.8 +#include "datapath.h"
     6.9 +
    6.10 +TextureSet::~TextureSet()
    6.11 +{
    6.12 +	for(auto iter : textures) {
    6.13 +		glDeleteTextures(1, &iter.second);
    6.14 +	}
    6.15 +}
    6.16 +
    6.17 +unsigned int TextureSet::get_texture(const char *fname) const
    6.18 +{
    6.19 +	auto iter = textures.find(fname);
    6.20 +	if(iter != textures.end()) {
    6.21 +		return iter->second;
    6.22 +	}
    6.23 +
    6.24 +	const char *path, *slash;
    6.25 +	if((slash = strrchr(fname, '/'))) {
    6.26 +		path = slash + 1;
    6.27 +	}
    6.28 +	path = datafile_path(path);
    6.29 +
    6.30 +	printf("loading texture: %s\n", path);
    6.31 +	unsigned int tex = img_gltexture_load(path);
    6.32 +	if(tex) {
    6.33 +		textures[fname] = tex;
    6.34 +	} else {
    6.35 +		fprintf(stderr, "failed to load texture: %s\n", path);
    6.36 +	}
    6.37 +	return tex;
    6.38 +}
     7.1 --- /dev/null	Thu Jan 01 00:00:00 1970 +0000
     7.2 +++ b/prototype/src/texman.h	Sun Aug 19 03:11:36 2012 +0300
     7.3 @@ -0,0 +1,17 @@
     7.4 +#ifndef TEXMAN_H_
     7.5 +#define TEXMAN_H_
     7.6 +
     7.7 +#include <string>
     7.8 +#include <map>
     7.9 +
    7.10 +class TextureSet {
    7.11 +private:
    7.12 +	mutable std::map<std::string, unsigned int> textures;
    7.13 +
    7.14 +public:
    7.15 +	~TextureSet();
    7.16 +
    7.17 +	unsigned int get_texture(const char *fname) const;
    7.18 +};
    7.19 +
    7.20 +#endif	// TEXMAN_H_
     8.1 --- a/prototype/src/tile.cc	Sat Aug 18 03:47:13 2012 +0300
     8.2 +++ b/prototype/src/tile.cc	Sun Aug 19 03:11:36 2012 +0300
     8.3 @@ -5,11 +5,16 @@
     8.4  #include <assimp/scene.h>
     8.5  #include <assimp/postprocess.h>
     8.6  #include "tile.h"
     8.7 +#include "tileset.h"
     8.8  
     8.9  using std::map;
    8.10  
    8.11  static void build_nodemap(map<aiMesh*, aiNode*> *nmap, const aiScene *scn, aiNode *node);
    8.12  
    8.13 +Tile::Tile(TileSet *tileset)
    8.14 +{
    8.15 +	tset = tileset;
    8.16 +}
    8.17  
    8.18  bool Tile::load(const char *fname)
    8.19  {
    8.20 @@ -90,6 +95,10 @@
    8.21  			continue;
    8.22  		}
    8.23  
    8.24 +		Material mat;
    8.25 +		mat.load(scn->mMaterials[scn->mMeshes[i]->mMaterialIndex], tset->get_textures());
    8.26 +		mesh->set_material(mat);
    8.27 +
    8.28  		// retrieve the node pointer
    8.29  		const char *name = "<unknown>";
    8.30  
     9.1 --- a/prototype/src/tile.h	Sat Aug 18 03:47:13 2012 +0300
     9.2 +++ b/prototype/src/tile.h	Sun Aug 19 03:11:36 2012 +0300
     9.3 @@ -15,8 +15,12 @@
     9.4  	TILE_ALL	= 0xffff
     9.5  };
     9.6  
     9.7 +class TileSet;
     9.8 +
     9.9  class Tile {
    9.10  private:
    9.11 +	TileSet *tset;
    9.12 +
    9.13  	std::vector<Mesh*> meshes;
    9.14  	std::vector<unsigned int> mesh_side;
    9.15  	std::vector<Light*> lights;
    9.16 @@ -25,6 +29,8 @@
    9.17  	int load_meshes(const aiScene *scn, const std::map<aiMesh*, aiNode*> &nmap);
    9.18  
    9.19  public:
    9.20 +	Tile(TileSet *tileset = 0);
    9.21 +
    9.22  	bool load(const char *fname);
    9.23  
    9.24  	void draw(unsigned int drawmask) const;
    10.1 --- a/prototype/src/tileset.cc	Sat Aug 18 03:47:13 2012 +0300
    10.2 +++ b/prototype/src/tileset.cc	Sun Aug 19 03:11:36 2012 +0300
    10.3 @@ -42,7 +42,7 @@
    10.4  		*tilefile++ = 0;
    10.5  
    10.6  		printf("Tileset %s, loading tile \"%s\" -> %s\n", fname, line, tilefile);
    10.7 -		Tile *tile = new Tile;
    10.8 +		Tile *tile = new Tile(this);
    10.9  		if(!tile->load(datafile_path(tilefile))) {
   10.10  			fprintf(stderr, "failed to load tile: %s\n", tilefile);
   10.11  			delete tile;
   10.12 @@ -56,6 +56,16 @@
   10.13  	return true;
   10.14  }
   10.15  
   10.16 +TextureSet *TileSet::get_textures()
   10.17 +{
   10.18 +	return &texset;
   10.19 +}
   10.20 +
   10.21 +const TextureSet *TileSet::get_textures() const
   10.22 +{
   10.23 +	return &texset;
   10.24 +}
   10.25 +
   10.26  Tile *TileSet::get_tile(const char *name) const
   10.27  {
   10.28  	auto res = tiles.find(name);
    11.1 --- a/prototype/src/tileset.h	Sat Aug 18 03:47:13 2012 +0300
    11.2 +++ b/prototype/src/tileset.h	Sun Aug 19 03:11:36 2012 +0300
    11.3 @@ -4,16 +4,22 @@
    11.4  #include <string>
    11.5  #include <map>
    11.6  #include "tile.h"
    11.7 +#include "texman.h"
    11.8  
    11.9  class TileSet {
   11.10  private:
   11.11  	std::map<std::string, Tile*> tiles;
   11.12  
   11.13 +	TextureSet texset;
   11.14 +
   11.15  public:
   11.16  	~TileSet();
   11.17  
   11.18  	bool load(const char *fname);
   11.19  
   11.20 +	TextureSet *get_textures();
   11.21 +	const TextureSet *get_textures() const;
   11.22 +
   11.23  	Tile *get_tile(const char *name) const;
   11.24  };
   11.25