Skip to content

Commit

Permalink
test: Moved testgesture.c over to the common SDLtest framework.
Browse files Browse the repository at this point in the history
  • Loading branch information
icculus committed Mar 16, 2019
1 parent f95ca7b commit 5897ed8
Showing 1 changed file with 45 additions and 41 deletions.
86 changes: 45 additions & 41 deletions test/testgesture.c
Expand Up @@ -22,6 +22,9 @@
#include <emscripten/emscripten.h>
#endif

#include "SDL_test.h"
#include "SDL_test_common.h"

#define WIDTH 640
#define HEIGHT 480
#define BPP 4
Expand All @@ -32,6 +35,7 @@

#define VERBOSE 0

static SDLTest_CommonState *state;
static SDL_Event events[EVENT_BUF_SIZE];
static int eventWrite;

Expand All @@ -40,7 +44,7 @@ static int colors[7] = {0xFF,0xFF00,0xFF0000,0xFFFF00,0x00FFFF,0xFF00FF,0xFFFFFF

SDL_Surface *screen;
SDL_Window *window;
SDL_bool quitting = SDL_FALSE;
int quitting = 0;

typedef struct {
float x,y;
Expand Down Expand Up @@ -113,9 +117,15 @@ void drawKnob(SDL_Surface* screen,Knob k) {
(k.p.y+k.r/2*SDL_sinf(k.ang))*screen->h,k.r/4*screen->w,0);
}

void DrawScreen(SDL_Surface* screen, SDL_Window* window)
void DrawScreen(SDL_Window* window)
{
SDL_Surface* screen = SDL_GetWindowSurface(window);
int i;

if (!screen) {
return;
}

#if 1
SDL_FillRect(screen, NULL, 0);
#else
Expand Down Expand Up @@ -155,33 +165,22 @@ void DrawScreen(SDL_Surface* screen, SDL_Window* window)
SDL_UpdateWindowSurface(window);
}

/* Returns a new SDL_Window if window is NULL or window if not. */
SDL_Window* initWindow(SDL_Window *window, int width,int height)
{
if (!window) {
window = SDL_CreateWindow("Gesture Test",
SDL_WINDOWPOS_CENTERED, SDL_WINDOWPOS_CENTERED,
width, height, SDL_WINDOW_RESIZABLE);
}
return window;
}

void loop()
{
SDL_Event event;
SDL_RWops *stream;
int i;

while(SDL_PollEvent(&event))
{
SDLTest_CommonEvent(state, &event, &quitting);

/* Record _all_ events */
events[eventWrite & (EVENT_BUF_SIZE-1)] = event;
eventWrite++;

switch (event.type)
{
case SDL_QUIT:
quitting = SDL_TRUE;
break;
case SDL_KEYDOWN:
switch (event.key.keysym.sym)
{
Expand All @@ -206,22 +205,10 @@ void loop()
stream = SDL_RWFromFile("gestureSave", "r");
SDL_Log("Loaded: %i", SDL_LoadDollarTemplates(-1, stream));
SDL_RWclose(stream);
break;
case SDLK_ESCAPE:
quitting = SDL_TRUE;
break;
}
break;
case SDL_WINDOWEVENT:
if (event.window.event == SDL_WINDOWEVENT_RESIZED) {
if (!(window = initWindow(window, event.window.data1, event.window.data2)) ||
!(screen = SDL_GetWindowSurface(window)))
{
SDL_Quit();
exit(1);
}
}
break;

case SDL_FINGERMOTION:
#if VERBOSE
SDL_Log("Finger: %"SDL_PRIs64",x: %f, y: %f",event.tfinger.fingerId,
Expand Down Expand Up @@ -264,7 +251,12 @@ void loop()
break;
}
}
DrawScreen(screen, window);

for (i = 0; i < state->num_windows; ++i) {
if (state->windows[i]) {
DrawScreen(state->windows[i]);
}
}

#ifdef __EMSCRIPTEN__
if (quitting) {
Expand All @@ -275,24 +267,36 @@ void loop()

int main(int argc, char* argv[])
{
window = NULL;
screen = NULL;
quitting = SDL_FALSE;
int i;

/* Enable standard application logging */
SDL_LogSetPriority(SDL_LOG_CATEGORY_APPLICATION, SDL_LOG_PRIORITY_INFO);
quitting = 0;

/* gesture variables */
knob.r = .1f;
knob.ang = 0;

if (SDL_Init(SDL_INIT_VIDEO) < 0 ) return 1;
/* !!! FIXME: there should be an SDLTest_CommonDefaultArgs() so apps don't need this. */
state = SDLTest_CommonCreateState(argv, SDL_INIT_VIDEO);
if (!state) {
return 1;
}

state->window_title = "Gesture Test";
state->window_w = WIDTH;
state->window_h = HEIGHT;
state->skip_renderer = SDL_TRUE;

if (!(window = initWindow(window, WIDTH, HEIGHT)) ||
!(screen = SDL_GetWindowSurface(window)))
{
SDL_Quit();
for (i = 1; i < argc;) {
const int consumed = SDLTest_CommonArg(state, i);
if (consumed == 0) {
SDL_Log("Usage: %s %s\n", argv[0], SDLTest_CommonUsage(state));
return 1;
}
i += consumed;
}

if (!SDLTest_CommonInit(state)) {
return 1;
}

#ifdef __EMSCRIPTEN__
Expand All @@ -303,7 +307,7 @@ int main(int argc, char* argv[])
}
#endif

SDL_Quit();
SDLTest_CommonQuit(state);
return 0;
}

0 comments on commit 5897ed8

Please sign in to comment.