X-Git-Url: http://git.mutantstargoat.com/user/nuclear/?p=dosdemo;a=blobdiff_plain;f=src%2Fsdl%2Fmain.c;h=6a5202190d9e0aeefde7f74226ccb405361984cc;hp=358d774bf9ccde3c692ed864e7707c87ab2a121d;hb=7deef4d5a20da09044bf7311c6ee274090cde5e6;hpb=00a81988c5c6c91997f2f9346ac94858622490bd diff --git a/src/sdl/main.c b/src/sdl/main.c index 358d774..6a52021 100644 --- a/src/sdl/main.c +++ b/src/sdl/main.c @@ -1,15 +1,22 @@ #include #include +#include #include #include #include "demo.h" #include "tinyfps.h" #include "timer.h" #include "cfgopt.h" +#include "sball.h" +#include "vmath.h" static void handle_event(SDL_Event *ev); static void toggle_fullscreen(void); +static int handle_sball_event(sball_event *ev); +static void recalc_sball_matrix(float *xform); + + static int quit; static SDL_Surface *fbsurf; @@ -17,6 +24,11 @@ static int fbscale = 2; static int xsz, ysz; static unsigned int sdl_flags = SDL_SWSURFACE; +static int use_sball; +static vec3_t pos = {0, 0, 0}; +static quat_t rot = {0, 0, 0, 1}; + + int main(int argc, char **argv) { int s, i, j; @@ -36,7 +48,7 @@ int main(int argc, char **argv) fprintf(stderr, "failed to allocate virtual framebuffer\n"); return 1; } - vmem_front = vmem_back = fb_pixels; + vmem = fb_pixels; SDL_Init(SDL_INIT_VIDEO | SDL_INIT_TIMER | SDL_INIT_NOPARACHUTE); if(!(fbsurf = SDL_SetVideoMode(xsz, ysz, fb_bpp, sdl_flags))) { @@ -46,6 +58,7 @@ int main(int argc, char **argv) return 1; } SDL_WM_SetCaption("dosdemo/SDL", 0); + SDL_ShowCursor(0); time_msec = 0; if(demo_init(argc, argv) == -1) { @@ -53,6 +66,11 @@ int main(int argc, char **argv) SDL_Quit(); return 1; } + + if(opt.sball && sball_init() == 0) { + use_sball = 1; + } + reset_timer(); while(!quit) { @@ -62,6 +80,15 @@ int main(int argc, char **argv) if(quit) goto break_evloop; } + if(use_sball) { + while(sball_pending()) { + sball_event ev; + sball_getevent(&ev); + handle_sball_event(&ev); + } + recalc_sball_matrix(sball_matrix); + } + time_msec = get_msec(); demo_draw(); drawFps(fb_pixels); @@ -123,11 +150,11 @@ static int bnmask(int sdlbn) { switch(sdlbn) { case SDL_BUTTON_LEFT: - return MOUSE_LEFT; + return MOUSE_BN_LEFT; case SDL_BUTTON_RIGHT: - return MOUSE_RIGHT; + return MOUSE_BN_RIGHT; case SDL_BUTTON_MIDDLE: - return MOUSE_MIDDLE; + return MOUSE_BN_MIDDLE; default: break; } @@ -184,3 +211,51 @@ static void toggle_fullscreen(void) fbsurf = newsurf; sdl_flags = newflags; } + + + +#define TX(ev) ((ev)->motion.motion[0]) +#define TY(ev) ((ev)->motion.motion[1]) +#define TZ(ev) ((ev)->motion.motion[2]) +#define RX(ev) ((ev)->motion.motion[3]) +#define RY(ev) ((ev)->motion.motion[4]) +#define RZ(ev) ((ev)->motion.motion[5]) + +static int handle_sball_event(sball_event *ev) +{ + switch(ev->type) { + case SBALL_EV_MOTION: + if(RX(ev) | RY(ev) | RZ(ev)) { + float rx = (float)RX(ev); + float ry = (float)RY(ev); + float rz = (float)RZ(ev); + float axis_len = sqrt(rx * rx + ry * ry + rz * rz); + if(axis_len > 0.0) { + rot = quat_rotate(rot, axis_len * 0.001, -rx / axis_len, + -ry / axis_len, -rz / axis_len); + } + } + + pos.x += TX(ev) * 0.001; + pos.y += TY(ev) * 0.001; + pos.z += TZ(ev) * 0.001; + break; + + case SBALL_EV_BUTTON: + if(ev->button.pressed) { + pos = v3_cons(0, 0, 0); + rot = quat_cons(1, 0, 0, 0); + } + break; + } + + return 0; +} + +void recalc_sball_matrix(float *xform) +{ + quat_to_mat(xform, rot); + xform[12] = pos.x; + xform[13] = pos.y; + xform[14] = pos.z; +}