X-Git-Url: https://git.artsoft.org/?a=blobdiff_plain;f=src%2Feditor.c;h=8570bd199ce47bf9083e7f0bb6d6688e415d1009;hb=240269d614d12d0612cc0764589e6798378e2b8c;hp=d7f0f4df364d76313f244891836cd4e6d4bda8c6;hpb=854913a35af50b39cd124772fbc1fe8ca51f127b;p=rocksndiamonds.git diff --git a/src/editor.c b/src/editor.c index d7f0f4df..8570bd19 100644 --- a/src/editor.c +++ b/src/editor.c @@ -91,7 +91,10 @@ #define ED_COUNT_ELEM_SCORE_YPOS (14 * MINI_TILEY) #define ED_COUNT_ELEM_CONTENT_XPOS ED_PROPERTIES_XPOS #define ED_COUNT_ELEM_CONTENT_YPOS (17 * MINI_TILEY) - +#define ED_COUNTER_YSTART (ED_LEVELINFO_YPOS + 3 * TILEY) +#define ED_COUNTER_YDISTANCE (3 * MINI_TILEY) +#define ED_COUNTER_YPOS(n) (ED_COUNTER_YSTART + \ + n * ED_COUNTER_YDISTANCE) /* standard distances */ #define ED_BORDER_SIZE 3 #define ED_GADGET_DISTANCE 2 @@ -165,57 +168,63 @@ #define ED_CTRL_ID_LEVEL_YSIZE_DOWN 31 #define ED_CTRL_ID_LEVEL_YSIZE_TEXT 32 #define ED_CTRL_ID_LEVEL_YSIZE_UP 33 -#define ED_CTRL_ID_LEVEL_COLLECT_DOWN 34 -#define ED_CTRL_ID_LEVEL_COLLECT_TEXT 35 -#define ED_CTRL_ID_LEVEL_COLLECT_UP 36 -#define ED_CTRL_ID_LEVEL_TIMELIMIT_DOWN 37 -#define ED_CTRL_ID_LEVEL_TIMELIMIT_TEXT 38 -#define ED_CTRL_ID_LEVEL_TIMELIMIT_UP 39 -#define ED_CTRL_ID_LEVEL_TIMESCORE_DOWN 40 -#define ED_CTRL_ID_LEVEL_TIMESCORE_TEXT 41 -#define ED_CTRL_ID_LEVEL_TIMESCORE_UP 42 +#define ED_CTRL_ID_LEVEL_RANDOM_DOWN 34 +#define ED_CTRL_ID_LEVEL_RANDOM_TEXT 35 +#define ED_CTRL_ID_LEVEL_RANDOM_UP 36 +#define ED_CTRL_ID_LEVEL_COLLECT_DOWN 37 +#define ED_CTRL_ID_LEVEL_COLLECT_TEXT 38 +#define ED_CTRL_ID_LEVEL_COLLECT_UP 39 +#define ED_CTRL_ID_LEVEL_TIMELIMIT_DOWN 40 +#define ED_CTRL_ID_LEVEL_TIMELIMIT_TEXT 41 +#define ED_CTRL_ID_LEVEL_TIMELIMIT_UP 42 +#define ED_CTRL_ID_LEVEL_TIMESCORE_DOWN 43 +#define ED_CTRL_ID_LEVEL_TIMESCORE_TEXT 44 +#define ED_CTRL_ID_LEVEL_TIMESCORE_UP 45 /* drawing area identifiers */ -#define ED_CTRL_ID_DRAWING_LEVEL 43 -#define ED_CTRL_ID_ELEM_CONTENT_0 44 -#define ED_CTRL_ID_ELEM_CONTENT_1 45 -#define ED_CTRL_ID_ELEM_CONTENT_2 46 -#define ED_CTRL_ID_ELEM_CONTENT_3 47 -#define ED_CTRL_ID_ELEM_CONTENT_4 48 -#define ED_CTRL_ID_ELEM_CONTENT_5 49 -#define ED_CTRL_ID_ELEM_CONTENT_6 50 -#define ED_CTRL_ID_ELEM_CONTENT_7 51 -#define ED_CTRL_ID_AMOEBA_CONTENT 52 +#define ED_CTRL_ID_DRAWING_LEVEL 46 +#define ED_CTRL_ID_ELEM_CONTENT_0 47 +#define ED_CTRL_ID_ELEM_CONTENT_1 48 +#define ED_CTRL_ID_ELEM_CONTENT_2 49 +#define ED_CTRL_ID_ELEM_CONTENT_3 50 +#define ED_CTRL_ID_ELEM_CONTENT_4 51 +#define ED_CTRL_ID_ELEM_CONTENT_5 52 +#define ED_CTRL_ID_ELEM_CONTENT_6 53 +#define ED_CTRL_ID_ELEM_CONTENT_7 54 +#define ED_CTRL_ID_AMOEBA_CONTENT 55 /* text input identifiers */ -#define ED_CTRL_ID_LEVEL_NAME 53 +#define ED_CTRL_ID_LEVEL_NAME 56 +#define ED_CTRL_ID_LEVEL_AUTHOR 57 /* gadgets for scrolling of drawing area */ -#define ED_CTRL_ID_SCROLL_UP 54 -#define ED_CTRL_ID_SCROLL_DOWN 55 -#define ED_CTRL_ID_SCROLL_LEFT 56 -#define ED_CTRL_ID_SCROLL_RIGHT 57 -#define ED_CTRL_ID_SCROLL_VERTICAL 58 -#define ED_CTRL_ID_SCROLL_HORIZONTAL 59 +#define ED_CTRL_ID_SCROLL_UP 58 +#define ED_CTRL_ID_SCROLL_DOWN 59 +#define ED_CTRL_ID_SCROLL_LEFT 60 +#define ED_CTRL_ID_SCROLL_RIGHT 61 +#define ED_CTRL_ID_SCROLL_VERTICAL 62 +#define ED_CTRL_ID_SCROLL_HORIZONTAL 63 -#define ED_NUM_GADGETS 60 +#define ED_NUM_GADGETS 64 /* values for counter gadgets */ #define ED_COUNTER_ID_ELEM_SCORE 0 #define ED_COUNTER_ID_ELEM_CONTENT 1 #define ED_COUNTER_ID_LEVEL_XSIZE 2 #define ED_COUNTER_ID_LEVEL_YSIZE 3 -#define ED_COUNTER_ID_LEVEL_COLLECT 4 -#define ED_COUNTER_ID_LEVEL_TIMELIMIT 5 -#define ED_COUNTER_ID_LEVEL_TIMESCORE 6 +#define ED_COUNTER_ID_LEVEL_RANDOM 4 +#define ED_COUNTER_ID_LEVEL_COLLECT 5 +#define ED_COUNTER_ID_LEVEL_TIMELIMIT 6 +#define ED_COUNTER_ID_LEVEL_TIMESCORE 7 /* values for text input gadgets */ #define ED_TEXTINPUT_ID_LEVEL_NAME 0 +#define ED_TEXTINPUT_ID_LEVEL_AUTHOR 1 -#define ED_NUM_COUNTERBUTTONS 7 +#define ED_NUM_COUNTERBUTTONS 8 #define ED_NUM_SCROLLBUTTONS 4 #define ED_NUM_SCROLLBARS 2 -#define ED_NUM_TEXTINPUT 1 +#define ED_NUM_TEXTINPUT 2 /* values for CopyLevelToUndoBuffer() */ #define UNDO_IMMEDIATE 0 @@ -263,6 +272,7 @@ static int *gadget_elem_score_value = NULL; static int *gadget_elem_content_value = NULL; static int *gadget_level_xsize_value = NULL; static int *gadget_level_ysize_value = NULL; +static int *gadget_level_random_value = NULL; static int *gadget_level_collect_value = NULL; static int *gadget_level_timelimit_value = NULL; static int *gadget_level_timescore_value = NULL; @@ -294,7 +304,7 @@ static struct "element content" }, { - ED_LEVELINFO_XPOS, ED_LEVELINFO_YPOS + 6 * MINI_TILEY, + ED_LEVELINFO_XPOS, ED_COUNTER_YPOS(0), MIN_LEV_FIELDX, MAX_LEV_FIELDX, ED_CTRL_ID_LEVEL_XSIZE_DOWN, ED_CTRL_ID_LEVEL_XSIZE_UP, ED_CTRL_ID_LEVEL_XSIZE_TEXT, @@ -302,7 +312,7 @@ static struct "playfield width" }, { - ED_LEVELINFO_XPOS, ED_LEVELINFO_YPOS + 10 * MINI_TILEY, + ED_LEVELINFO_XPOS, ED_COUNTER_YPOS(1), MIN_LEV_FIELDY, MAX_LEV_FIELDY, ED_CTRL_ID_LEVEL_YSIZE_DOWN, ED_CTRL_ID_LEVEL_YSIZE_UP, ED_CTRL_ID_LEVEL_YSIZE_TEXT, @@ -310,7 +320,15 @@ static struct "playfield height" }, { - ED_LEVELINFO_XPOS, ED_LEVELINFO_YPOS + 14 * MINI_TILEY, + ED_LEVELINFO_XPOS, ED_COUNTER_YPOS(2), + 0, 100, + ED_CTRL_ID_LEVEL_RANDOM_DOWN, ED_CTRL_ID_LEVEL_RANDOM_UP, + ED_CTRL_ID_LEVEL_RANDOM_TEXT, + &gadget_level_random_value, + "number of random elements" + }, + { + ED_LEVELINFO_XPOS, ED_COUNTER_YPOS(3), 0, 999, ED_CTRL_ID_LEVEL_COLLECT_DOWN, ED_CTRL_ID_LEVEL_COLLECT_UP, ED_CTRL_ID_LEVEL_COLLECT_TEXT, @@ -318,7 +336,7 @@ static struct "number of emeralds to collect" }, { - ED_LEVELINFO_XPOS, ED_LEVELINFO_YPOS + 18 * MINI_TILEY, + ED_LEVELINFO_XPOS, ED_COUNTER_YPOS(4), 0, 999, ED_CTRL_ID_LEVEL_TIMELIMIT_DOWN, ED_CTRL_ID_LEVEL_TIMELIMIT_UP, ED_CTRL_ID_LEVEL_TIMELIMIT_TEXT, @@ -326,7 +344,7 @@ static struct "time available to solve level" }, { - ED_LEVELINFO_XPOS, ED_LEVELINFO_YPOS + 22 * MINI_TILEY, + ED_LEVELINFO_XPOS, ED_COUNTER_YPOS(5), 0, 255, ED_CTRL_ID_LEVEL_TIMESCORE_DOWN, ED_CTRL_ID_LEVEL_TIMESCORE_UP, ED_CTRL_ID_LEVEL_TIMESCORE_TEXT, @@ -344,10 +362,16 @@ static struct } textinput_info[ED_NUM_TEXTINPUT] = { { - ED_LEVELINFO_XPOS, ED_LEVELINFO_YPOS + 26 * MINI_TILEY, + ED_LEVELINFO_XPOS, ED_COUNTER_YPOS(6), ED_CTRL_ID_LEVEL_NAME, level.name, - "level title" + "Level Title" + }, + { + ED_LEVELINFO_XPOS, ED_COUNTER_YPOS(7), + ED_CTRL_ID_LEVEL_AUTHOR, + level.author, + "Level Author" } }; @@ -1150,42 +1174,44 @@ static void CreateDrawingAreas() static void CreateTextInputGadgets() { - Pixmap gd_pixmap = pix[PIX_DOOR]; - int gd_x, gd_y; - struct GadgetInfo *gi; - unsigned long event_mask; - char infotext[MAX_INFOTEXT_LEN + 1]; - int i, id; + int i; - /* text input gadget for the level name */ - i = ED_TEXTINPUT_ID_LEVEL_NAME; - id = ED_CTRL_ID_LEVEL_NAME; + for (i=0; itext.number_value; + break; + case ED_CTRL_ID_LEVEL_COLLECT_DOWN: case ED_CTRL_ID_LEVEL_COLLECT_UP: step *= (id == ED_CTRL_ID_LEVEL_COLLECT_DOWN ? -1 : 1); @@ -3557,6 +3604,10 @@ static void HandleTextInputGadgets(struct GadgetInfo *gi) strcpy(level.name, gi->text.value); break; + case ED_CTRL_ID_LEVEL_AUTHOR: + strcpy(level.author, gi->text.value); + break; + default: break; }