Для начала я рисую серую платформу с проекцией перспективы и задаю её с помощью gluPerspective:
float fov = 69;
float aspectRatio = 960.0f / 480.0f;
float zNear = 0.1;
float zFar = 1000.0;
glMatrixMode(GL_PROJECTION);
glLoadIdentity();
gluPerspective(fov, aspectRatio, zNear, zFar);
glMatrixMode(GL_MODELVIEW);
glLoadIdentity();
gluLookAt(
0.0f, 0.0f, 5.0f,
0.0f, 0.0f, 0.0f,
0.0f, 1.0f, 0.0f
);
Потом я устанавлию ортографическую проекцию на весь экран. Отрисовка идёт от левого верхнего угла окна. Моя задача нарисовать красный квадрат в точке где начинается отрисовка первой вершины серой платформы:
glMatrixMode(GL_PROJECTION);
glLoadIdentity();
glOrtho(0, 960, 480, 0, 1, -1);
glMatrixMode(GL_MODELVIEW);
glLoadIdentity();
drawRedRect(Project(glm::vec3(-1.0f, -1.0f, -1.0f), fov, aspectRatio, zNear, zFar));
Код Project:
float fov = tan(glm::radians(fovy / 2.0F));
glm::mat4x4 identity = glm::mat4x4(
1.0f, 0, 0, 0,
0, 1, 0, 0,
0, 0, 1, 0,
0, 0, 0, 1
);
glm::mat4x4 projectionMatrix = glm::mat4x4(
fov / aspectRatio, 0.0f, 0.0f, 0.0f,
0.0f, fov, 0.0f, 0.0f,
0.0f, 0.0f, (zFar + zNear) / (zNear - zFar), (2.0f * zFar * zNear) / (zNear - zFar),
0.0f, 0.0f, -1.0f, 0.0f
);
glm::mat4x4 lookAt = glm::lookAt(
glm::vec3(0.0f, 0.0f, 5.0f),
glm::vec3(0.0f, 0.0f, 0.0f),
glm::vec3(0.0f, 1.0f, 0.0f)
);
glm::vec4 platformVector4 = glm::vec4(platformVector.x, platformVector.y, platformVector.z, 1.0f);
platformVector4 = projectionMatrix * lookAt * platformVector4;
//platformVector4 /= platformVector4.w;
float halfWidth = 960.0f / 2.0f;
float halfHeight = 480.0f / 2.0f;
glm::vec2 screenProjectedVector = glm::vec2(
halfWidth + (platformVector4.x * 960.0f) * 0.5f,
halfHeight - (platformVector4.y * 480.0f) * 0.5f
);
return screenProjectedVector;
Согласно формуле, которую использует gluPerspective я высчитал fov и матрицу перспективной проекции:
Результат:
Может быть есть догадки что я делаю не так?