- int i,x,y;
-
- ClearWindow();
- UnmapLevelEditorWindowGadgets();
-
- /* Inhalt der Mampfer */
- DrawText(ED_COUNT_GADGET_XPOS+1,SY+6,
- "Contents of a smashed cruncher:",FS_SMALL,FC_YELLOW);
- for(i=0;i<4;i++) for(y=0;y<4;y++) for(x=0;x<4;x++)
- {
- DrawMiniElement(1+5*i+x,2+y,EL_ERDREICH);
- XFillRectangle(display,drawto,gc,
- SX+(1+5*i)*MINI_TILEX+MINI_TILEX/2-1,
- SY+(2)*MINI_TILEY+MINI_TILEY/2-1,
- 3*MINI_TILEX+2,3*MINI_TILEY+2);
- }
- XCopyArea(display,drawto,drawto,gc,
- SX+1*MINI_TILEX,SY+2*MINI_TILEY,
- 4*5*MINI_TILEX,5*MINI_TILEY,
- SX+1*MINI_TILEX-MINI_TILEX/2,SY+2*MINI_TILEY-MINI_TILEY/2);
- for(i=0;i<4;i++)
- {
- for(y=0;y<3;y++) for(x=0;x<3;x++)
- DrawMiniElement(1+5*i+x,2+y,level.mampfer_inhalt[i][x][y]);
-
- DrawText(SX+MINI_TILEX+(5*i+1)*MINI_TILEX+1,
- SY+2*MINI_TILEY+(4)*MINI_TILEY-4,
- int2str(i+1,1),FS_SMALL,FC_YELLOW);
- }
-
- /* Inhalt der Amöbe */
- for(y=0;y<2;y++) for(x=0;x<2;x++)
- {
- DrawMiniElement(29+x,26+y,EL_ERDREICH);
- XFillRectangle(display,drawto,gc,
- SX+29*MINI_TILEX+MINI_TILEX/2-1,
- SY+26*MINI_TILEY+MINI_TILEY/2-1,
- MINI_TILEX+2,MINI_TILEY+2);
- }
- XCopyArea(display,drawto,drawto,gc,
- SX+29*MINI_TILEX,SY+26*MINI_TILEY,
- 3*MINI_TILEX,3*MINI_TILEY,
- SX+29*MINI_TILEX-MINI_TILEX/2,SY+26*MINI_TILEY-MINI_TILEY/2);
- DrawMiniElement(29,26,level.amoebe_inhalt);
-
- for(i=0;i<11+3+2;i++)
- {
- XCopyArea(display,pix[PIX_DOOR],drawto,gc,
- DOOR_GFX_PAGEX4+ED_BUTTON_MINUS_XPOS,
- DOOR_GFX_PAGEY1+ED_BUTTON_MINUS_YPOS,
- DXSIZE-4,ED_BUTTON_MINUS_YSIZE,
- ED_COUNT_GADGET_XPOS,
- ED_COUNT_GADGET_YPOS+i*ED_COUNT_GADGET_YSIZE);
-
- if (i<11)
- DrawText(ED_COUNT_VALUE_XPOS,
- ED_COUNT_VALUE_YPOS+i*ED_COUNT_GADGET_YSIZE,
- int2str(level.score[i],3),FS_SMALL,FC_YELLOW);
- else if (i==11)
- DrawText(ED_COUNT_VALUE_XPOS,
- ED_COUNT_VALUE_YPOS+11*ED_COUNT_GADGET_YSIZE,
- int2str(level.tempo_amoebe,3),FS_SMALL,FC_YELLOW);
- else if (i==12)
- DrawText(ED_COUNT_VALUE_XPOS,
- ED_COUNT_VALUE_YPOS+12*ED_COUNT_GADGET_YSIZE,
- int2str(level.dauer_sieb,3),FS_SMALL,FC_YELLOW);
- else if (i==13)
- DrawText(ED_COUNT_VALUE_XPOS,
- ED_COUNT_VALUE_YPOS+13*ED_COUNT_GADGET_YSIZE,
- int2str(level.dauer_ablenk,3),FS_SMALL,FC_YELLOW);
- else if (i==14)
- DrawText(ED_COUNT_VALUE_XPOS,
- ED_COUNT_VALUE_YPOS+14*ED_COUNT_GADGET_YSIZE,
- int2str(level.edelsteine,3),FS_SMALL,FC_YELLOW);
- else if (i==15)
- DrawText(ED_COUNT_VALUE_XPOS,
- ED_COUNT_VALUE_YPOS+15*ED_COUNT_GADGET_YSIZE,
- int2str(level.time,3),FS_SMALL,FC_YELLOW);
- }
-
- DrawText(ED_COUNT_TEXT_XPOS,ED_COUNT_TEXT_YPOS+0*ED_COUNT_TEXT_YSIZE,
- "Score for Emerald",FS_SMALL,FC_YELLOW);
- DrawText(ED_COUNT_TEXT_XPOS,ED_COUNT_TEXT_YPOS+1*ED_COUNT_TEXT_YSIZE,
- "Score for Diamond",FS_SMALL,FC_YELLOW);
- DrawText(ED_COUNT_TEXT_XPOS,ED_COUNT_TEXT_YPOS+2*ED_COUNT_TEXT_YSIZE,
- "Score for smashing a Bug",FS_SMALL,FC_YELLOW);
- DrawText(ED_COUNT_TEXT_XPOS,ED_COUNT_TEXT_YPOS+3*ED_COUNT_TEXT_YSIZE,
- "Score for smashing a Spaceship",FS_SMALL,FC_YELLOW);
- DrawText(ED_COUNT_TEXT_XPOS,ED_COUNT_TEXT_YPOS+4*ED_COUNT_TEXT_YSIZE,
- "Score for smashing a Cruncher",FS_SMALL,FC_YELLOW);
- DrawText(ED_COUNT_TEXT_XPOS,ED_COUNT_TEXT_YPOS+5*ED_COUNT_TEXT_YSIZE,
- "Score for smashing an Alien",FS_SMALL,FC_YELLOW);
- DrawText(ED_COUNT_TEXT_XPOS,ED_COUNT_TEXT_YPOS+6*ED_COUNT_TEXT_YSIZE,
- "Score for smashing a Pacman",FS_SMALL,FC_YELLOW);
- DrawText(ED_COUNT_TEXT_XPOS,ED_COUNT_TEXT_YPOS+7*ED_COUNT_TEXT_YSIZE,
- "Score for cracking a nut",FS_SMALL,FC_YELLOW);
- DrawText(ED_COUNT_TEXT_XPOS,ED_COUNT_TEXT_YPOS+8*ED_COUNT_TEXT_YSIZE,
- "Score for dynamite",FS_SMALL,FC_YELLOW);
- DrawText(ED_COUNT_TEXT_XPOS,ED_COUNT_TEXT_YPOS+9*ED_COUNT_TEXT_YSIZE,
- "Score for key",FS_SMALL,FC_YELLOW);
- DrawText(ED_COUNT_TEXT_XPOS,ED_COUNT_TEXT_YPOS+10*ED_COUNT_TEXT_YSIZE,
- "Score for each 10 seconds left",FS_SMALL,FC_YELLOW);
- DrawText(ED_COUNT_TEXT_XPOS,ED_COUNT_TEXT_YPOS+11*ED_COUNT_TEXT_YSIZE,
- "Speed of the amoeba / Content",FS_SMALL,FC_YELLOW);
- DrawText(ED_COUNT_TEXT_XPOS,ED_COUNT_TEXT_YPOS+12*ED_COUNT_TEXT_YSIZE,
- "Time for magic wall",FS_SMALL,FC_YELLOW);
- DrawText(ED_COUNT_TEXT_XPOS,ED_COUNT_TEXT_YPOS+13*ED_COUNT_TEXT_YSIZE,
- "Time for wheel",FS_SMALL,FC_YELLOW);
- DrawText(ED_COUNT_TEXT_XPOS,ED_COUNT_TEXT_YPOS+14*ED_COUNT_TEXT_YSIZE,
- "Emeralds needed in this level",FS_SMALL,FC_YELLOW);
- DrawText(ED_COUNT_TEXT_XPOS,ED_COUNT_TEXT_YPOS+15*ED_COUNT_TEXT_YSIZE,
- "Time available for this level",FS_SMALL,FC_YELLOW);
-
- XCopyArea(display,pix[PIX_DOOR],drawto,gc,
- DOOR_GFX_PAGEX4+ED_WIN_COUNT_XPOS,
- DOOR_GFX_PAGEY1+ED_WIN_COUNT_YPOS,
- ED_WIN_COUNT_XSIZE,ED_WIN_COUNT_YSIZE,
- ED_COUNT_GADGET_XPOS,
- ED_COUNT_GADGET_YPOS+16*ED_COUNT_GADGET_YSIZE);
- for(i=1;i<31;i++)
- XCopyArea(display,pix[PIX_DOOR],drawto,gc,
- DOOR_GFX_PAGEX4+ED_WIN_COUNT_XPOS+3+2*FONT2_XSIZE,
- DOOR_GFX_PAGEY1+ED_WIN_COUNT_YPOS,
- ED_WIN_COUNT_XSIZE-3-2*FONT2_XSIZE,ED_WIN_COUNT_YSIZE,
- ED_COUNT_GADGET_XPOS+3+i*FONT2_XSIZE,
- ED_COUNT_GADGET_YPOS+16*ED_COUNT_GADGET_YSIZE);
- DrawText(ED_COUNT_GADGET_XPOS+5,
- ED_COUNT_TEXT_YPOS+16*ED_COUNT_TEXT_YSIZE,
- level.name,FS_SMALL,FC_YELLOW);
- DrawText(ED_COUNT_GADGET_XPOS+(30+3)*FONT2_XSIZE-5,
- ED_COUNT_TEXT_YPOS+16*ED_COUNT_TEXT_YSIZE,
- "Title",FS_SMALL,FC_YELLOW);
-
- DrawText(ED_SIZE_GADGET_XPOS,ED_SIZE_GADGET_YPOS-18,
- "Playfield size:",FS_SMALL,FC_YELLOW);
- XCopyArea(display,pix[PIX_DOOR],drawto,gc,
- DOOR_GFX_PAGEX4+ED_BUTTON_MINUS_XPOS,
- DOOR_GFX_PAGEY1+ED_BUTTON_MINUS_YPOS,
- DXSIZE-4,ED_BUTTON_MINUS_YSIZE,
- ED_SIZE_GADGET_XPOS,
- ED_SIZE_GADGET_YPOS+0*ED_COUNT_GADGET_YSIZE);
- XCopyArea(display,pix[PIX_DOOR],drawto,gc,
- DOOR_GFX_PAGEX4+ED_BUTTON_MINUS_XPOS,
- DOOR_GFX_PAGEY1+ED_BUTTON_MINUS_YPOS,
- DXSIZE-4,ED_BUTTON_MINUS_YSIZE,
- ED_SIZE_GADGET_XPOS,
- ED_SIZE_GADGET_YPOS+1*ED_COUNT_GADGET_YSIZE);
- DrawText(ED_SIZE_TEXT_XPOS,ED_SIZE_TEXT_YPOS+0*ED_SIZE_TEXT_YSIZE,
- "Width",FS_SMALL,FC_YELLOW);
- DrawText(ED_SIZE_TEXT_XPOS,ED_SIZE_TEXT_YPOS+1*ED_SIZE_TEXT_YSIZE,
- "Height",FS_SMALL,FC_YELLOW);
- DrawText(ED_SIZE_VALUE_XPOS,ED_SIZE_VALUE_YPOS+0*ED_SIZE_GADGET_YSIZE,
- int2str(level.fieldx,3),FS_SMALL,FC_YELLOW);
- DrawText(ED_SIZE_VALUE_XPOS,ED_SIZE_VALUE_YPOS+1*ED_SIZE_GADGET_YSIZE,
- int2str(level.fieldy,3),FS_SMALL,FC_YELLOW);
+ int ed_xsize = lev_fieldx + 2;
+ int ed_ysize = lev_fieldy + 2;
+ int max_ed_fieldx = MAX_ED_FIELDX;
+ int max_ed_fieldy = MAX_ED_FIELDY;
+ boolean horizontal_scrollbar_needed;
+ boolean vertical_scrollbar_needed;
+ int x, y, width, height;
+ int xoffset, yoffset;
+
+ /* check if we need any scrollbars */
+ horizontal_scrollbar_needed = (ed_xsize > max_ed_fieldx);
+ vertical_scrollbar_needed = (ed_ysize > max_ed_fieldy);
+
+ /* check if we have a smaller editor field because of scrollbars */
+ if (horizontal_scrollbar_needed)
+ max_ed_fieldy = MAX_ED_FIELDY - 1;
+ if (vertical_scrollbar_needed)
+ max_ed_fieldx = MAX_ED_FIELDX - 1;
+
+ /* check again if we now need more scrollbars because of less space */
+ horizontal_scrollbar_needed = (ed_xsize > max_ed_fieldx);
+ vertical_scrollbar_needed = (ed_ysize > max_ed_fieldy);
+
+ /* check if editor field gets even smaller after adding new scrollbars */
+ if (horizontal_scrollbar_needed)
+ max_ed_fieldy = MAX_ED_FIELDY - 1;
+ if (vertical_scrollbar_needed)
+ max_ed_fieldx = MAX_ED_FIELDX - 1;
+
+ ed_fieldx = (ed_xsize < MAX_ED_FIELDX ? ed_xsize : max_ed_fieldx);
+ ed_fieldy = (ed_ysize < MAX_ED_FIELDY ? ed_ysize : max_ed_fieldy);
+
+ ModifyGadget(level_editor_gadget[GADGET_ID_DRAWING_LEVEL],
+ GDI_WIDTH, ed_fieldx * MINI_TILEX,
+ GDI_HEIGHT, ed_fieldy * MINI_TILEY,
+ GDI_AREA_SIZE, ed_fieldx, ed_fieldy,
+ GDI_END);
+
+ xoffset = (ed_fieldx == MAX_ED_FIELDX ? ED_SCROLLBUTTON_XSIZE : 0);
+ yoffset = (ed_fieldy == MAX_ED_FIELDY ? ED_SCROLLBUTTON_YSIZE : 0);
+
+ x = SX + scrollbutton_info[ED_SCROLLBUTTON_ID_AREA_RIGHT].x + xoffset;
+ y = SX + scrollbutton_info[ED_SCROLLBUTTON_ID_AREA_DOWN].y + yoffset;
+
+ ModifyGadget(level_editor_gadget[GADGET_ID_SCROLL_RIGHT], GDI_X, x, GDI_END);
+ ModifyGadget(level_editor_gadget[GADGET_ID_SCROLL_DOWN], GDI_Y, y, GDI_END);
+
+ width = scrollbar_info[ED_SCROLLBAR_ID_HORIZONTAL].width + xoffset;
+ height = scrollbar_info[ED_SCROLLBAR_ID_VERTICAL].height + yoffset;
+
+ ModifyGadget(level_editor_gadget[GADGET_ID_SCROLL_HORIZONTAL],
+ GDI_WIDTH, width,
+ GDI_SCROLLBAR_ITEMS_VISIBLE, ed_fieldx,
+ GDI_END);
+ ModifyGadget(level_editor_gadget[GADGET_ID_SCROLL_VERTICAL],
+ GDI_HEIGHT, height,
+ GDI_SCROLLBAR_ITEMS_VISIBLE, ed_fieldy,
+ GDI_END);