X-Git-Url: https://git.artsoft.org/?a=blobdiff_plain;f=src%2Fbuttons.h;h=bafbd2a2d8400ff0516e8b173a0cba6d08aa77f5;hb=5ed4de42ced8e7dce5b786ba3d5fd1a6f6a7d7f6;hp=d52b4a628b529c3cf3ba193cdb9a3a8418bee7ee;hpb=cd47bf969c6d8c602b8f5dfa100f0be944bd0e46;p=rocksndiamonds.git diff --git a/src/buttons.h b/src/buttons.h index d52b4a62..bafbd2a2 100644 --- a/src/buttons.h +++ b/src/buttons.h @@ -193,18 +193,21 @@ #define ED_BUTTON_EXIT_XSIZE 90 #define ED_BUTTON_EXIT_YSIZE 20 +#define ED_BUTTON_COUNT_YPOS 60 +#define ED_BUTTON_COUNT_XSIZE 20 +#define ED_BUTTON_COUNT_YSIZE 20 #define ED_BUTTON_MINUS_XPOS 2 -#define ED_BUTTON_MINUS_YPOS 60 -#define ED_BUTTON_MINUS_XSIZE 20 -#define ED_BUTTON_MINUS_YSIZE 20 +#define ED_BUTTON_MINUS_YPOS ED_BUTTON_COUNT_YPOS +#define ED_BUTTON_MINUS_XSIZE ED_BUTTON_COUNT_XSIZE +#define ED_BUTTON_MINUS_YSIZE ED_BUTTON_COUNT_YSIZE #define ED_WIN_COUNT_XPOS (ED_BUTTON_MINUS_XPOS+ED_BUTTON_MINUS_XSIZE+2) -#define ED_WIN_COUNT_YPOS ED_BUTTON_MINUS_YPOS +#define ED_WIN_COUNT_YPOS ED_BUTTON_COUNT_YPOS #define ED_WIN_COUNT_XSIZE 52 -#define ED_WIN_COUNT_YSIZE ED_BUTTON_MINUS_YSIZE +#define ED_WIN_COUNT_YSIZE ED_BUTTON_COUNT_YSIZE #define ED_BUTTON_PLUS_XPOS (ED_WIN_COUNT_XPOS+ED_WIN_COUNT_XSIZE+2) -#define ED_BUTTON_PLUS_YPOS ED_BUTTON_MINUS_YPOS -#define ED_BUTTON_PLUS_XSIZE ED_BUTTON_MINUS_XSIZE -#define ED_BUTTON_PLUS_YSIZE ED_BUTTON_MINUS_YSIZE +#define ED_BUTTON_PLUS_YPOS ED_BUTTON_COUNT_YPOS +#define ED_BUTTON_PLUS_XSIZE ED_BUTTON_COUNT_XSIZE +#define ED_BUTTON_PLUS_YSIZE ED_BUTTON_COUNT_YSIZE #define ED_COUNT_GADGET_XPOS 16 #define ED_COUNT_GADGET_YPOS (16+3*MINI_TILEY+64) @@ -283,6 +286,8 @@ int CheckCountButtons(int, int, int); #define GD_EVENT_PRESSED (1<<0) #define GD_EVENT_RELEASED (1<<1) #define GD_EVENT_MOVING (1<<2) +#define GD_EVENT_REPEATED (1<<3) +#define GD_EVENT_OFF_BORDERS (1<<4) /* gadget button states */ #define GD_BUTTON_UNPRESSED 0 @@ -293,21 +298,25 @@ int CheckCountButtons(int, int, int); /* gadget creation tags */ #define GDI_END 0 -#define GDI_X 1 -#define GDI_Y 2 -#define GDI_WIDTH 3 -#define GDI_HEIGHT 4 -#define GDI_TYPE 5 -#define GDI_STATE 6 -#define GDI_ALT_STATE 7 -#define GDI_NUMBER_VALUE 8 -#define GDI_TEXT_VALUE 9 -#define GDI_DESIGN_UNPRESSED 10 -#define GDI_DESIGN_PRESSED 11 -#define GDI_ALT_DESIGN_UNPRESSED 12 -#define GDI_ALT_DESIGN_PRESSED 13 -#define GDI_EVENT 14 -#define GDI_CALLBACK 15 +#define GDI_CUSTOM_ID 1 +#define GDI_X 2 +#define GDI_Y 3 +#define GDI_WIDTH 4 +#define GDI_HEIGHT 5 +#define GDI_TYPE 6 +#define GDI_STATE 7 +#define GDI_ALT_STATE 8 +#define GDI_NUMBER_VALUE 9 +#define GDI_TEXT_VALUE 10 +#define GDI_DESIGN_UNPRESSED 11 +#define GDI_DESIGN_PRESSED 12 +#define GDI_ALT_DESIGN_UNPRESSED 13 +#define GDI_ALT_DESIGN_PRESSED 14 +#define GDI_EVENT_MASK 15 +#define GDI_EVENT 16 +#define GDI_CALLBACK 17 +#define GDI_AREA_SIZE 18 +#define GDI_ITEM_SIZE 19 typedef void (*gadget_callback_function)(void *); @@ -317,8 +326,24 @@ struct GadgetDesign int x, y; /* position of rectangle in Pixmap */ }; +struct GadgetEvent +{ + unsigned long type; /* event type */ + int button; /* button number for button events */ + int x, y; /* gadget position at event time */ + boolean off_borders; /* mouse pointer outside gadget? */ +}; + +struct GadgetDrawingArea +{ + int area_xsize, area_ysize; /* size of drawing area (in items) */ + int item_xsize, item_ysize; /* size of each item in drawing area */ +}; + struct GadgetInfo { + int id; /* internal gadget identifier */ + int custom_id; /* custom gadget identifier */ int x, y; /* gadget position */ int width, height; /* gadget size */ unsigned long type; /* type (button, text input, ...) */ @@ -329,30 +354,13 @@ struct GadgetInfo char text_value[MAX_GADGET_TEXTSIZE]; struct GadgetDesign design[2]; /* 0: normal; 1: pressed */ struct GadgetDesign alt_design[2]; /* alternative design */ - unsigned long event; /* actual gadget event */ + unsigned long event_mask; /* possible events for this gadget */ + struct GadgetEvent event; /* actual gadget event */ gadget_callback_function callback; + struct GadgetDrawingArea drawing; /* fields for drawing area gadget */ struct GadgetInfo *next; /* next list entry */ }; - -#if 0 -struct NewGadget -{ - int x, y; /* screen position */ - int width, height; /* screen size */ - unsigned long type; /* type (button, text input, ...) */ - struct GadgetDesign *design[2]; /* 0: normal; 1: pressed */ - struct GadgetDesign *alt_design[2]; /* alternative design */ - unsigned long value_mask; /* actual gadget event */ -}; -#endif - -struct GadgetEvent -{ - unsigned long state; /* state (pressed, released, ...) */ - int x,y; /* position inside drawing area */ -}; - struct GadgetInfo *CreateGadget(int, ...); void FreeGadget(struct GadgetInfo *);