ccdemos/realtime_dragon.cc
author Radek Brich <radek.brich@devl.cz>
Wed, 23 Apr 2008 19:35:03 +0200 (2008-04-23)
branchpyrit
changeset 80 907929fa9b59
parent 72 7c3f38dff082
child 91 9d66d323c354
permissions -rw-r--r--
remove forgotten noise.h includes common_ply.h: ignore invalid faces with duplicated points (this solves visual flaws in dragon model) extend loadShape for loading triangles realtime_dragon.cc demo: add kd-tree dump/load functionality, add colored perlin cloud texture
#include "raytracer.h"
#include "kdtree.h"
#include "serialize.h"

#include "common_sdl.h"
#include "common_ply.h"

int main(int argc, char **argv)
{
	Raytracer rt;
	KdTree top;
	Camera cam;

	rt.setMaxDepth(0);
	rt.setTop(&top);
	rt.setCamera(&cam);
	cam.setEye(Vector3(0,0,10));

	Light light1(Vector3(-5.0, 2.0, 8.0), Colour(0.9, 0.3, 0.6));
	light1.castShadows(false);
	rt.addLight(&light1);

	//Light light2(Vector3(-2.0, 10.0, 2.0), Colour(0.4, 0.6, 0.3));
	//light2.castShadows(false);
	//rt.addlight(&light2);

	Material mat(Colour(0.9, 0.9, 0.9));
	mat.setSmooth(true);
	LinearColourMap cmap(Colour(0.5, 0.0, 0.0), Colour(1.0, 1.0, 0.5));
	//LinearColourMap cmap(Colour(1.0, 0.2, 0.0), Colour(0.3, 0.9, 0.2));
	mat.setTexture(new CloudTexture(10, &cmap));

	ifstream fin("realtime_dragon.kdtreedump");
	if (!fin)
	{
		load_ply(rt, "../models/ply/dragon/dragon_vrip.ply",
			&mat, Vector3(-29,29,-29), Vector3(0,-3.6,0));
		top.optimize();
	}
	else
		top.load(fin, &mat);

	for (int i = 1; i < argc; i++)
	{
		if (strcmp(argv[1], "-dump") == 0)
		{
			resetSerializer();
			ofstream fout("realtime_dragon.kdtreedump");
			fout << top << endl;
			fout.close();
		}

		if (strcmp(argv[1], "-buildonly") == 0)
			return 0;
	}

	loop_sdl(rt, cam);
}