added baked textures
This commit is contained in:
parent
a62e309fb6
commit
06d5158356
|
@ -6,6 +6,7 @@
|
||||||
#include "input/keyboard.hpp"
|
#include "input/keyboard.hpp"
|
||||||
#include "../math.hpp"
|
#include "../math.hpp"
|
||||||
|
|
||||||
|
#include <cmath>
|
||||||
#include <iostream>
|
#include <iostream>
|
||||||
#include <glm/matrix.hpp>
|
#include <glm/matrix.hpp>
|
||||||
#include <glm/vec3.hpp>
|
#include <glm/vec3.hpp>
|
||||||
|
@ -34,10 +35,10 @@ void camera::move(double xoff, double yoff, double zoff)
|
||||||
pos.z += zoff;
|
pos.z += zoff;
|
||||||
}
|
}
|
||||||
|
|
||||||
void camera::update()
|
void camera::update(double dt)
|
||||||
{
|
{
|
||||||
glm::vec<2, double> off(0, 0);
|
glm::vec<2, double> off(0, 0);
|
||||||
double m = 0.002;
|
double m = 30;
|
||||||
|
|
||||||
if(keyboard::is_pressed(GLFW_KEY_W))
|
if(keyboard::is_pressed(GLFW_KEY_W))
|
||||||
off.y += 1;
|
off.y += 1;
|
||||||
|
@ -50,7 +51,7 @@ void camera::update()
|
||||||
if(keyboard::is_pressed(GLFW_KEY_LEFT_SHIFT))
|
if(keyboard::is_pressed(GLFW_KEY_LEFT_SHIFT))
|
||||||
m *= 1.5;
|
m *= 1.5;
|
||||||
if(off.x != 0 || off.y != 0)
|
if(off.x != 0 || off.y != 0)
|
||||||
off /= std::sqrt(off.x * off.x + off.y * off.y);
|
off = glm::normalize(off);
|
||||||
|
|
||||||
double angle = glm::radians<double>(yaw);
|
double angle = glm::radians<double>(yaw);
|
||||||
|
|
||||||
|
@ -62,15 +63,15 @@ void camera::update()
|
||||||
glm::vec<2, double> rotated = glm::vec<2, double>(off.x, off.y) * mat;
|
glm::vec<2, double> rotated = glm::vec<2, double>(off.x, off.y) * mat;
|
||||||
bool on_ground = false;
|
bool on_ground = false;
|
||||||
|
|
||||||
velocity.z -= 0.000981;
|
velocity.z -= 9.81 * dt;
|
||||||
|
|
||||||
if(pos.z + velocity.z < 1.6)
|
if(pos.z + velocity.z * dt < 1.6)
|
||||||
{
|
{
|
||||||
on_ground = true;
|
on_ground = true;
|
||||||
|
|
||||||
if(keyboard::is_pressed(GLFW_KEY_SPACE))
|
if(keyboard::is_pressed(GLFW_KEY_SPACE))
|
||||||
{
|
{
|
||||||
velocity.z += 0.04;
|
velocity.z = 3.5;
|
||||||
}
|
}
|
||||||
|
|
||||||
else
|
else
|
||||||
|
@ -85,16 +86,18 @@ void camera::update()
|
||||||
m = 0;
|
m = 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
velocity.x += rotated.x * m;
|
velocity.x += rotated.x * m * dt;
|
||||||
velocity.y += rotated.y * m;
|
velocity.y += rotated.y * m * dt;
|
||||||
|
|
||||||
if(std::abs(pos.x + velocity.x) > 2.9)
|
if(std::abs(pos.x + velocity.x * dt) > 2.9)
|
||||||
velocity.x = 0;
|
velocity.x = 0;
|
||||||
if(std::abs(pos.y + velocity.y) > 3.9)
|
if(std::abs(pos.y + velocity.y * dt) > 3.9)
|
||||||
velocity.y = 0;
|
velocity.y = 0;
|
||||||
|
|
||||||
pos += velocity;
|
float m2 = std::pow(0.5, dt / (on_ground ? 0.05 : 1));
|
||||||
velocity *= glm::vec<3, double>(on_ground ? 0.9 : 0.999);
|
|
||||||
|
pos += velocity * dt;
|
||||||
|
velocity *= m2;
|
||||||
|
|
||||||
camera_mat = glm::mat4(1);
|
camera_mat = glm::mat4(1);
|
||||||
camera_mat = glm::rotate(camera_mat, (float)glm::radians(-pitch), glm::vec3(1, 0, 0));
|
camera_mat = glm::rotate(camera_mat, (float)glm::radians(-pitch), glm::vec3(1, 0, 0));
|
||||||
|
|
|
@ -10,7 +10,7 @@ namespace sim::graphics::camera
|
||||||
glm::mat4 get_matrix();
|
glm::mat4 get_matrix();
|
||||||
void rotate(double pitch, double yaw);
|
void rotate(double pitch, double yaw);
|
||||||
void move(double x, double y, double z);
|
void move(double x, double y, double z);
|
||||||
void update();
|
void update(double dt);
|
||||||
|
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
|
@ -95,12 +95,11 @@ void window::loop()
|
||||||
MeshText.bind();
|
MeshText.bind();
|
||||||
font::generate(MeshText, "Hello, World!\nThis is cool!\n=)", 0.1);
|
font::generate(MeshText, "Hello, World!\nThis is cool!\n=)", 0.1);
|
||||||
|
|
||||||
glClearColor(0, 0, 0, 1.0f);
|
|
||||||
glClear(GL_COLOR_BUFFER_BIT | GL_DEPTH_BUFFER_BIT);
|
|
||||||
|
|
||||||
camera::update();
|
|
||||||
glm::mat4 mat_projection = glm::perspective(glm::radians(90.0f), 1.0f, 0.01f, 20.f);
|
glm::mat4 mat_projection = glm::perspective(glm::radians(90.0f), 1.0f, 0.01f, 20.f);
|
||||||
glUniformMatrix4fv(shader::gl_projection, 1, false, &mat_projection[0][0]);
|
glUniformMatrix4fv(shader::gl_projection, 1, false, &mat_projection[0][0]);
|
||||||
|
|
||||||
|
glClearColor(0, 0, 0, 1.0f);
|
||||||
|
glClear(GL_COLOR_BUFFER_BIT | GL_DEPTH_BUFFER_BIT);
|
||||||
|
|
||||||
MeshScene.bind();
|
MeshScene.bind();
|
||||||
MeshScene.render();
|
MeshScene.render();
|
||||||
|
|
18
src/main.cpp
18
src/main.cpp
|
@ -1,14 +1,32 @@
|
||||||
|
|
||||||
|
#include <sys/time.h>
|
||||||
|
|
||||||
#include "graphics/window.hpp"
|
#include "graphics/window.hpp"
|
||||||
|
#include "graphics/camera.hpp"
|
||||||
|
|
||||||
using namespace sim;
|
using namespace sim;
|
||||||
|
|
||||||
|
unsigned long get_now()
|
||||||
|
{
|
||||||
|
struct timeval tv;
|
||||||
|
gettimeofday(&tv, nullptr);
|
||||||
|
return (unsigned long)tv.tv_sec * 1000000 + tv.tv_usec;
|
||||||
|
}
|
||||||
|
|
||||||
int main()
|
int main()
|
||||||
{
|
{
|
||||||
graphics::window::create();
|
graphics::window::create();
|
||||||
|
|
||||||
|
long clock = get_now();
|
||||||
|
|
||||||
while(!graphics::window::should_close())
|
while(!graphics::window::should_close())
|
||||||
{
|
{
|
||||||
|
long now = get_now();
|
||||||
|
long passed = now - clock;
|
||||||
|
double dt = (double)passed / 1e6;
|
||||||
|
clock += passed;
|
||||||
|
|
||||||
|
graphics::camera::update(dt);
|
||||||
graphics::window::loop();
|
graphics::window::loop();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue