ccdemos/realtime_dragon.cc
author Radek Brich <radek.brich@devl.cz>
Tue, 29 Apr 2008 23:31:08 +0200
branchpyrit
changeset 90 f6a72eb99631
parent 80 907929fa9b59
child 91 9d66d323c354
permissions -rw-r--r--
rename Python module from 'raytracer' to 'pyrit' improve Python binding: - new objects: Container, Octree, KdTree, Shape, Pixmap, Sampler, DefaultSampler - all shapes are now subclasses of Shape - clean, remove redundant Getattr's - Raytracer render method now just wraps C++ method without doing any additional work adjust all demos for changes in Python binding, remove PIL dependency add demo_PIL.py as a example of pyrit + PIL usage render_nff.py now either loads file given as a argument or reads input from stdin otherwise fix bug in pixmap float to char conversion

#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);
}