Move hudNode out of root node, remove HUD node type, make main loop fetch window size and propagate it though update and render calls
This commit is contained in:
parent
ce277dfce5
commit
c699330ab5
@ -53,6 +53,10 @@ Gloom::Shader* test_shader;
|
|||||||
Gloom::Shader* plain_shader;
|
Gloom::Shader* plain_shader;
|
||||||
Gloom::Shader* post_shader;
|
Gloom::Shader* post_shader;
|
||||||
|
|
||||||
|
vec3 cameraPosition = vec3(0, 0, 400);
|
||||||
|
vec3 cameraLookAt = vec3(500, 500, 0);
|
||||||
|
vec3 cameraUpward = vec3(0, 0, 1);
|
||||||
|
|
||||||
const vec3 boxDimensions(180, 90, 50);
|
const vec3 boxDimensions(180, 90, 50);
|
||||||
const vec3 padDimensions(30, 3, 40);
|
const vec3 padDimensions(30, 3, 40);
|
||||||
|
|
||||||
@ -122,16 +126,17 @@ void initGame(GLFWwindow* window, CommandLineOptions gameOptions) {
|
|||||||
Mesh sphere = generateSphere(1.0, 40, 40);
|
Mesh sphere = generateSphere(1.0, 40, 40);
|
||||||
|
|
||||||
rootNode = createSceneNode();
|
rootNode = createSceneNode();
|
||||||
|
hudNode = createSceneNode();
|
||||||
|
|
||||||
boxNode = createSceneNode(NORMAL_TEXTURED_GEOMETRY);
|
boxNode = createSceneNode(NORMAL_TEXTURED_GEOMETRY);
|
||||||
padNode = createSceneNode();
|
padNode = createSceneNode();
|
||||||
ballNode = createSceneNode();
|
ballNode = createSceneNode();
|
||||||
hudNode = createSceneNode(HUD);
|
|
||||||
textNode = createSceneNode(TEXTURED_GEOMETRY);
|
textNode = createSceneNode(TEXTURED_GEOMETRY);
|
||||||
|
|
||||||
rootNode->children.push_back(boxNode);
|
rootNode->children.push_back(boxNode);
|
||||||
rootNode->children.push_back(padNode);
|
rootNode->children.push_back(padNode);
|
||||||
rootNode->children.push_back(ballNode);
|
rootNode->children.push_back(ballNode);
|
||||||
rootNode->children.push_back(hudNode);
|
|
||||||
|
|
||||||
hudNode->children.push_back(textNode);
|
hudNode->children.push_back(textNode);
|
||||||
//rootNode->children.push_back(textNode);
|
//rootNode->children.push_back(textNode);
|
||||||
@ -142,7 +147,7 @@ void initGame(GLFWwindow* window, CommandLineOptions gameOptions) {
|
|||||||
padNode->setMesh(&pad);
|
padNode->setMesh(&pad);
|
||||||
ballNode->setMesh(&sphere);
|
ballNode->setMesh(&sphere);
|
||||||
|
|
||||||
// task 1a, add point lights
|
// add lights
|
||||||
for (int i = 0; i<3; i++) {
|
for (int i = 0; i<3; i++) {
|
||||||
lightNode[i] = createSceneNode(POINT_LIGHT);
|
lightNode[i] = createSceneNode(POINT_LIGHT);
|
||||||
lightNode[i]->lightID = i;
|
lightNode[i]->lightID = i;
|
||||||
@ -160,8 +165,7 @@ void initGame(GLFWwindow* window, CommandLineOptions gameOptions) {
|
|||||||
|
|
||||||
// hud
|
// hud
|
||||||
Mesh hello_world = generateTextGeometryBuffer("Skjer'a bagera?", 1.3, 2);
|
Mesh hello_world = generateTextGeometryBuffer("Skjer'a bagera?", 1.3, 2);
|
||||||
textNode->position = vec3(-1.0, 0.0, 0.0);
|
textNode->position = vec3(-1.0, -1.0, 0.0);
|
||||||
textNode->rotation = vec3(0.0, 0.0, 0.0);
|
|
||||||
textNode->setMesh(&hello_world);
|
textNode->setMesh(&hello_world);
|
||||||
textNode->setTexture(&t_charmap);
|
textNode->setTexture(&t_charmap);
|
||||||
textNode->isIlluminated = false;
|
textNode->isIlluminated = false;
|
||||||
@ -173,16 +177,9 @@ void initGame(GLFWwindow* window, CommandLineOptions gameOptions) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
void updateNodeTransformations(SceneNode* node, mat4 transformationThusFar, mat4 V, mat4 P) {
|
void updateNodeTransformations(SceneNode* node, mat4 transformationThusFar, mat4 V, mat4 P) {
|
||||||
|
|
||||||
mat4 transformationMatrix(1.0);
|
mat4 transformationMatrix(1.0);
|
||||||
|
|
||||||
switch(node->nodeType) {
|
switch(node->nodeType) {
|
||||||
case HUD:
|
|
||||||
// We orthographic now, bitches!
|
|
||||||
// set orthographic VP
|
|
||||||
V = mat4(1.0);
|
|
||||||
P = glm::ortho(-float(windowWidth) / float(windowHeight), float(windowWidth) / float(windowHeight), -1.0f, 1.0f);//, -10.0f, 120.0f);
|
|
||||||
break;
|
|
||||||
case NORMAL_TEXTURED_GEOMETRY:
|
case NORMAL_TEXTURED_GEOMETRY:
|
||||||
case TEXTURED_GEOMETRY:
|
case TEXTURED_GEOMETRY:
|
||||||
case GEOMETRY:
|
case GEOMETRY:
|
||||||
@ -218,7 +215,7 @@ void updateNodeTransformations(SceneNode* node, mat4 transformationThusFar, mat4
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
void updateFrame(GLFWwindow* window) {
|
void updateFrame(GLFWwindow* window, int windowWidth, int windowHeight) {
|
||||||
glfwSetInputMode(window, GLFW_CURSOR, GLFW_CURSOR_DISABLED);
|
glfwSetInputMode(window, GLFW_CURSOR, GLFW_CURSOR_DISABLED);
|
||||||
double timeDelta = getTimeDeltaSeconds();
|
double timeDelta = getTimeDeltaSeconds();
|
||||||
|
|
||||||
@ -345,17 +342,24 @@ void updateFrame(GLFWwindow* window) {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
mat4 projection = glm::perspective(glm::radians(90.0f), float(windowWidth) / float(windowHeight), 0.1f,
|
mat4 projection = glm::perspective(
|
||||||
120.f);
|
glm::radians(45.0f), // fovy
|
||||||
|
float(windowWidth) / float(windowHeight), // aspect
|
||||||
|
0.1f, 50000.f // near, far
|
||||||
|
);
|
||||||
|
|
||||||
// hardcoded camera position...
|
// hardcoded camera position...
|
||||||
mat4 cameraTransform
|
mat4 cameraTransform
|
||||||
= glm::translate(mat4(1), vec3(0, 0, 0))
|
= glm::lookAt(cameraPosition, cameraLookAt, cameraUpward);
|
||||||
* glm::rotate(mat4(1.0), 0.2f, vec3(1, 0, 0))
|
|
||||||
* glm::rotate(mat4(1.0), float(M_PI), vec3(0, 1, 0));
|
|
||||||
|
|
||||||
updateNodeTransformations(rootNode, mat4(1.0), cameraTransform, projection);
|
updateNodeTransformations(rootNode, mat4(1.0), cameraTransform, projection);
|
||||||
|
|
||||||
|
// We orthographic now, bitches!
|
||||||
|
// set orthographic VP
|
||||||
|
cameraTransform = mat4(1.0);
|
||||||
|
projection = glm::ortho(-float(windowWidth) / float(windowHeight), float(windowWidth) / float(windowHeight), -1.0f, 1.0f);
|
||||||
|
updateNodeTransformations(hudNode, mat4(1.0), cameraTransform, projection);
|
||||||
|
|
||||||
boxNode->position = {-boxDimensions.x / 2, -boxDimensions.y / 2 - 15, boxDimensions.z - 10};
|
boxNode->position = {-boxDimensions.x / 2, -boxDimensions.y / 2 - 15, boxDimensions.z - 10};
|
||||||
padNode->position = {-boxDimensions.x / 2 + (1 - padPositionX) * (boxDimensions.x - padDimensions.x),
|
padNode->position = {-boxDimensions.x / 2 + (1 - padPositionX) * (boxDimensions.x - padDimensions.x),
|
||||||
-boxDimensions.y / 2 - 15,
|
-boxDimensions.y / 2 - 15,
|
||||||
@ -429,7 +433,6 @@ void renderNode(SceneNode* node, Gloom::Shader* parent_shader = default_shader)
|
|||||||
lights[id].push_to_shader(s, id);
|
lights[id].push_to_shader(s, id);
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
case HUD:
|
|
||||||
default:
|
default:
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
@ -439,10 +442,9 @@ void renderNode(SceneNode* node, Gloom::Shader* parent_shader = default_shader)
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
void renderFrame(GLFWwindow* window) {
|
void renderFrame(GLFWwindow* window, int windowWidth, int windowHeight) {
|
||||||
int windowWidth, windowHeight;
|
|
||||||
glfwGetWindowSize(window, &windowWidth, &windowHeight);
|
|
||||||
glViewport(0, 0, windowWidth, windowHeight);
|
glViewport(0, 0, windowWidth, windowHeight);
|
||||||
|
|
||||||
renderNode(rootNode);
|
renderNode(rootNode);
|
||||||
|
renderNode(hudNode);
|
||||||
}
|
}
|
||||||
|
@ -4,5 +4,5 @@
|
|||||||
#include <utilities/window.hpp>
|
#include <utilities/window.hpp>
|
||||||
|
|
||||||
void initGame(GLFWwindow* window, CommandLineOptions options);
|
void initGame(GLFWwindow* window, CommandLineOptions options);
|
||||||
void updateFrame(GLFWwindow* window);
|
void updateFrame(GLFWwindow* window, int windowWidth, int windowHeight);
|
||||||
void renderFrame(GLFWwindow* window);
|
void renderFrame(GLFWwindow* window, int windowWidth, int windowHeight);
|
||||||
|
10
src/main.cpp
10
src/main.cpp
@ -36,13 +36,13 @@ GLFWwindow* initialise()
|
|||||||
glfwSetErrorCallback(glfwErrorCallback);
|
glfwSetErrorCallback(glfwErrorCallback);
|
||||||
|
|
||||||
// Set additional window options
|
// Set additional window options
|
||||||
glfwWindowHint(GLFW_RESIZABLE, windowResizable);
|
glfwWindowHint(GLFW_RESIZABLE, c_windowResizable);
|
||||||
glfwWindowHint(GLFW_SAMPLES, windowSamples); // MSAA
|
glfwWindowHint(GLFW_SAMPLES, c_windowSamples); // MSAA
|
||||||
|
|
||||||
// Create window using GLFW
|
// Create window using GLFW
|
||||||
GLFWwindow* window = glfwCreateWindow(windowWidth,
|
GLFWwindow* window = glfwCreateWindow(c_windowWidth,
|
||||||
windowHeight,
|
c_windowHeight,
|
||||||
windowTitle.c_str(),
|
c_windowTitle.c_str(),
|
||||||
nullptr,
|
nullptr,
|
||||||
nullptr);
|
nullptr);
|
||||||
|
|
||||||
|
@ -39,13 +39,11 @@ void runProgram(GLFWwindow* window, CommandLineOptions options)
|
|||||||
// Clear colour and depth buffers
|
// Clear colour and depth buffers
|
||||||
glClear(GL_COLOR_BUFFER_BIT | GL_DEPTH_BUFFER_BIT);
|
glClear(GL_COLOR_BUFFER_BIT | GL_DEPTH_BUFFER_BIT);
|
||||||
|
|
||||||
|
int w, h;
|
||||||
|
glfwGetWindowSize(window, &w, &h);
|
||||||
|
|
||||||
updateFrame(window);
|
updateFrame(window, w, h);
|
||||||
renderFrame(window);
|
renderFrame(window, w, h);
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
// Handle other events
|
// Handle other events
|
||||||
|
@ -22,7 +22,7 @@ using std::vector;
|
|||||||
typedef unsigned int uint;
|
typedef unsigned int uint;
|
||||||
|
|
||||||
enum SceneNodeType {
|
enum SceneNodeType {
|
||||||
GEOMETRY, POINT_LIGHT, SPOT_LIGHT, HUD, TEXTURED_GEOMETRY, NORMAL_TEXTURED_GEOMETRY
|
GEOMETRY, POINT_LIGHT, SPOT_LIGHT, TEXTURED_GEOMETRY, NORMAL_TEXTURED_GEOMETRY
|
||||||
};
|
};
|
||||||
|
|
||||||
struct SceneNode {
|
struct SceneNode {
|
||||||
|
@ -7,13 +7,13 @@
|
|||||||
#include <string>
|
#include <string>
|
||||||
|
|
||||||
// Constants
|
// Constants
|
||||||
const int windowWidth = 1366;
|
const int c_windowWidth = 1366;
|
||||||
const int windowHeight = 768;
|
const int c_windowHeight = 768;
|
||||||
const std::string windowTitle = "Glowbox";
|
const std::string c_windowTitle = "Glowbox";
|
||||||
const GLint windowResizable = GL_TRUE;
|
const GLint c_windowResizable = GL_TRUE;
|
||||||
const int windowSamples = 4;
|
const int c_windowSamples = 4;
|
||||||
|
|
||||||
struct CommandLineOptions {
|
struct CommandLineOptions {
|
||||||
bool enableMusic;
|
bool enableMusic;
|
||||||
bool enableAutoplay;
|
bool enableAutoplay;
|
||||||
};
|
};
|
||||||
|
Loading…
Reference in New Issue
Block a user