tetris, mine: appearance fixes

git-svn-id: svn://kolibrios.org@6166 a494cfbc-eb01-0410-851d-a64ba20cac60
This commit is contained in:
Kirill Lipatov (Leency) 2016-02-07 20:43:08 +00:00
parent b7c1c94b59
commit 3e5852cee7
5 changed files with 22 additions and 276 deletions

View File

@ -27,7 +27,7 @@ void draw_window() //
sys_window_redraw(1); sys_window_redraw(1);
EBX = xpos << 16 + xsize; EBX = xpos << 16 + xsize;
ECX = ypos << 16 + ysize; ECX = ypos << 16 + ysize;
sys_draw_window(EBX, ECX, 0x14CCCCCC, colors.w_grab | 0x80000000, "MineSweeper"); sys_draw_window(EBX, ECX, 0x14CCCCCC, colors.w_work | 0x80000000, "MineSweeper");
sys_window_redraw(2); sys_window_redraw(2);
// Leency ROLLED UP FIX // Leency ROLLED UP FIX
@ -135,7 +135,7 @@ void draw_square(int x, y)
// Òàéìåð // Òàéìåð
void draw_time() void draw_time()
{ {
sys_draw_bar(XST<<16+25, 31<<16+10, 0xCCCCCC); sys_draw_bar(XST<<16+25, 31<<16+14, 0xCCCCCC);
sys_write_number(0x00030000, time, XST<<16+32, 0x10ff0000); sys_write_number(0x00030000, time, XST<<16+32, 0x10ff0000);
} }
@ -146,7 +146,7 @@ void draw_minesi()
EBX = xsize - XST - 25; EBX = xsize - XST - 25;
$PUSH EBX $PUSH EBX
EBX = EBX << 16 + 25; EBX = EBX << 16 + 25;
sys_draw_bar(EBX, 31<<16+10, 0xCCCCCC); sys_draw_bar(EBX, 31<<16+14, 0xCCCCCC);
$POP EDX $POP EDX
EDX <<= 16; EDX += 32; EDX <<= 16; EDX += 32;
sys_write_number(0x00030000, cmines, EDX, 0x10ff0000); sys_write_number(0x00030000, cmines, EDX, 0x10ff0000);

View File

@ -65,11 +65,11 @@ struct ProcessInfo
struct SystemColours struct SystemColours
{ {
dword w_frames, dword nonset1,
w_grab, nonset2,
w_grab_button, work_3d_dark,
w_grab_button_text, work_3d_light,
w_grab_text, w_title,
w_work, w_work,
w_work_button, w_work_button,
w_work_button_text, w_work_button_text,

View File

@ -102,7 +102,6 @@ inline void fastcall mouse_disable()
# include "draw.h--" // drawing functions # include "draw.h--" // drawing functions
# include "access.h--" // get & set functions # include "access.h--" // get & set functions
# include "random.h--" // random number generator # include "random.h--" // random number generator
//? include "uf.h--" // user field window
void init() void init()

View File

@ -1,232 +0,0 @@
/*******************************************************************************
MenuetOS MineSweeper
Copyright (C) 2003, 2004 Ivan Poddubny
This program is free software; you can redistribute it and/or modify
it under the terms of the GNU General Public License as published by
the Free Software Foundation; either version 2 of the License, or
(at your option) any later version.
This program is distributed in the hope that it will be useful,
but WITHOUT ANY WARRANTY; without even the implied warranty of
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
GNU General Public License for more details.
You should have received a copy of the GNU General Public License
along with this program; if not, write to the Free Software
Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
*******************************************************************************/
// USER FIELD WINDOW
byte px,py,pm;
byte uf_open = FALSE;
byte uf_stack[2048];
dword active_textbox = #str1;
byte str1[4] = {'1','1','1',0};
byte str2[4] = {'2','2','2',0};
byte str3[4] = {'3','2','1',0};
dword uf_x=0,
uf_y=0;
:fastcall dword str2dword(dword EAX)
// str2byte ïåðåâîäèò ñòðîêó èç 3¸õ öèôð â áàéò
// IN: EAX = àäðåñ ñòîðêè
// OUT: EAX = áàéò
{
EDX = 0;
ECX = 0;
WHILE(ECX<3)
{
EDX *= 10;
EBX = DSBYTE[EAX+ECX];
EBX -= '0';
EDX += EBX;
ECX++;
}
EAX = EDX;
}
:fastcall void dword2str(dword EAX,ESI)
{
$PUSHA
DSDWORD[ESI]=0;
// EAX &= 255;
EDI = 10;
ECX = 2;
WHILE(ECX>=0)
{
IF(!EAX) BREAK;
$XOR EDX,EDX
$DIV EDI // al = div; dl = mod
DL += '0';
DSBYTE[ESI+ECX] = DL;
ECX--;
}
$POPA
}
void draw_uf_window()
{
#ifdef DEBUG
sys_debug_write_string("MINE: îòðèñîâêà UF\n"w);
#endif
sys_get_colors(#colors, 40);
sys_window_redraw(1);
EDX = colors.w_work;
$bts edx,25
EBX = uf_x;
ECX = uf_y;
sys_draw_window(EBX, ECX, EDX, colors.w_grab | 0x80000000, colors.w_frames);
ECX = colors.w_grab_text | 0x10000000;
sys_write_text(7<<16+8, colors.w_grab_text | 0x10000000, "USER FIELD"n, 10);
sys_draw_button(83<<16+12, 5<<16+12, 1, colors.w_grab_button);
// three buttons:
// 1) WIDTH 10
// 2) HEIGHT 11
// 3) MINES 12
// and also:
// OK, Cancel - 20,21
sys_draw_button(54<<16+38, 30<<16+10, 10, 0xe0e0e0); // WIDTH
EDX++; sys_draw_button(EBX, 48<<16+10, EDX, ESI); // HEIGHT
EDX++; sys_draw_button(EBX, 66<<16+10, EDX, ESI); // MINES
ESI = colors.w_work_button;
ECX = 84<<16+10;
sys_draw_button( 8<<16+38, ECX, 20, ESI); EDX++;
sys_draw_button(54<<16+38, ECX, EDX, ESI);
ECX = colors.w_work_text | 0x10000000;
sys_write_text(8<<16+32, ECX, "WIDTH"n, 5);
sys_write_text(8<<16+50, ECX, "HEIGHT"n, 6);
sys_write_text(8<<16+68, ECX, "MINES"n, 5);
sys_write_text(72<<16+32, 0, #str1, 3);
sys_write_text(72<<16+50, 0, #str2, 3);
sys_write_text(72<<16+68, 0, #str3, 3);
sys_write_text(21<<16+86, colors.w_work_button_text, "OK Cancel", 12);
sys_window_redraw(2);
}
void uf_main()
{
#ifdef DEBUG
sys_debug_write_string("MINE: ïîòîê ñîçäàí\n"w);
#endif
// dword2str(13, #str1);
// EAX = str2dword(#str3);
// dword2str(EAX, #str2);
uf_x <<= 16; uf_x += 100;
uf_y <<= 16; uf_y += 104;
draw_uf_window();
#ifdef DEBUG
sys_debug_write_string("MINE: æäó ñîáûòèé\n"w);
#endif
WHILE()
{
SWITCH (sys_wait_event())
{
case 1: draw_uf_window();
break;
case 2: //IF (sys_get_key() == 27)
//{
// uf_open = FALSE;
// sys_exit_process();
//}
//EAX = key now!
EAX = sys_get_key();
if (active_textbox != 0)
{
EBX = #str1; //active_textbox;
DSBYTE[EBX] = 'A';
DSBYTE[EBX] = DSBYTE[EBX+1];
DSBYTE[EBX+1] = DSBYTE[EBX+2];
DSBYTE[EBX+2] = AL;
draw_uf_window();
}
break;
case 3: uf_button();
}
}
}
uf_button()
{
switch (sys_get_button_id())
{
case 10:
// set [width] INPUT active
active_textbox = #str1; break;
case 11:
// set [height] INPUT active
active_textbox = #str2; break;
case 12:
// set [mines] INPUT active
active_textbox = #str3; break;
case 20:
// [string -> byte] three times and save them
px = str2dword(#str1);
py = str2dword(#str2);
pm = str2dword(#str3);
mode = 4;
case 21:
// close UF window, forget all changes
case 1:
uf_open = FALSE;
sys_exit_process();
}
}
void start_uf()
{
#ifdef DEBUG
sys_debug_write_string("MINE: âûçâàíà start_uf\n"w);
#endif
sys_process_info(#procinfo, -1);
uf_x = procinfo.xstart + XST;
uf_y = procinfo.ystart + YST;
#ifdef DEBUG
sys_debug_write_string("MINE: ñîçäàþ ïîòîê...\n"w);
#endif
sys_create_thread(#uf_main, #uf_stack + 2048);
IF(EAX > 0x80000000)
return;
uf_open = TRUE;
mouse_disable();
WHILE (uf_open == TRUE)
{
SWITCH (sys_wait_event_timeout(5))
{
CASE 1: draw_window(); CONTINUE;
CASE 2: sys_get_key(); CONTINUE;
CASE 3: sys_get_button_id(); CONTINUE;
}
}
mouse_enable();
}

View File

@ -26,7 +26,6 @@
; 31.10.2001 - rdtsc replaced - quickcode <quickcode@mail.ru> ; 31.10.2001 - rdtsc replaced - quickcode <quickcode@mail.ru>
; 28.06.2001 - fasm port & framed blocks - Ville Turjanmaa ; 28.06.2001 - fasm port & framed blocks - Ville Turjanmaa
; ;
;
LEN_X equ 19 ;width of table LEN_X equ 19 ;width of table
LEN_Y equ 29 ; height of table LEN_Y equ 29 ; height of table
@ -254,50 +253,30 @@ jmp still
; ********************************************* ; *********************************************
draw_window: draw_window:
mcall 48,3,sc,sizeof.system_colors
mov eax,48 mcall 12,1
mov ebx,3 ; DRAW WINDOW
mov ecx,sc
mov edx,sizeof.system_colors
int 0x40
mov eax,12 ; function 12:tell os about windowdraw
mov ebx,1 ; 1, start of draw
int 0x40
; DRAW WINDOW
xor eax,eax ; function 0 : define and draw window xor eax,eax ; function 0 : define and draw window
mov ebx,320*65536+(LEN_X-BORDER_LEFT-BORDER_RIGHT)*ADOBE_SIZE+X_LOCATION*2 mov ebx,320*65536+(LEN_X-BORDER_LEFT-BORDER_RIGHT)*ADOBE_SIZE+X_LOCATION*2
mov ecx,25*65536+ (LEN_Y-BORDER_TOP-BORDER_BOTTOM)*ADOBE_SIZE+Y_LOCATION+30 mov ecx,25*65536+ (LEN_Y-BORDER_TOP-BORDER_BOTTOM)*ADOBE_SIZE+Y_LOCATION+36
mov edx,[sc.work] ; color of work area RRGGBB mov edx,[sc.work] ; color of work area RRGGBB
or edx,0x13000000 or edx,0x13000000
mov edi,title ; WINDOW LABEL mov edi,title ; WINDOW LABEL
int 0x40 int 0x40
mcall 8, 30*65536+100,378*65536+22,2,[sc.work_button] ;new game
mov eax,8 mcall ,132*65536+102, ,3 ;Wildwest's 'Pause' button
mov ebx,30*65536+100 ;///////////////////////////////////////////////
mov ecx,378*65536+18
mov edx,2
mov esi,[sc.work_button]
int 0x40
;/////////////////////////////////////////////// Wildwest's 'Pause' button
;mov eax,8
mov ebx,132*65536+102
mov ecx,378*65536+18
mov edx,3
mov esi,[sc.work_button];
int 0x40
mov eax,4 ; function 4 : write text to window mov eax,4 ; function 4 : write text to window
mov ebx,164*65536+384 ; [x start] *65536 + [y start] mov ebx,164*65536+383 ; [x start] *65536 + [y start]
mov ecx,[sc.work_button_text] ; color of text RRGGBB mov ecx,[sc.work_button_text] ; color of text RRGGBB
or ecx,0x90000000 or ecx,0x90000000
mov edx,labe ; pointer to text mov edx,labe ; pointer to text
int 0x40 int 0x40
;/////////////////////////////////////////////// ;///////////////////////////////////////////////
;mov eax,4 ;mov eax,4
mov ebx,49*65536+384 mov ebx,49*65536+383
mov edx,game_finished mov edx,game_finished
int 0x40 int 0x40
call draw_table call draw_table
@ -306,7 +285,7 @@ draw_window:
call draw_block call draw_block
cld cld
mov ebx,38*65536+35 ; draw info text with function 4 mov ebx,38*65536+32 ; draw info text with function 4
mov ecx,[sc.work_text] ; color mov ecx,[sc.work_text] ; color
or ecx,0x90000000 or ecx,0x90000000
mov edx,text mov edx,text
@ -658,7 +637,7 @@ write_score:
mov eax,[score] mov eax,[score]
call number_to_str call number_to_str
mov ebx,90*65536+35 ; draw info text with function 4 mov ebx,90*65536+32 ; draw info text with function 4
mov ecx,[sc.work_text] ; color mov ecx,[sc.work_text] ; color
or ecx,0x50000000 or ecx,0x50000000
mov edx,number_str mov edx,number_str
@ -841,21 +820,21 @@ block_table:
if lang eq ru if lang eq ru
title db '<EFBFBD>ˆ 1.61 - <E28098>Šˆ ˆ <20><>Ž<EFBFBD>',0 title db '¥âà¨á 1.62',0
labe db '<27>€“‡€',0 labe db '<27>€“‡€',0
text db 'Žçª¨:',0 text db 'Žçª¨:',0
game_finished: db ' <20>Ž€Ÿ',0 game_finished: db ' <20>Ž€Ÿ',0
else if lang eq et else if lang eq et
title db 'TETRIS 1.61 - NOOLED & TÜHIK',0 title db 'Tetris 1.62',0
labe db 'PAUS',0 labe db 'PAUS',0
text db 'Tulemus:',0 text db 'Tulemus:',0
game_finished: db 'UUS MÄNG',0 game_finished: db 'UUS MÄNG',0
else else
title db 'TETRIS 1.61 - ARROWS & SPACE',0 title db 'Tetris 1.62',0
labe db 'PAUSE',0 labe db 'PAUSE',0
text db 'Score:',0 text db 'Score:',0
game_finished: db 'NEW GAME',0 game_finished: db 'NEW GAME',0