This repository has been archived by the owner on Apr 17, 2022. It is now read-only.
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathmodelerdraw.h
116 lines (89 loc) · 3.14 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
110
111
112
113
114
115
116
// modelerdraw.h
// Contains object and routines related to rendering things
#ifndef MODELERDRAW_H
#define MODELERDRAW_H
#include <FL/gl.h>
#include <cstdio>
#include <vector>
using namespace std;
struct Triangle {
double p1[3];
double p2[3];
double p3[3];
};
#include "modelerglobals.h"
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 &) {
// !todo: implement operator
return *this;
}
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);
// 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);
void drawPolygon(const vector<Triangle> &list);
void drawTorus(double r, double c);
#endif