zoukankan      html  css  js  c++  java
  • 流动贴图需要注意的问题

    比如把一张水纹图片贴在一个quad上,然后让quad各顶点的s纹理坐标随时间递增,这样实现流动效果,即各顶点的s坐标按下式计算:

    s=s0+time*speed

    其中s0是最初的s坐标值。

    但有一个问题,就是shader中纹理坐标v_texCoord精度是非常有限的,通常为mediump float,那么随着time的增加,s的值会变得很大,很快会使v_texCoord溢出,届时渲染效果会变得不正常,通常是流动效果卡顿并伴随马赛克,因此我们希望通过加减1的整数倍使纹理坐标wrap到较小的数值范围,然后再传入shader。

    但这里有一点要特别注意,在做wrap时,我们要将quad所有顶点一起处理,而不能各顶点单独处理,例如我们要将某顶点的s坐标减1,则一定要同步地为其它各顶点也减1。例如经过一点时间后quad纹理坐标变为如下:

    所有顶点的s都减1,变成:

    二者显示结果是相同的。

    但是如果对各顶点单独wrap,就可能出现下面结果:

    显然是不对的。

  • 相关阅读:
    Flsak中的socket是基于werkzeug实现的。
    Flask中的CBV
    beego——静态文件
    beego——模板函数
    beego——模板处理
    beego——模板语法
    beego——模型定义
    beego——事务处理和命令模式
    beego——构造查询
    beego——原生SQL查询
  • 原文地址:https://www.cnblogs.com/wantnon/p/4403976.html
Copyright © 2011-2022 走看看