【发布时间】:2014-11-27 05:59:49
【问题描述】:
我正在开发一个在 Android 设备上使用 openGL ES 2.0 的应用程序。该应用程序包含一些使用编程布局控件显示的按钮。此按钮板叠加在 OpenGL 表面视图上。当我在平板电脑上运行应用程序时,会出现按钮,但 Surface View 是灰色的,这是我创建的 3d 模型的背景颜色。这让我相信我的着色器有问题。我在片段着色器中使用了许多统一的 vec2。我在看这个网站:
http://www.shaderific.com/glsl-variables/
它说有一个内置函数,您可以使用它来判断您的 GL 实现使用了多少统一向量。如何在 android 中运行此代码?
gl_MaxFragmentUniformVectors
我打印出 GLES20.GL_MAX_FRAGMENT_UNIFORM_VECTORS 的内容,得到数字 36349。我的着色器使用了大约 20。
如果这不会导致任何结果,这就是基本错误。该应用程序适用于 Android 4.1.2 的 Motorola Bionic,但不适用于 Android 4.4.2 的三星 Galaxy Tab/Pro!当然,我希望它同时适用于两者。
W/ApplicationPackageManager﹕ getCSCPackageItemText()
E/MoreInfoHPW_ViewGroup﹕ Parent view is not a TextView
以下是三星设备的日志。
10-10 14:27:03.723 30456-30462/org.android.airplane D/dalvikvm﹕ Debugger has detached; object registry had 1 entries
10-10 14:38:55.833 1269-1269/org.android.airplane I/SELinux﹕ Function: selinux_android_load_priority [0], There is no sepolicy file.
10-10 14:38:55.833 1269-1269/org.android.airplane I/SELinux﹕ Function: selinux_android_load_priority , loading version is VE=SEPF_SM-T320_4.4.2_0018
10-10 14:38:55.833 1269-1269/org.android.airplane I/SELinux﹕ selinux_android_seapp_context_reload: seapp_contexts file is loaded from /seapp_contexts
10-10 14:38:55.843 1269-1269/org.android.airplane D/dalvikvm﹕ Late-enabling CheckJNI
10-10 14:38:55.943 1269-1269/org.android.airplane W/ApplicationPackageManager﹕ getCSCPackageItemText()
10-10 14:38:55.983 1269-1269/org.android.airplane E/MoreInfoHPW_ViewGroup﹕ Parent view is not a TextView
10-10 14:38:56.083 1269-1269/org.android.airplane I/Adreno-EGL﹕ <qeglDrvAPI_eglInitialize:410>: EGL 1.4 QUALCOMM build: ()
OpenGL ES Shader Compiler Version: E031.24.00.07
Build Date: 01/22/14 Wed
Local Branch: base_au149_adreno_au169_patches
Remote Branch:
Local Patches:
Reconstruct Branch:
10-10 14:38:56.113 1269-1269/org.android.airplane D/OpenGLRenderer﹕ Enabling debug mode 0
10-10 14:38:58.823 1269-1269/org.android.airplane W/ApplicationPackageManager﹕ getCSCPackageItemText()
【问题讨论】:
-
我不得不提一下,应该在按钮下可见的 GLSurfaceViewRenderer 在消失为灰色之前会显示一秒钟。我之前没有注意到。看来,这短暂的时刻已经完成了。换句话说,GL 组件可能确实在工作,但我无法确定。
-
我在这里发布了一个新问题:stackoverflow.com/questions/26455589/… 请看一下。
标签: android opengl-es samsung-mobile