Text on screen added, few modifications needed

This commit is contained in:
Marcin Kwapisz 2021-02-25 01:30:26 +01:00
parent 36fe4ce569
commit 1d52adb106

View File

@ -2,6 +2,7 @@
#include <cmath> #include <cmath>
#include <ctime> #include <ctime>
#include <vector> #include <vector>
#include <string>
#include <assimp/Importer.hpp> #include <assimp/Importer.hpp>
#include <assimp/scene.h> #include <assimp/scene.h>
#include <assimp/postprocess.h> #include <assimp/postprocess.h>
@ -19,6 +20,12 @@
#include <WinUser.h> #include <WinUser.h>
#define STB_IMAGE_IMPLEMENTATION #define STB_IMAGE_IMPLEMENTATION
#include "stb_image.h" #include "stb_image.h"
//Text handling
int msgId = 0;
int checkTimer = 360;
int frames = 0;
const char* screenMsg[4] = { "Znajdz zaloganta w pasie asteroid", "Znalazles zaloganta!",
"Uszkodzenie oslon termicznych", "Zderzenie z duzym obiektem" };
physx::PxRigidDynamic* getActor(std::string name); physx::PxRigidDynamic* getActor(std::string name);
static PxFilterFlags simulationFilterShader(PxFilterObjectAttributes attributes0, static PxFilterFlags simulationFilterShader(PxFilterObjectAttributes attributes0,
@ -48,7 +55,8 @@ public:
auto actorName2 = ((Object*)ac2->userData)->GetName(); auto actorName2 = ((Object*)ac2->userData)->GetName();
if ((actorName1 == "Space Humster" && actorName2 == "Corvette") || (actorName2 == "Space Humster" && actorName1 == "Corvette")) if ((actorName1 == "Space Humster" && actorName2 == "Corvette") || (actorName2 == "Space Humster" && actorName1 == "Corvette"))
{ {
cout << "Znalazles chomika! :)" << endl; checkTimer = frames + 240;
msgId = 1;
auto humster = getActor("Space Humster"); auto humster = getActor("Space Humster");
((Object*)humster->userData)->exists = false; ((Object*)humster->userData)->exists = false;
humster->setActorFlag(PxActorFlag::eDISABLE_SIMULATION, true); humster->setActorFlag(PxActorFlag::eDISABLE_SIMULATION, true);
@ -75,6 +83,7 @@ int SCR_HEIGHT = 720;
int winId; int winId;
Core::Shader_Loader shaderLoader; Core::Shader_Loader shaderLoader;
//shader programs //shader programs
GLuint programTex; GLuint programTex;
GLuint programSkybox; GLuint programSkybox;
@ -165,6 +174,7 @@ void SortParticles() {
std::sort(&ParticlesContainer[0], &ParticlesContainer[MaxParticles]); std::sort(&ParticlesContainer[0], &ParticlesContainer[MaxParticles]);
} }
int FindUnusedParticle() { int FindUnusedParticle() {
for (int i = LastUsedParticle; i < MaxParticles; i++) { for (int i = LastUsedParticle; i < MaxParticles; i++) {
@ -654,6 +664,16 @@ void updateLights(GLuint program)
} }
} }
void output()
{
glMatrixMode(GL_MODELVIEW);
glPushMatrix();
glLoadIdentity();
glColor3f(0.0, 1.0, 0.0);
glRasterPos2f(-0.1, 0);
glutBitmapString(GLUT_BITMAP_TIMES_ROMAN_24, (unsigned char*)screenMsg[msgId]);
}
void renderScene() void renderScene()
{ {
cameraMatrix = createCameraMatrix(); cameraMatrix = createCameraMatrix();
@ -670,9 +690,14 @@ void renderScene()
} }
} }
glClearColor(0.0f, 0.0f, 0.0f, 1.0f); glClearColor(0.0f, 0.0f, 0.0f, 1.0f);
glClear(GL_COLOR_BUFFER_BIT | GL_DEPTH_BUFFER_BIT); glClear(GL_COLOR_BUFFER_BIT | GL_DEPTH_BUFFER_BIT);
frames++;
if (frames<checkTimer)
{
output();
}
glBindFramebuffer(GL_FRAMEBUFFER, FBO); glBindFramebuffer(GL_FRAMEBUFFER, FBO);
glClear(GL_COLOR_BUFFER_BIT | GL_DEPTH_BUFFER_BIT); glClear(GL_COLOR_BUFFER_BIT | GL_DEPTH_BUFFER_BIT);
@ -804,6 +829,7 @@ void renderScene()
glutSwapBuffers(); glutSwapBuffers();
} }
void initPhysics() void initPhysics()
{ {
material = pxScene.physics->createMaterial(0.5, 0.5, 0.5); material = pxScene.physics->createMaterial(0.5, 0.5, 0.5);
@ -1039,7 +1065,7 @@ void initObjects()
objects.push_back(moon); objects.push_back(moon);
Object crewmateObj = Object("Space Humster", crewmate, programNormal, glm::vec3(1.0f), Object crewmateObj = Object("Space Humster", crewmate, programNormal, glm::vec3(1.0f),
glm::vec3(-5, 0, 0), glm::vec3(1, 0, 1), glm::vec3(0.1), 0, true, false); glm::vec3(-5, 0, 0), glm::vec3(1, 0, 1), glm::vec3(1.1), 0, true, false);
objects.push_back(crewmateObj); objects.push_back(crewmateObj);
//glm::mat4 shipModelMatrix = glm::translate(cameraPos + cameraDir * 0.7f + glm::vec3(0, -0.25f, 0)) * glm::rotate(-cameraAngle + glm::radians(90.0f), glm::vec3(0, 1, 0)) * glm::scale(glm::vec3(0.0001f));; //glm::mat4 shipModelMatrix = glm::translate(cameraPos + cameraDir * 0.7f + glm::vec3(0, -0.25f, 0)) * glm::rotate(-cameraAngle + glm::radians(90.0f), glm::vec3(0, 1, 0)) * glm::scale(glm::vec3(0.0001f));;