Compare commits
2 commits
89c0b0b920
...
2ee55100e5
Author | SHA1 | Date | |
---|---|---|---|
|
2ee55100e5 | ||
|
9e1a61af1d |
1 changed files with 82 additions and 40 deletions
80
main.c
80
main.c
|
@ -18,7 +18,7 @@
|
||||||
*
|
*
|
||||||
* For instance if you want fps and position set the value to 2*3=6
|
* For instance if you want fps and position set the value to 2*3=6
|
||||||
*/
|
*/
|
||||||
#define DEBUG_MODE 5
|
#define DEBUG_MODE 1
|
||||||
|
|
||||||
GLuint screenWidth = 720, screenHeight = 480;
|
GLuint screenWidth = 720, screenHeight = 480;
|
||||||
const GLFWvidmode* mode;
|
const GLFWvidmode* mode;
|
||||||
|
@ -44,6 +44,13 @@ float ez[3] = {0};
|
||||||
float ex[3] = {0};
|
float ex[3] = {0};
|
||||||
float ey[3] = {0};
|
float ey[3] = {0};
|
||||||
|
|
||||||
|
bool upar = false;
|
||||||
|
bool downar = false;
|
||||||
|
bool leftar = false;
|
||||||
|
bool rightar = false;
|
||||||
|
bool forwardar = false;
|
||||||
|
bool backwardar = false;
|
||||||
|
|
||||||
float fovValue=1.0;
|
float fovValue=1.0;
|
||||||
//283=3.14/2 * 180
|
//283=3.14/2 * 180
|
||||||
const int maxYmouse = 283;
|
const int maxYmouse = 283;
|
||||||
|
@ -73,8 +80,7 @@ static void key_callback(GLFWwindow* window, int key, int scancode, int action,
|
||||||
multiplicatorFov=1.;
|
multiplicatorFov=1.;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (!action == GLFW_PRESS)
|
if (action == GLFW_PRESS) {
|
||||||
return;
|
|
||||||
if (key == GLFW_KEY_ESCAPE)
|
if (key == GLFW_KEY_ESCAPE)
|
||||||
{
|
{
|
||||||
//glfwSetWindowShouldClose(window, GLFW_TRUE);
|
//glfwSetWindowShouldClose(window, GLFW_TRUE);
|
||||||
|
@ -93,29 +99,40 @@ static void key_callback(GLFWwindow* window, int key, int scancode, int action,
|
||||||
}
|
}
|
||||||
if (key == GLFW_KEY_BACKSPACE)
|
if (key == GLFW_KEY_BACKSPACE)
|
||||||
glfwSetWindowShouldClose(window, GLFW_TRUE);
|
glfwSetWindowShouldClose(window, GLFW_TRUE);
|
||||||
if (key == GLFW_KEY_SPACE && stateControl != GLFW_PRESS)
|
if (key == GLFW_KEY_SPACE)
|
||||||
camPosY += speed;
|
upar = true;
|
||||||
if (key == GLFW_KEY_SPACE && stateControl == GLFW_PRESS)
|
if (key == GLFW_KEY_LEFT_CONTROL)
|
||||||
camPosY -= speed;
|
downar = true;
|
||||||
if (key == GLFW_KEY_UP || key == GLFW_KEY_W) {
|
if (key == GLFW_KEY_UP || key == GLFW_KEY_W) {
|
||||||
camPosX += speed*ez[0];
|
forwardar = true;
|
||||||
camPosY += speed*ez[1];
|
|
||||||
camPosZ += speed*ez[2];
|
|
||||||
}
|
}
|
||||||
if (key == GLFW_KEY_DOWN || key == GLFW_KEY_S ) {
|
if (key == GLFW_KEY_DOWN || key == GLFW_KEY_S ) {
|
||||||
camPosX -= speed*ez[0];
|
backwardar = true;
|
||||||
camPosY -= speed*ez[1];
|
|
||||||
camPosZ -= speed*ez[2];
|
|
||||||
}
|
}
|
||||||
if (key == GLFW_KEY_RIGHT || key == GLFW_KEY_D) {
|
if (key == GLFW_KEY_RIGHT || key == GLFW_KEY_D) {
|
||||||
camPosX += speed*ex[0];
|
rightar = true;
|
||||||
camPosY += speed*ex[1];
|
|
||||||
camPosZ += speed*ex[2];
|
|
||||||
}
|
}
|
||||||
if (key == GLFW_KEY_LEFT || key == GLFW_KEY_A ) {
|
if (key == GLFW_KEY_LEFT || key == GLFW_KEY_A ) {
|
||||||
camPosX -= speed*ex[0];
|
leftar = true;
|
||||||
camPosY -= speed*ex[1];
|
}
|
||||||
camPosZ -= speed*ex[2];
|
}
|
||||||
|
else if (action == GLFW_RELEASE) {
|
||||||
|
if (key == GLFW_KEY_SPACE)
|
||||||
|
upar = false;
|
||||||
|
if (key == GLFW_KEY_LEFT_CONTROL)
|
||||||
|
downar = false;
|
||||||
|
if (key == GLFW_KEY_UP || key == GLFW_KEY_W) {
|
||||||
|
forwardar = false;
|
||||||
|
}
|
||||||
|
if (key == GLFW_KEY_DOWN || key == GLFW_KEY_S ) {
|
||||||
|
backwardar = false;
|
||||||
|
}
|
||||||
|
if (key == GLFW_KEY_RIGHT || key == GLFW_KEY_D) {
|
||||||
|
rightar = false;
|
||||||
|
}
|
||||||
|
if (key == GLFW_KEY_LEFT || key == GLFW_KEY_A ) {
|
||||||
|
leftar = false;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -256,6 +273,31 @@ int main (){
|
||||||
ey[2] = ex[0] * ez[1] - ex[1] * ez[0];
|
ey[2] = ex[0] * ez[1] - ex[1] * ez[0];
|
||||||
//crossProduct(ex,ez);
|
//crossProduct(ex,ez);
|
||||||
|
|
||||||
|
if (upar)
|
||||||
|
camPosY += speed;
|
||||||
|
if (downar)
|
||||||
|
camPosY -= speed;
|
||||||
|
if (forwardar) {
|
||||||
|
camPosX += speed*ez[0];
|
||||||
|
camPosY += speed*ez[1];
|
||||||
|
camPosZ += speed*ez[2];
|
||||||
|
}
|
||||||
|
if (backwardar) {
|
||||||
|
camPosX -= speed*ez[0];
|
||||||
|
camPosY -= speed*ez[1];
|
||||||
|
camPosZ -= speed*ez[2];
|
||||||
|
}
|
||||||
|
if (rightar) {
|
||||||
|
camPosX += speed*ex[0];
|
||||||
|
camPosY += speed*ex[1];
|
||||||
|
camPosZ += speed*ex[2];
|
||||||
|
}
|
||||||
|
if (leftar) {
|
||||||
|
camPosX -= speed*ex[0];
|
||||||
|
camPosY -= speed*ex[1];
|
||||||
|
camPosZ -= speed*ex[2];
|
||||||
|
}
|
||||||
|
|
||||||
currentTime = glfwGetTime();
|
currentTime = glfwGetTime();
|
||||||
deltaTime = currentTime - lastFrame;
|
deltaTime = currentTime - lastFrame;
|
||||||
lastFrame = currentTime;
|
lastFrame = currentTime;
|
||||||
|
|
Loading…
Reference in a new issue