0

我为我的 android 应用程序编写了一些着色器代码。它有一些时间相关的动画,在 webgl 版本上工作得很好,着色器代码如下,但完整版本可以在这里找到

vec3 bip(vec2 uv, vec2 center)
{
vec2 diff = center-uv; //difference between center and start coordinate
float r = length(diff); //vector length
float scale = mod(u_ElapsedTime,2.); //it is equal 1 every 2 seconds and trigerring function
float circle = smoothstep(scale, scale+cirleWidth, r)
   * smoothstep(scale+cirleWidth,scale, r)*4.;

return vec3(circle);
}

函数的返回在 Fragcolor 中用作颜色的基础。

u_ElapsedTime 通过统一发送到着色器:

glUniform1f(uElapsedTime,elapsedTime);

从“onDrawFrame”发送到着色器的时间数据:

public void onDrawFrame(GL10 gl) {
    glClear(GL_COLOR_BUFFER_BIT);
    elapsedTime = (SystemClock.currentThreadTimeMillis()-startTime)/100f;
    //Log.d("KOS","time " + elapsedTime);
    scannerProgram.useProgram(); //initialize shader
    scannerProgram.setUniforms(resolution,elapsedTime,rotate); //send uniforms to shader
    scannerSurface.bindData(scannerProgram); //get attribute location
    scannerSurface.draw(); //draw vertices with given attributes
}

所以一切看起来都很好。然而,经过一段时间后,似乎有一些滞后,并且帧数量从一开始就更少。最后,对于该功能,每个 cicle 可能只有一两帧。同时,opengl 本身似乎没有一些滞后,因为我可以例如旋转图片并且看不到任何滞后。

滞后的原因可能是什么?

更新:绑定数据的代码:

public void bindData(ScannerShaderProgram scannerProgram) {
    //getting location of each attribute for shader program
    vertexArray.setVertexAttribPointer(
            0,
            scannerProgram.getPositionAttributeLocation(),
            POSITION_COMPONENT_COUNT,
            0
    );
4

1 回答 1

0

对我来说听起来像是精度问题。尝试从着色器中获取这一行:

float scale = mod(u_ElapsedTime,2.);

而是在 CPU 上执行。例如

elapsedTime = ((SystemClock.currentThreadTimeMillis()-startTime)%200)/100f;
于 2016-08-20T16:50:02.920 回答