diff --git a/glm/core/dummy.cpp b/glm/core/dummy.cpp index e369d625..29731c57 100644 --- a/glm/core/dummy.cpp +++ b/glm/core/dummy.cpp @@ -31,7 +31,7 @@ #define GLM_MESSAGES #include "../glm.hpp" - +/* #if(GLM_ARCH & GLM_ARCH_SSE2) struct float4 { @@ -54,16 +54,17 @@ int test_simd() } #endif//GLM_ARCH - +*/ int main() { glm::mat4 A(1.0f); glm::vec4 B(1.0f); glm::vec4 C = A * B; +/* # if(GLM_ARCH & GLM_ARCH_SSE2) test_simd(); # endif - +*/ return 0; } diff --git a/glm/gtc/matrix_transform.inl b/glm/gtc/matrix_transform.inl index 8a2f9c40..df9b7ae9 100644 --- a/glm/gtc/matrix_transform.inl +++ b/glm/gtc/matrix_transform.inl @@ -243,15 +243,11 @@ namespace glm #else valType const rad = glm::radians(fovy); #endif - valType range = tan(rad / valType(2)) * zNear; - valType left = -range * aspect; - valType right = range * aspect; - valType bottom = -range; - valType top = range; + valType tanHalfFovy = tan(rad / valType(2)); detail::tmat4x4 Result(valType(0)); - Result[0][0] = (valType(2) * zNear) / (right - left); - Result[1][1] = (valType(2) * zNear) / (top - bottom); + Result[0][0] = valType(1) / (aspect * tanHalfFovy); + Result[1][1] = valType(1) / (tanHalfFovy); Result[2][2] = - (zFar + zNear) / (zFar - zNear); Result[2][3] = - valType(1); Result[3][2] = - (valType(2) * zFar * zNear) / (zFar - zNear); diff --git a/readme.txt b/readme.txt index d0f7a698..8c9f749d 100644 --- a/readme.txt +++ b/readme.txt @@ -50,10 +50,7 @@ GLM 0.9.5.0: 2013-XX-XX - Fixed GTX_multiple for negative value - Removed GTX_ocl_type extension - Fixed post increment and decrement operators - -================================================================================ -GLM 0.9.4.4: 2013-0X-XX --------------------------------------------------------------------------------- +- Fixed perspective with zNear == 0 (#71) - Fixed slerp when costheta is close to 1 - Fixed mat4x2 value_type constructor diff --git a/test/gtc/gtc_matrix_transform.cpp b/test/gtc/gtc_matrix_transform.cpp index 289e2b0d..4ecad93e 100644 --- a/test/gtc/gtc_matrix_transform.cpp +++ b/test/gtc/gtc_matrix_transform.cpp @@ -14,6 +14,7 @@ int main() { int Error = 0; + glm::mat4 Projection = glm::perspective(45.0f, 4.0f / 3.0f, 0.1f, 100.0f); glm::mat4 Pick = glm::pickMatrix(glm::vec2(1, 2), glm::vec2(3, 4), glm::ivec4(0, 0, 320, 240)); return Error;