-
Notifications
You must be signed in to change notification settings - Fork 1
/
modelerdraw.h
109 lines (79 loc) · 3.12 KB
/
modelerdraw.h
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
101
102
103
104
105
106
107
108
109
// modelerdraw.h
// Contains object and routines related to rendering things
#ifndef MODELERDRAW_H
#define MODELERDRAW_H
#include <FL/gl.h>
#include <Eigen/Dense>
#include <cstdio>
#include "modelerglobals.h"
#include <vector>
using namespace Eigen;
enum DrawModeSetting_t
{ NONE=0, NORMAL, WIREFRAME, FLATSHADE, };
enum QualitySetting_t
{ HIGH, MEDIUM, LOW, POOR, };
// Ignore this; the ModelerDrawState just keeps
// information about the current color, etc, etc.
class ModelerDrawState
{
public:
static ModelerDrawState* Instance();
FILE* m_rayFile;
DrawModeSetting_t m_drawMode;
QualitySetting_t m_quality;
GLfloat m_ambientColor[4];
GLfloat m_diffuseColor[4];
GLfloat m_specularColor[4];
GLfloat m_shininess;
private:
ModelerDrawState();
ModelerDrawState(const ModelerDrawState &) {}
ModelerDrawState& operator=(const ModelerDrawState&) {}
static ModelerDrawState *m_instance;
};
// ****************************************************************************
// DRAWING FUNCTIONS
//
// The following functions are for your use in Modeler. You don't *need* to
// use these functions; however, if you desire to output your model for
// the raytracer project (in .ray file format), you must either call these
// functions or implement the appropriate functionality so that the raytracer
// can handle it.
//
// Note: Depending on whether a ray file is open or closed, these functions
// will either output to a ray file or make OpenGL calls.
// ****************************************************************************
// Set the current material properties
void setAmbientColor(float r, float g, float b);
void setDiffuseColor(float r, float g, float b);
void setSpecularColor(float r, float g, float b);
void setShininess(float s);
// Set the current draw mode (see DrawModeSetting_t for valid values
void setDrawMode(DrawModeSetting_t drawMode);
// Set the current quality mode (See QualityModeSetting_t for valid values
void setQuality(QualitySetting_t quality);
// Opens a .ray file for writing, returns false on error
bool openRayFile(const char rayFileName[]);
// Closes the current .ray file if one exists
void closeRayFile();
/////////////////////////////
// Raytraceable Primitives //
/////////////////////////////
// Draw a sphere of radius r
void drawSphere(double r);
// Draw an axis-aligned box from origin to (x,y,z)
void drawBox( double x, double y, double z );
// Draw an axis-aligned texture box from origin to (x,y,z)
void drawTextureBox( double x, double y, double z );
// Draw a cylinder from z=0 to z=h with radius r1 at origin and r2 at z=h
void drawCylinder( double h, double r1, double r2 );
void drawTextureCylinder( double h, double r1, double r2 );
void drawLathe(const std::vector<std::pair<double, double>>& xyPositions);
void drawTriangularColumn(double h, double l1, double l2, double l3);
// Driangle with three given vertices. Specify in counterclockwise direction
void drawTriangle( double x1, double y1, double z1,
double x2, double y2, double z2,
double x3, double y3, double z3 );
inline void drawTriangle(Vector3d p1, Vector3d p2, Vector3d p3);
void initTextures();
#endif