簡體   English   中英

在opengl中限制繞x軸旋轉

[英]Limiting rotation around the x-axis in opengl

為了好玩,我用 opengl 制作了一個 3d 相機。 它運行良好,除了我無法弄清楚如何限制繞 x 軸旋轉的事實。 如果向上滾動太多,向上和向下控件將反轉。 我嘗試將camFront.y變量限制為任意值,但相機仍會在 x 軸上翻轉。

這是我的代碼:

#ifndef CAMERA_H
#define CAMERA_H

#include <GL/glew.h>

#include <GLFW/glfw3.h>

#include <glm/glm.hpp>
#include <glm/gtc/matrix_transform.hpp>
#include <glm/gtc/quaternion.hpp>
#include <glm/gtx/quaternion.hpp>

#define WORLD_UP glm::vec3(0.0f, 1.0f, 0.0f)

#include <iostream>


enum CamDirection {
    CAM_FORWARD,
    CAM_BACKWARD,
    CAM_LEFT,
    CAM_RIGHT
};


class Camera {
public:
    void cameraUpdate();

    glm::mat4 getViewMatrix();

    Camera();

    Camera(glm::vec3 startPosition);

    void move(CamDirection dir, GLfloat deltaTime);

    void look(double xOffset, double yOffset);

    void update();

private:

    glm::vec3 camPos;
    glm::vec3 camFront;
    glm::vec3 camUp;
    glm::vec3 camRight;

    const GLfloat camSpeed = 5.05f;

};

glm::mat4 Camera::getViewMatrix() {
    return glm::lookAt(camPos, camPos + camFront, camUp);
}

Camera::Camera():
    camPos  (glm::vec3(0.0f, 0.0f,  0.0f)),
    camFront(glm::vec3(0.0f, 0.0f, -1.0f)),
    camUp   (WORLD_UP)
{}

Camera::Camera(glm::vec3 startPos):
    camPos   (startPos),
    camFront (glm::vec3(0.0f, 0.0f, -1.0f)),
    camUp    (WORLD_UP)
{}

void Camera::move(CamDirection dir, GLfloat deltaTime) {
    const GLfloat v = camSpeed * deltaTime;
    if (dir == CAM_FORWARD)
        camPos += v * camFront;
    else if (dir == CAM_BACKWARD)
        camPos -= v * camFront;
    else if (dir == CAM_RIGHT)
        camPos += v * camRight;
    else
        camPos -= v * camRight;
}
void Camera::look(double xOffset, double yOffset) {
    glm::quat startQuat = {0, camFront.x, camFront.y, camFront.z};

    glm::quat rotation = glm::angleAxis((GLfloat)xOffset, glm::vec3(0.0f, 1.0f, 0.0f));
    glm::quat view = startQuat * rotation;

    rotation = glm::angleAxis((GLfloat)yOffset, glm::vec3(-1.0f, 0.0f, 0.0f));
    view = view * rotation;

    camFront = glm::vec3(view.x, view.y, view.z);
    std::cerr << camFront.x << ' ' << camFront.y << ' ' << camFront.z << std::endl;

}

void Camera::update() {
        // Also re-calculate the Right and Up vector
        camRight = glm::normalize(glm::cross(camFront, WORLD_UP));  // Normalize the vectors, because their length gets closer to 0 the more you look up or down which results in slower movement.
        camUp    = glm::normalize(glm::cross(camRight, camFront));
}
#endif // CAMERA_H

我怎樣才能解決這個問題?

在將它們分配給camFront之前,您需要限制view.yview.z值,最大為 89 度,最小為 -89 度。 在 90 度和 -90 度時,它開始反轉。 所以一個非常簡單的方法可能是,

if(view.y > 89)
{
  view.y = 89;
}
if(view.y < -89)
{
  view.y = -89;
}
if(view.z > 89)
{
  view.z = 89;
}
if(view.z < -89)
{
  view.z = -89;
}

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM