summaryrefslogtreecommitdiffstats
path: root/DisplayClass.cpp
blob: 174e4ac7f5c5f8e2b213a728873317f3eff2df33 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
#include "DisplayClass.h"
#include "gl.h"


DisplayClass::Renderer DisplayClass::render;

DisplayClass::DisplayClass(int x, int y, int z) : angle(0) {
  /*cubehole0 = Cubehole(3.0, 6.0, 3.0, 0.0, 0.0, 0.0, 2.5, 2.5,
      vmml::vec4f(1.0, 0.85, 0.06, 0.5),
      vmml::vec4f(1.0, 0.85, 0.06, 0.5),
      vmml::vec4f(1.0, 0.85, 0.06, 0.5),
      vmml::vec4f(1.0, 0.85, 0.06, 0.5));
  cubehole1 = Cubehole(2.5, 6.0, 2.5, 0.0, 0.0, 0.0, 2.0, 2.0,
      vmml::vec4f(0.0, 0.85, 0.06, 0.5),
      vmml::vec4f(0.0, 0.85, 0.06, 0.5),
      vmml::vec4f(0.0, 0.85, 0.06, 0.5),
      vmml::vec4f(0.0, 0.85, 0.06, 0.5));
  cubehole2 = Cubehole(2.0, 6.0, 2.0, 0.0, 0.0, 0.0, 1.5, 1.5,
      vmml::vec4f(1.0, 0.0, 0.06, 0.5),
      vmml::vec4f(1.0, 0.0, 0.06, 0.5),
      vmml::vec4f(1.0, 0.0, 0.06, 0.5),
      vmml::vec4f(1.0, 0.0, 0.06, 0.5));
  cubehole3 = Cubehole(1.5, 6.0, 1.5, 0.0, 0.0, 0.0, 1.0, 1.0,
      vmml::vec4f(1.0, 0.85, 0.06, 0.5),
      vmml::vec4f(1.0, 0.85, 0.06, 0.5),
      vmml::vec4f(1.0, 0.85, 0.06, 0.5),
      vmml::vec4f(1.0, 0.85, 0.06, 0.5));
  cubehole4 = Cubehole(1.0, 6.0, 1.0, 0.0, 0.0, 0.0, 0.5, 0.5,
      vmml::vec4f(0.0, 0.85, 0.06, 0.5),
      vmml::vec4f(0.0, 0.85, 0.06, 0.5),
      vmml::vec4f(0.0, 0.85, 0.06, 0.5),
      vmml::vec4f(0.0, 0.85, 0.06, 0.5));
  cubehole5 = Cubehole(0.5, 6.0, 0.5, 0.0, 0.0, 0.0, 0.0, 0.0,
      vmml::vec4f(1.0, 0.0, 0.06, 0.5),
      vmml::vec4f(1.0, 0.0, 0.06, 0.5),
      vmml::vec4f(1.0, 0.0, 0.06, 0.5),
      vmml::vec4f(1.0, 0.0, 0.06, 0.5));

  std::list<Triangle> triangles = cubehole0.getTriangles();
  std::list<Triangle> t1 = cubehole1.getTriangles();
  triangles.splice(triangles.end(), t1);
  std::list<Triangle> t2 = cubehole2.getTriangles();
  triangles.splice(triangles.end(), t2);
  std::list<Triangle> t3 = cubehole3.getTriangles();
  triangles.splice(triangles.end(), t3);
  std::list<Triangle> t4 = cubehole4.getTriangles();
  triangles.splice(triangles.end(), t4);
  std::list<Triangle> t5 = cubehole5.getTriangles();
  triangles.splice(triangles.end(), t5);*/

//  Temparray temp(20, x, y, z);
//  triangles=temp.getTriangles();
this->x=x;
this->y=y;
this->z=z;
  //tree = new BSPTree(triangles);
}

DisplayClass::~DisplayClass() {
  //delete tree;
}

void DisplayClass::renderScene(unsigned long delta) {
  angle += delta*0.055;
  if(angle >= 360)
    angle -= 360;

  glClear(GL_COLOR_BUFFER_BIT | GL_DEPTH_BUFFER_BIT);
  
  glLoadIdentity(); // Clean up matrix
  glTranslatef(0.0, -2.0, -10.0); // Then set up transformation
  glRotatef(15, 1.0, 0.0, 0.0);
  glRotatef(angle, 0.0, 1.0, 0.0);
//  glRotatef(angle*2, 1.0, 0.0, 0.0);
//  glRotatef(angle*3, 0.0, 0.0, 1.0);
//  glRotatef(-angle*5, 1.0, 1.0, 1.0);
  
  
  static Temparray temp(20, x, y, z);
  triangles=temp.getTriangles();
  temp.calcTemp();
  
  //vmml::mat4f transform, inverseTransform;
  //glGetFloatv(GL_MODELVIEW_MATRIX, transform.array);

  //transform.inverse(inverseTransform);

  //vmml::vec3f viewPoint = inverseTransform*vmml::vec3f::ZERO;

  glBegin(GL_TRIANGLES);
  //tree->visit(render, viewPoint);

  for(std::list<Triangle>::iterator t = triangles.begin(); t != triangles.end(); ++t) {
    render(*t);
  }

  glEnd();
  
  glFlush();
}