changeset 1858:d3ac464fb3c1

Add program to test mouse cursor change
author Patrice Mandin <patmandin@gmail.com>
date Wed, 14 Jun 2006 18:59:30 +0000
parents 417f2af2bd52
children 2fce7697adca
files test/Makefile.in test/testcursor.c
diffstat 2 files changed, 125 insertions(+), 1 deletions(-) [+]
line wrap: on
line diff
--- a/test/Makefile.in	Wed Jun 14 18:57:58 2006 +0000
+++ b/test/Makefile.in	Wed Jun 14 18:59:30 2006 +0000
@@ -7,7 +7,7 @@
 CFLAGS  = @CFLAGS@
 LIBS	= @LIBS@
 
-TARGETS = checkkeys$(EXE) graywin$(EXE) loopwave$(EXE) testalpha$(EXE) testbitmap$(EXE) testblitspeed$(EXE) testcdrom$(EXE) testdyngl$(EXE) testerror$(EXE) testfile$(EXE) testgamma$(EXE) testgl$(EXE) testhread$(EXE) testiconv$(EXE) testjoystick$(EXE) testkeys$(EXE) testlock$(EXE) testoverlay2$(EXE) testoverlay$(EXE) testpalette$(EXE) testplatform$(EXE) testsem$(EXE) testsprite$(EXE) testtimer$(EXE) testver$(EXE) testvidinfo$(EXE) testwin$(EXE) testwm$(EXE) threadwin$(EXE) torturethread$(EXE)
+TARGETS = checkkeys$(EXE) graywin$(EXE) loopwave$(EXE) testalpha$(EXE) testbitmap$(EXE) testblitspeed$(EXE) testcdrom$(EXE) testcursor$(EXE) testdyngl$(EXE) testerror$(EXE) testfile$(EXE) testgamma$(EXE) testgl$(EXE) testhread$(EXE) testiconv$(EXE) testjoystick$(EXE) testkeys$(EXE) testlock$(EXE) testoverlay2$(EXE) testoverlay$(EXE) testpalette$(EXE) testplatform$(EXE) testsem$(EXE) testsprite$(EXE) testtimer$(EXE) testver$(EXE) testvidinfo$(EXE) testwin$(EXE) testwm$(EXE) threadwin$(EXE) torturethread$(EXE)
 
 all: $(TARGETS)
 
@@ -32,6 +32,9 @@
 testcdrom$(EXE): $(srcdir)/testcdrom.c
 	$(CC) -o $@ $? $(CFLAGS) $(LIBS)
 
+testcursor$(EXE): $(srcdir)/testcursor.c
+	$(CC) -o $@ $? $(CFLAGS) $(LIBS)
+
 testdyngl$(EXE): $(srcdir)/testdyngl.c
 	$(CC) -o $@ $? $(CFLAGS) $(LIBS)
 
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/test/testcursor.c	Wed Jun 14 18:59:30 2006 +0000
@@ -0,0 +1,121 @@
+#include <stdio.h>
+#include <stdlib.h>
+
+#include "SDL.h"
+
+/* This is an example 16x16 cursor
+	top left :	black
+	top right : inverted color or black
+	bottom left: white
+	bottom right: transparent
+	(swap left and right for different endianness)
+*/
+
+Uint16 cursor_data[16]={
+	0xffff,
+	0xffff,
+	0xffff,
+	0xffff,	
+
+	0xffff,
+	0xffff,
+	0xffff,
+	0xffff,	
+
+	0x0000,
+	0x0000,
+	0x0000,
+	0x0000,
+
+	0x0000,
+	0x0000,
+	0x0000,
+	0x0000
+};
+
+Uint16 cursor_mask[16]={
+	0xff00,
+	0xff00,
+	0xff00,
+	0xff00,
+
+	0xff00,
+	0xff00,
+	0xff00,
+	0xff00,
+
+	0xff00,
+	0xff00,
+	0xff00,
+	0xff00,
+
+	0xff00,
+	0xff00,
+	0xff00,
+	0xff00
+};
+
+int main(int argc, char *argv[])
+{
+	SDL_Surface *screen;
+	SDL_bool quit = SDL_FALSE, first_time = SDL_TRUE;
+	SDL_Cursor *cursor;
+	SDL_Rect update_area;
+
+	/* Load the SDL library */
+	if ( SDL_Init(SDL_INIT_VIDEO) < 0 ) {
+		fprintf(stderr, "Couldn't initialize SDL: %s\n",SDL_GetError());
+		return(1);
+	}
+
+	screen = SDL_SetVideoMode(320,200,8,SDL_ANYFORMAT);
+	if (screen==NULL) {
+		fprintf(stderr, "Couldn't initialize video mode: %s\n",SDL_GetError());
+		return(1);
+	}
+
+	update_area.x = update_area.y = 0;
+	update_area.w = screen->w;
+	update_area.h = screen->h;
+
+	SDL_FillRect(screen, NULL, 0x664422);
+
+	cursor = SDL_CreateCursor((Uint8 *)cursor_data, (Uint8 *)cursor_mask,
+		16, 16, 8, 8);
+	if (cursor==NULL) {
+		fprintf(stderr, "Couldn't initialize cursor: %s\n",SDL_GetError());
+		return(1);
+	}
+
+	SDL_SetCursor(cursor);
+
+	while (!quit) {
+		SDL_Event	event;
+		while (SDL_PollEvent(&event)) {
+			switch(event.type) {
+				case SDL_KEYDOWN:
+					if (event.key.keysym.sym == SDLK_ESCAPE) {
+						quit = SDL_TRUE;
+					}
+					break;
+				case SDL_QUIT:
+					quit = SDL_TRUE;
+					break;
+			}
+		}	
+		if (screen->flags & SDL_DOUBLEBUF) {
+			if (first_time) {
+				SDL_UpdateRects(screen, 1, &update_area);
+				first_time = SDL_FALSE;
+			}
+		} else {
+			SDL_Flip(screen);
+		}	
+		SDL_Delay(1);
+	}
+
+	SDL_FreeCursor(cursor);
+
+	SDL_Quit();
+	return(0);
+}