diff options
author | Mathias Agopian <mathias@google.com> | 2009-08-06 16:05:39 -0700 |
---|---|---|
committer | Mathias Agopian <mathias@google.com> | 2009-08-06 16:05:39 -0700 |
commit | 265d9c076a588cf4cd811fbafd999c7ffe36641b (patch) | |
tree | 8e4b8a390de2d36c8bd0e2a92d1907bdcbb99f04 /opengl/tests/swapinterval | |
parent | 25ec00fd13a6310d80a726cc9493a4b394056063 (diff) | |
download | frameworks_base-265d9c076a588cf4cd811fbafd999c7ffe36641b.zip frameworks_base-265d9c076a588cf4cd811fbafd999c7ffe36641b.tar.gz frameworks_base-265d9c076a588cf4cd811fbafd999c7ffe36641b.tar.bz2 |
added two EGL helpers for selecting a config matching a certain pixelformat or native window type
Diffstat (limited to 'opengl/tests/swapinterval')
-rw-r--r-- | opengl/tests/swapinterval/swapinterval.cpp | 42 |
1 files changed, 11 insertions, 31 deletions
diff --git a/opengl/tests/swapinterval/swapinterval.cpp b/opengl/tests/swapinterval/swapinterval.cpp index f51d882..cf908a0 100644 --- a/opengl/tests/swapinterval/swapinterval.cpp +++ b/opengl/tests/swapinterval/swapinterval.cpp @@ -26,6 +26,7 @@ #include <utils/StopWatch.h> #include <ui/FramebufferNativeWindow.h> +#include <ui/EGLUtils.h> using namespace android; @@ -36,48 +37,27 @@ int main(int argc, char** argv) EGL_NONE }; - EGLint numConfigs = -1, n=0; EGLint majorVersion; EGLint minorVersion; - EGLConfig config; EGLContext context; + EGLConfig config; EGLSurface surface; EGLint w, h; - EGLDisplay dpy; dpy = eglGetDisplay(EGL_DEFAULT_DISPLAY); eglInitialize(dpy, &majorVersion, &minorVersion); + + EGLNativeWindowType window = android_createDisplaySurface(); - // Get all the "potential match" configs... - eglGetConfigs(dpy, NULL, 0, &numConfigs); - EGLConfig* const configs = (EGLConfig*)malloc(sizeof(EGLConfig)*numConfigs); - eglChooseConfig(dpy, configAttribs, configs, numConfigs, &n); - config = configs[0]; - if (n > 1) { - // if there is more than one candidate, go through the list - // and pick one that matches our framebuffer format - int fbSzA = 0; // should not hardcode - int fbSzR = 5; // should not hardcode - int fbSzG = 6; // should not hardcode - int fbSzB = 5; // should not hardcode - int i; - for (i=0 ; i<n ; i++) { - EGLint r,g,b,a; - eglGetConfigAttrib(dpy, configs[i], EGL_RED_SIZE, &r); - eglGetConfigAttrib(dpy, configs[i], EGL_GREEN_SIZE, &g); - eglGetConfigAttrib(dpy, configs[i], EGL_BLUE_SIZE, &b); - eglGetConfigAttrib(dpy, configs[i], EGL_ALPHA_SIZE, &a); - if (fbSzA == a && fbSzR == r && fbSzG == g && fbSzB == b) { - config = configs[i]; - break; - } - } + status_t err = EGLUtils::selectConfigForNativeWindow( + dpy, configAttribs, window, &config); + if (err) { + fprintf(stderr, "couldn't find an EGLConfig matching the screen format\n"); + return 0; } - free(configs); - - surface = eglCreateWindowSurface(dpy, config, - android_createDisplaySurface(), NULL); + + surface = eglCreateWindowSurface(dpy, config, window, NULL); context = eglCreateContext(dpy, config, NULL, NULL); eglMakeCurrent(dpy, surface, surface, context); eglQuerySurface(dpy, surface, EGL_WIDTH, &w); |