c – 使用顶点着色器的定点算术

如果我使用定点(或描述最小游戏单元的1的整数)来描述我的顶点向量,我如何设置OpenGL /本征变换来使用它?如果我在顶点着色器中执行此操作:

gl_Position = projectionMatrix * viewMatrix * modelMatrix * vec4(in_Position,1.0)

如果我将in_Position作为GL_INT的vec3传入,而我将矩阵作为GL_FLOAT传递给mat4,是否会进行正确的转换?是否有性能成本?

是否有可能将我的转换矩阵准备好定点?

这是通过2D游戏完成的,我认为这比使用3D更可行.我真的更喜欢准确性,因为当事物离原点很远时,大地图上的位置似乎会降低.我意识到我可能只能将对象位置变为整数,而顶点仍被描述为浮点数.但是,我认为我的碰撞方案可以更好地使用定点顶点.一般性能差异是什么?

解决方法

这将意味着一个int to float转换将惩罚你的表现.您应该在cpu到GPU复制时将in_Position转换为vec3.如果使用Matrix对象将它们存储在cpu上,则可以使用以下方法强制转换它们:

MatrixXf data_as_float = data_as_int.cast<float>();

然后使用data_as_float调用glBufferData.

相关文章

本程序的编译和运行环境如下(如果有运行方面的问题欢迎在评...
水了一学期的院选修,万万没想到期末考试还有比较硬核的编程...
补充一下,先前文章末尾给出的下载链接的完整代码含有部分C&...
思路如标题所说采用模N取余法,难点是这个除法过程如何实现。...
本篇博客有更新!!!更新后效果图如下: 文章末尾的完整代码...
刚开始学习模块化程序设计时,估计大家都被形参和实参搞迷糊...