testgl2: Press 'o' or 'p' to decrease/increase OpenGL swap interval.
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65
diff --git a/test/testgl2.c b/test/testgl2.c
index dd01d0e..f89f5a2 100644
--- a/test/testgl2.c
+++ b/test/testgl2.c
@@ -218,6 +218,7 @@ main(int argc, char *argv[])
Uint32 then, now, frames;
int status;
int dw, dh;
+ int swap_interval = 0;
/* Enable standard application logging */
SDL_LogSetPriority(SDL_LOG_CATEGORY_APPLICATION, SDL_LOG_PRIORITY_INFO);
@@ -289,11 +290,15 @@ main(int argc, char *argv[])
if (state->render_flags & SDL_RENDERER_PRESENTVSYNC) {
/* try late-swap-tearing first. If not supported, try normal vsync. */
- if (SDL_GL_SetSwapInterval(-1) == -1) {
+ if (SDL_GL_SetSwapInterval(-1) == 0) {
+ swap_interval = -1;
+ } else {
SDL_GL_SetSwapInterval(1);
+ swap_interval = 1;
}
} else {
SDL_GL_SetSwapInterval(0); /* disable vsync. */
+ swap_interval = 0;
}
SDL_GetCurrentDisplayMode(0, &mode);
@@ -377,16 +382,35 @@ main(int argc, char *argv[])
then = SDL_GetTicks();
done = 0;
while (!done) {
+ SDL_bool update_swap_interval = SDL_FALSE;
+
/* Check for events */
++frames;
while (SDL_PollEvent(&event)) {
SDLTest_CommonEvent(state, &event, &done);
+ if (event.type == SDL_KEYDOWN) {
+ if (event.key.keysym.sym == SDLK_o) {
+ swap_interval--;
+ update_swap_interval = SDL_TRUE;
+ } else if (event.key.keysym.sym == SDLK_p) {
+ swap_interval++;
+ update_swap_interval = SDL_TRUE;
+ }
+ }
}
+
+ if (update_swap_interval) {
+ SDL_Log("Swap interval to be set to %d\n", swap_interval);
+ }
+
for (i = 0; i < state->num_windows; ++i) {
int w, h;
if (state->windows[i] == NULL)
continue;
SDL_GL_MakeCurrent(state->windows[i], context);
+ if (update_swap_interval) {
+ SDL_GL_SetSwapInterval(swap_interval);
+ }
SDL_GL_GetDrawableSize(state->windows[i], &w, &h);
ctx.glViewport(0, 0, w, h);
Render();