微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

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.

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐