TimothyQiu's Blog

keep it simple stupid

记一次有意义的调试

分类:技术

最近阳光明媚,天气晴朗,我为了更好地折腾理解 CMake,尝试把以前在 macOS 上写的一个 OpenGL 程序从 Makefile 改成 CMake 构建,顺带看看同样的东西在 Windows 上编译、运行效果如何。然而在 Windows 上用 MSVC 2015 构建后运行,发现场景里的东西没有了,并且没有任何错误输出。

因为似乎坊间传言 Windows 对 OpenGL 的支持很迷,所以我的第一直觉是 GLSL 的兼容问题,不过这个角度似乎很难排查。

所以还是搞个最小的可重现问题的代码吧,于是从经典的「三角形」Hello World 开始很快地试了一下,发现在 Shader 里做矩阵乘法就有问题;进而发现只要不乘投影矩阵就没有大问题,至少场景里的东西还是可以显示出来的。

蛤?这是什么鬼?总不见得 glm::perspective 有移植性问题吧?

经过一番调试,终于找到了问题所在,结论让人哭笑不得:

我在代码里自己封装了摄像机类,初始化时需要设置投影矩阵所需的远近裁剪平面,相当于下面这样。

Camera(float far, float near)
    : far_{far}, near_{near}
{
    /* blah blah */
}

虽然在其它平台没什么问题,但 windows.h 里有这种东西:

#define far
#define near

于是代码就相当于变成了

Camera(float far, float near)
    : far_{}, near_{}
{
    /* blah blah */
}

把远近裁剪平面的两个变量都初始化成了 0,也难怪场景里什么东西都看不见了。


唉,写代码的时候忘记了 far / near 指针这种历史遗留爆点,不过还是要吐槽下 windows.h 如此暴力的解决方法。

以上,真是有意义的一天呀~

这篇文章没有标签

添加新评论 »