File: misc.cpp

package info (click to toggle)
pinball 0.3.20201218-4
  • links: PTS, VCS
  • area: main
  • in suites: bookworm, bullseye
  • size: 8,452 kB
  • sloc: cpp: 15,230; makefile: 840; sh: 381; xml: 24
file content (94 lines) | stat: -rw-r--r-- 2,279 bytes parent folder | download | duplicates (8)
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
/***************************************************************************
 Triangle point distance test.
***************************************************************************/

#include <iostream>

#include "Private.h"
#include "Engine.h"
#include "Camera.h"
#include "Cube.h"
#include "Cone.h"
#include "Keyboard.h"
#include "KeyBehavior.h"
#include "KeyRotBehavior.h"
#include "Shape3D.h"
#include "Polygon.h"
#include "CollisionBounds.h"
#include "EMath.h"
#include "CollisionVisitor.h"
#include "Cube.h"

/** A Triangle */
class TriClass : public Shape3D {
public:
  TriClass();
  ~TriClass() {};
};

TriClass::TriClass() {
  this->add(1, -1, 0, 1.0f, 0.0f, 1.0f, 1.0f, 0.0f, 0.0f);
  this->add(-1, -1, 0, 1.0f, 0.0f, 1.0f, 1.0f, 0.0f, 0.0f);
  this->add(0, 1, 0, 1.0f, 0.0f, 1.0f, 1.0f, 0.0f, 0.0f);
  this->add(1, 1, 0, 1.0f, 0.0f, 1.0f, 1.0f, 0.0f, 0.0f);

  Polygon3D * p = new Polygon3D(this, 3);
  p->add(0);
  p->add(1);
  p->add(2);
  p->add(3);
  this->add(p);

  this->countNormals();
}

/** Main */
int main(int argc, char *argv[]) {
  cerr << "Simple emilia test." << endl;

  // Create the engine.
  Engine* engine = new Engine(argc, argv);
  engine->setLightning(0.5f, 0.1f);

  // Add a camera. Move a bit.
  Camera* camera = new Camera();
  Group* groupCamera = new Group();
  engine->add(groupCamera);
  groupCamera->setCamera(camera);
  groupCamera->setTranslation(0, 0, 2);
  engine->setEngineCamera(groupCamera);

  engine->addShape3D(new Cube(0.1f, 1.0f, 1.0f, 1.0f, 1.0f));

  Group * gt = new Group();
  engine->add(gt);
  gt->setBehavior(new KeyBehavior());
  Group * gr = new Group();
  gt->add(gr);
  gr->setBehavior(new KeyRotBehavior());
  TriClass * tri = new TriClass();
  gr->addShape3D(tri);
		
  Vertex3D vtx = {0.0f, 0.0f, 0.0f};
  Vertex3D vtxDist;
  engine->resetTick();
  while (!Keyboard::isKeyDown(SDLK_ESCAPE)) {
    if (engine->nextTickFPS(10)) {
      engine->tick();
      float sqrdist = CollisionVisitor::getInstance()->
	vtxPolySqrDist(vtx, tri->getPolygon(0), vtxDist);
      cerr << EMath::emSqrt(sqrdist) <<" : "<< 
	vtxDist.x <<" "<< vtxDist.y <<" "<< vtxDist.z << endl; 
    } else {
      engine->render();
      engine->swap();
    }
  }

  delete(engine);
  return 0;
}

#if EM_USE_ALLEGRO
END_OF_MAIN();
#endif