Subversion Repositories gelsvn

Rev

Rev 399 | Rev 406 | Go to most recent revision | Details | Compare with Previous | Last modification | View Log | RSS feed

Rev Author Line No. Line
399 jab 1
/*
2
 *  VisObj.cpp
3
 *  GEL
4
 *
5
 *  Created by J. Andreas Bærentzen on 20/09/08.
6
 *  Copyright 2008 __MyCompanyName__. All rights reserved.
7
 *
8
 */
9
 
10
#include "VisObj.h"
11
 
12
#include <HMesh/load.h>
13
 
14
using namespace std;
15
using namespace CGLA;
16
using namespace HMesh;
17
 
18
 
19
int WINX=800, WINY=800;
20
 
21
 
22
bool VisObj::reload(string _file)
23
{
24
	if(_file != "") file = _file;
25
	mani.clear();
26
	if(!load(file, mani))
27
		return false;
28
	Vec3f c(0,0,0);
29
	float r = 5;
30
	mani.get_bsphere(c,r);
31
	view_ctrl.set_centre(c);
32
	view_ctrl.set_eye_dist(2*r);
33
	return true;
34
}
35
 
36
 
37
void VisObj::display(const std::string& display_method , bool smooth)
38
{
39
	if(create_display_list)
40
	{
41
		create_display_list = false;
42
		delete renderer;
43
 
401 jab 44
		string short_name = display_method.substr(0,3);
45
		if(short_name== "wir")
399 jab 46
			renderer = new WireframeRenderer(mani, smooth);
401 jab 47
		else if(short_name == "har")
399 jab 48
			renderer = new HarmonicsRenderer(harmonics);
401 jab 49
		else if(short_name == "iso")
399 jab 50
			renderer = new IsophoteLineRenderer(mani);
401 jab 51
		else if(short_name == "ref")
399 jab 52
			renderer = new ReflectionLineRenderer(mani);
401 jab 53
		else if(short_name == "gla")
54
			renderer = new GlazedRenderer(mani);
55
		else if(short_name == "met")
56
			renderer = new MetallicRenderer(mani);
57
		else
399 jab 58
			renderer = new NormalRenderer(mani,smooth);
59
 
60
	}
61
	view_ctrl.set_gl_modelview();
62
	renderer->draw();
63
}