summaryrefslogtreecommitdiffstats
path: root/dev/angry-vectors/angry_vectors.h
blob: 37ad5788ac56decad5dedff7a24e6a10cacbc526 (plain) (blame)
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
/** CSci-4611 In-Class Example */

#ifndef ANGRY_VECTORS_H_
#define ANGRY_VECTORS_H_

#include <mingfx.h>
using namespace mingfx;

#include <string>
#include <vector>

class AngryVectors : public GraphicsApp {
public:
  
    // Creates the App
    AngryVectors();
    
    // Cleans up when the App shuts down
    virtual ~AngryVectors();
    
    // Note a Run() function is inherited from GraphicsApp, that's what
    // actually starts up the App.
    
    // This is a callback, a function that gets called when the user presses
    // the Pause button in the GUI.
    void OnPauseBtnPressed();
    
    // This calculates the bird position given a time value.
    Point3 CalcBirdPos(double time);

    // This calculates the bird velocity given a time value, this is the routine
    // we want to check to make sure it is working properly
    Vector3 CalcBirdVel(double time);
    
    // This gets called once each frame.  Note that dt (a.k.a., "delta time") is
    // the amount of time (in seconds) that has passed since the last frame.
    void UpdateSimulation(double dt);
    
    // This is where we initialize the on-screen GUI, which is implemented using
    // an open source library called NanoGUI.  It gets called once
    // when the program starts up.
    void InitNanoGUI();
    
    // This is where we initialize any OpenGL data, like textures or meshes that
    // need to be loaded from files and setup in OpenGL.  It gets called once
    // when the program starts up.
    void InitOpenGL();
    
    // This gets called once each frame, and this is where you draw the latest
    // version of your 3D graphics scene.
    void DrawUsingOpenGL();
    
    
private:    
    
    // Time of flight for our "bird"
    float time_;
    
    // Sets up the computer graphics camera
    Matrix4 view_matrix_;
    Matrix4 proj_matrix_;
    
    // A helper class for drawing some simple shapes (cubes, spheres, 3D arrows)
    QuickShapes quick_shapes_;
    
    // Gui elements
    nanogui::Button  *pauseBtn_;
    bool playing_;
};

#endif