【发布时间】:2014-02-20 02:37:01
【问题描述】:
我正在使用 Harism 在https://github.com/harism/android_page_curl创建的页面卷曲动画。我已经在我的安卓电子书阅读器应用程序中实现了他的动画,问题是当我快速滑动页面时,有时会切换奇怪的白色闪电。但是,当我正常卷曲页面时,不会出现这种情况。我认为问题出在OpenGL方面。我不熟悉该技术,但在调试过程中我看到页面卷曲完成后仍有一些绘图过程正在进行CurlRenderer onDrawFrame 方法中的 strong> 类。
@Override
public synchronized void onDrawFrame(final GL10 gl) {
mObserver.onDrawFrame();
gl.glClearColor(Color.red(mBackgroundColor) / 255f,
Color.green(mBackgroundColor) / 255f,
Color.blue(mBackgroundColor) / 255f,
Color.alpha(mBackgroundColor) / 255f);
gl.glClear(GL10.GL_COLOR_BUFFER_BIT);
gl.glLoadIdentity();
if (USE_PERSPECTIVE_PROJECTION) {
gl.glTranslatef(0, 0, -6f);
}
for (int i = 0; i < mCurlMeshes.size(); ++i) {
mCurlMeshes.get(i).onDrawFrame(gl);
}
Calendar now = Calendar.getInstance();
int minute = now.get(Calendar.MINUTE);
int second = now.get(Calendar.SECOND);
int millis = now.get(Calendar.MILLISECOND);
Log.i("time curl renderer (onDrawFrame) : ", minute + ":" + second + "." + millis);
}
下面是日志
02-20 07:27:37.320 30215-30407/org.com.ebook I/time curl renderer (onDrawFrame) :﹕ 27:37.326
02-20 07:27:37.328 30215-30407/org.com.ebook I/time curl renderer (onDrawFrame) :﹕ 27:37.336
02-20 07:27:37.335 30215-30407/org.com.ebook I/time curl renderer (onDrawFrame) :﹕ 27:37.344
02-20 07:27:37.343 30215-30407/org.com.ebook I/time curl renderer (onDrawFrame) :﹕ 27:37.354
02-20 07:27:37.359 30215-30407/org.com.ebook I/time curl renderer (onDrawFrame) :﹕ 27:37.367
02-20 07:27:37.367 30215-30407/org.com.ebook I/time curl renderer (onDrawFrame) :﹕ 27:37.377
02-20 07:27:37.375 30215-30407/org.com.ebook I/time curl renderer (onDrawFrame) :﹕ 27:37.387
02-20 07:27:37.390 30215-30407/org.com.ebook I/time curl renderer (onDrawFrame) :﹕ 27:37.399
02-20 07:27:37.398 30215-30407/org.com.ebook I/time curl renderer (onDrawFrame) :﹕ 27:37.410
02-20 07:27:37.414 30215-30407/org.com.ebook I/time curl renderer (onDrawFrame) :﹕ 27:37.422
02-20 07:27:37.421 30215-30407/org.com.ebook I/time curl renderer (onDrawFrame) :﹕ 27:37.432
02-20 07:27:37.437 30215-30407/org.com.ebook I/time curl renderer (onDrawFrame) :﹕ 27:37.444
02-20 07:27:37.445 30215-30407/org.com.ebook I/time curl renderer (onDrawFrame) :﹕ 27:37.455
02-20 07:27:37.453 30215-30407/org.com.ebook I/time curl renderer (onDrawFrame) :﹕ 27:37.465
02-20 07:27:37.468 30215-30407/org.com.ebook I/time curl renderer (onDrawFrame) :﹕ 27:37.477
02-20 07:27:37.476 30215-30407/org.com.ebook I/time curl renderer (onDrawFrame) :﹕ 27:37.487
02-20 07:27:37.492 30215-30407/org.com.ebook I/time curl renderer (onDrawFrame) :﹕ 27:37.501
02-20 07:27:37.500 30215-30407/org.com.ebook I/time curl renderer (onDrawFrame) :﹕ 27:37.509
02-20 07:27:37.515 30215-30407/org.com.ebook I/time curl renderer (onDrawFrame) :﹕ 27:37.520
02-20 07:27:37.523 30215-30407/org.com.ebook I/time curl renderer (onDrawFrame) :﹕ 27:37.532
02-20 07:27:37.531 30215-30407/org.com.ebook I/time curl renderer (onDrawFrame) :﹕ 27:37.542
02-20 07:27:37.546 30215-30407/org.com.ebook I/time curl renderer (onDrawFrame) :﹕ 27:37.555
02-20 07:27:37.554 30215-30407/org.com.ebook I/time curl renderer (onDrawFrame) :﹕ 27:37.565
02-20 07:27:37.570 30215-30407/org.com.ebook I/time curl renderer (onDrawFrame) :﹕ 27:37.576
02-20 07:27:37.578 30215-30407/org.com.ebook I/time curl renderer (onDrawFrame) :﹕ 27:37.588
02-20 07:27:37.585 30215-30407/org.com.ebook I/time curl renderer (onDrawFrame) :﹕ 27:37.598
02-20 07:27:37.601 30215-30407/org.com.ebook I/time curl renderer (onDrawFrame) :﹕ 27:37.610
02-20 07:27:37.609 30215-30407/org.com.ebook I/time curl renderer (onDrawFrame) :﹕ 27:37.619
02-20 07:27:37.617 30215-30407/org.com.ebook I/time curl renderer (onDrawFrame) :﹕ 27:37.629
当第一行日志出现时书籍的页面完成卷曲让我们说 02-20 07:27:37.320 在这种情况下,但在接下来的几行中,您可以看到 onDrawFrame 方法被连续调用。也许当这个方法还没有完成它的工作并且来自那个故障的闪电开关时,我正在卷曲页面?有帮助吗?这里是视频链接,您可以在那里看到有时会出现闪电http://www.youtube.com/watch?v=HPJ2U18Caok&feature=youtu.be
【问题讨论】:
-
嗨,你也发布视频吗?由此,很难猜出哪里出了问题。另外,您在什么移动设备上进行测试?您是否尝试过多种设备?
-
是的,我尝试了一些设备,但问题没有解决。我也会尝试发布视频...
-
我建议您编译并运行 curl 示例项目,不要进行任何添加或修改,看看是否也会发生这种情况。如果是这样,那就是 curl 中的一个错误。如果没有,我们将从那里拿走。
-
我从日志中看到,一些 onDrawFrame 调用实际上在下一个调用开始后返回(例如比较 2 和 3 日志条目的时间)。我认为这里可能涉及某种多线程/同步问题。
-
@LOG_TAG 是的,它出现在所有设备中。
标签: android opengl-es page-curl