forked from KolibriOS/kolibrios
CPU v1.8
1) Complete elimination of flicker. 2) Using f.0 C = 1 3) Increasing the size of buttons and a bright color. git-svn-id: svn://kolibrios.org@2582 a494cfbc-eb01-0410-851d-a64ba20cac60
This commit is contained in:
parent
e22890bbd0
commit
c2ff395a8a
@ -2,6 +2,13 @@
|
|||||||
; CPU -process Manager
|
; CPU -process Manager
|
||||||
;
|
;
|
||||||
;------------------------------------------------------------------------------
|
;------------------------------------------------------------------------------
|
||||||
|
; version: 1.80
|
||||||
|
; last update: 07/04/2012
|
||||||
|
; changed by: Marat Zakiyanov aka Mario79, aka Mario
|
||||||
|
; changes: Complete elimination of flicker.
|
||||||
|
; Using f.0 C = 1 - don't fill working area on window draw.
|
||||||
|
; Increasing the size of buttons and a bright color.
|
||||||
|
;------------------------------------------------------------------------------
|
||||||
; version: 1.70
|
; version: 1.70
|
||||||
; last update: 04/04/2012
|
; last update: 04/04/2012
|
||||||
; changed by: Marat Zakiyanov aka Mario79, aka Mario
|
; changed by: Marat Zakiyanov aka Mario79, aka Mario
|
||||||
@ -36,7 +43,7 @@ include '../../../macros.inc'
|
|||||||
include '../../../develop/libraries/box_lib/trunk/box_lib.mac'
|
include '../../../develop/libraries/box_lib/trunk/box_lib.mac'
|
||||||
include '../../../develop/libraries/box_lib/load_lib.mac'
|
include '../../../develop/libraries/box_lib/load_lib.mac'
|
||||||
;------------------------------------------------------------------------------
|
;------------------------------------------------------------------------------
|
||||||
display_processes=32 ; number of processes to show
|
display_processes=24 ;32 ; number of processes to show
|
||||||
window_x_size=524
|
window_x_size=524
|
||||||
window_y_size=430
|
window_y_size=430
|
||||||
;------------------------------------------------------------------------------
|
;------------------------------------------------------------------------------
|
||||||
@ -94,9 +101,6 @@ still:
|
|||||||
dec eax ; button in buffer ?
|
dec eax ; button in buffer ?
|
||||||
jz button
|
jz button
|
||||||
|
|
||||||
; sub eax,3 ; If not use mouse - show
|
|
||||||
; jnz still_end
|
|
||||||
|
|
||||||
push dword edit1
|
push dword edit1
|
||||||
call [edit_box_mouse]
|
call [edit_box_mouse]
|
||||||
|
|
||||||
@ -179,7 +183,7 @@ button:
|
|||||||
jle still_end
|
jle still_end
|
||||||
;terminate application
|
;terminate application
|
||||||
mcall 18,2
|
mcall 18,2
|
||||||
jmp show_process_info_1 ;still_end
|
jmp show_process_info_1
|
||||||
;--------------------------------------
|
;--------------------------------------
|
||||||
align 4
|
align 4
|
||||||
noterm:
|
noterm:
|
||||||
@ -205,21 +209,20 @@ noterm:
|
|||||||
align 4
|
align 4
|
||||||
pgdn:
|
pgdn:
|
||||||
sub [list_start],display_processes
|
sub [list_start],display_processes
|
||||||
; cmp [list_start],0
|
jge show_process_info_1
|
||||||
jge show_process_info_1 ;still_end
|
|
||||||
mov [list_start],0
|
mov [list_start],0
|
||||||
jmp show_process_info_1 ;still_end
|
jmp show_process_info_1
|
||||||
;------------------------------------------------------------------------------
|
;------------------------------------------------------------------------------
|
||||||
align 4
|
align 4
|
||||||
pgup:
|
pgup:
|
||||||
mov eax,[list_add] ;maximal displayed process slot
|
mov eax,[list_add] ;maximal displayed process slot
|
||||||
mov [list_start],eax
|
mov [list_start],eax
|
||||||
jmp show_process_info_1 ;still_end
|
jmp show_process_info_1
|
||||||
;------------------------------------------------------------------------------
|
;------------------------------------------------------------------------------
|
||||||
align 4
|
align 4
|
||||||
program_start:
|
program_start:
|
||||||
mcall 70,file_start
|
mcall 70,file_start
|
||||||
jmp show_process_info_1 ;still_end
|
jmp show_process_info_1
|
||||||
;------------------------------------------------------------------------------
|
;------------------------------------------------------------------------------
|
||||||
align 4
|
align 4
|
||||||
reboot:
|
reboot:
|
||||||
@ -232,6 +235,24 @@ close:
|
|||||||
mcall
|
mcall
|
||||||
;------------------------------------------------------------------------------
|
;------------------------------------------------------------------------------
|
||||||
align 4
|
align 4
|
||||||
|
draw_empty_slot:
|
||||||
|
cmp [draw_window_flag],1
|
||||||
|
je @f
|
||||||
|
mov ecx,[curposy]
|
||||||
|
shl ecx,16
|
||||||
|
mov cx,10 ; button height
|
||||||
|
push ecx
|
||||||
|
add ecx,3 shl 16
|
||||||
|
mcall 13,<11,95>,,[btn_bacground_color]
|
||||||
|
pop ecx
|
||||||
|
|
||||||
|
mcall 13,<111,393>,,[bar_bacground_color]
|
||||||
|
;--------------------------------------
|
||||||
|
align 4
|
||||||
|
@@:
|
||||||
|
ret
|
||||||
|
;------------------------------------------------------------------------------
|
||||||
|
align 4
|
||||||
draw_next_process:
|
draw_next_process:
|
||||||
;input:
|
;input:
|
||||||
; edi - current slot
|
; edi - current slot
|
||||||
@ -240,39 +261,61 @@ draw_next_process:
|
|||||||
; edi - next slot (or -1 if no next slot)
|
; edi - next slot (or -1 if no next slot)
|
||||||
;registers corrupted!
|
;registers corrupted!
|
||||||
;delete old button
|
;delete old button
|
||||||
|
cmp [draw_window_flag],0
|
||||||
|
je @f
|
||||||
mov edx,[index]
|
mov edx,[index]
|
||||||
add edx,(1 shl 31)+11
|
add edx,(1 shl 31)+11
|
||||||
mcall 8
|
mcall 8
|
||||||
|
;--------------------------------------
|
||||||
|
align 4
|
||||||
|
@@:
|
||||||
;create terminate process button
|
;create terminate process button
|
||||||
mov ecx,[curposy]
|
mov ecx,[curposy]
|
||||||
shl ecx,16
|
shl ecx,16
|
||||||
mov cx,10
|
mov cx,13 ; button height
|
||||||
mov edx,[index]
|
mov edx,[index]
|
||||||
add edx,11
|
add edx,11
|
||||||
mov esi,0xaabbcc
|
mov esi,0xccddee ; 0xaabbcc
|
||||||
;contrast
|
;contrast
|
||||||
test dword [index],1
|
test dword [index],1
|
||||||
jz .change_color_button
|
jz .change_color_button
|
||||||
mov esi,0x8899aa
|
mov esi,0xaabbcc ; 0x8899aa
|
||||||
;--------------------------------------
|
;--------------------------------------
|
||||||
align 4
|
align 4
|
||||||
.change_color_button:
|
.change_color_button:
|
||||||
mcall ,<10,99>
|
cmp [draw_window_flag],0
|
||||||
|
je @f
|
||||||
|
mcall 8,<10,99>
|
||||||
|
;--------------------------------------
|
||||||
|
align 4
|
||||||
|
@@:
|
||||||
|
mov [btn_bacground_color],esi
|
||||||
;draw background for proccess information
|
;draw background for proccess information
|
||||||
; ecx was already set
|
; ecx was already set
|
||||||
mov edx,0x88ff88
|
mov edx,0xddffdd ; 0x88ff88
|
||||||
;contrast
|
;contrast
|
||||||
test dword [index],1
|
test dword [index],1
|
||||||
jz .change_color_info
|
jz .change_color_info
|
||||||
mov edx,0xddffdd
|
mov edx,0xffffff ; 0xddffdd
|
||||||
;--------------------------------------
|
;--------------------------------------
|
||||||
align 4
|
align 4
|
||||||
.change_color_info:
|
.change_color_info:
|
||||||
|
inc cx
|
||||||
|
cmp [draw_window_flag],0
|
||||||
|
je @f
|
||||||
mcall 13,<110,395>
|
mcall 13,<110,395>
|
||||||
|
;--------------------------------------
|
||||||
|
align 4
|
||||||
|
@@:
|
||||||
|
mov [bar_bacground_color],edx
|
||||||
;nothing else should be done
|
;nothing else should be done
|
||||||
;if there is no process for this button
|
;if there is no process for this button
|
||||||
test edi,edi
|
cmp edi,-1
|
||||||
jl .ret
|
jne .return_1
|
||||||
|
|
||||||
|
call draw_empty_slot
|
||||||
|
or edi,-1
|
||||||
|
jmp .ret
|
||||||
;--------------------------------------
|
;--------------------------------------
|
||||||
align 4
|
align 4
|
||||||
.return_1:
|
.return_1:
|
||||||
@ -302,6 +345,7 @@ align 4
|
|||||||
;--------------------------------------
|
;--------------------------------------
|
||||||
align 4
|
align 4
|
||||||
.no_processes:
|
.no_processes:
|
||||||
|
call draw_empty_slot
|
||||||
or edi,-1
|
or edi,-1
|
||||||
ret
|
ret
|
||||||
;--------------------------------------
|
;--------------------------------------
|
||||||
@ -368,18 +412,27 @@ align 4
|
|||||||
.color_set:
|
.color_set:
|
||||||
;show slot number
|
;show slot number
|
||||||
;ecx haven't changed since .process_found
|
;ecx haven't changed since .process_found
|
||||||
; mov ecx,edi
|
push edi
|
||||||
mov edx,[curposy]
|
mov edx,[curposy]
|
||||||
add edx,15*65536+1
|
add edx,15*65536+3
|
||||||
mcall 47,<2,256>,,,[tcolor]
|
mov esi,[tcolor]
|
||||||
|
and esi,0xffffff
|
||||||
|
or esi,0x40000000
|
||||||
|
mcall 47,<2,256>,,,,[btn_bacground_color]
|
||||||
;show process name
|
;show process name
|
||||||
mov ebx,[curposy]
|
mov ebx,[curposy]
|
||||||
add ebx,45*65536+1
|
add ebx,40*65536+3
|
||||||
mcall 4,,[tcolor],process_info_buffer.process_name,11
|
mov ecx,[tcolor]
|
||||||
|
and ecx,0xffffff
|
||||||
|
or ecx,0x40000000
|
||||||
|
mcall 4,,,process_info_buffer.process_name,11,[btn_bacground_color]
|
||||||
;show pid
|
;show pid
|
||||||
mov edx,[curposy]
|
mov edx,[curposy]
|
||||||
add edx,125*65536+1
|
add edx,125*65536+3
|
||||||
mcall 47,<8,256>,[process_info_buffer.PID],,[tcolor]
|
mov esi,[tcolor]
|
||||||
|
and esi,0xffffff
|
||||||
|
or esi,0x40000000
|
||||||
|
mcall 47,<8,256>,[process_info_buffer.PID],,,[bar_bacground_color]
|
||||||
;show cpu usage
|
;show cpu usage
|
||||||
add edx,60*65536
|
add edx,60*65536
|
||||||
mcall ,,[process_info_buffer.cpu_usage]
|
mcall ,,[process_info_buffer.cpu_usage]
|
||||||
@ -403,6 +456,7 @@ align 4
|
|||||||
add ecx,[process_info_buffer.box.top]
|
add ecx,[process_info_buffer.box.top]
|
||||||
add edx,60*65536
|
add edx,60*65536
|
||||||
mcall
|
mcall
|
||||||
|
pop edi
|
||||||
;--------------------------------------
|
;--------------------------------------
|
||||||
align 4
|
align 4
|
||||||
.ret:
|
.ret:
|
||||||
@ -427,10 +481,42 @@ draw_window:
|
|||||||
; DRAW WINDOW
|
; DRAW WINDOW
|
||||||
xor eax,eax ; function 0 : define and draw window
|
xor eax,eax ; function 0 : define and draw window
|
||||||
xor esi,esi
|
xor esi,esi
|
||||||
mcall ,[winxpos],[winypos],0x34ddffdd,,title
|
mcall ,[winxpos],[winypos],0x74ffffff,,title ;0x34ddffdd
|
||||||
|
|
||||||
|
mcall 9,process_info_buffer,-1
|
||||||
|
mov eax,[ebx+62]
|
||||||
|
inc eax
|
||||||
|
mov [client_area_x_size],eax
|
||||||
|
mov eax,[ebx+66]
|
||||||
|
inc eax
|
||||||
|
mov [client_area_y_size],eax
|
||||||
|
|
||||||
|
mov ebx,[client_area_x_size]
|
||||||
|
mcall 13,,<0,20>,0xffffff
|
||||||
; function 4 : write text to window
|
; function 4 : write text to window
|
||||||
xor ecx,ecx
|
xor ecx,ecx
|
||||||
mcall 4,<17,13>,,text,text_len
|
mcall 4,<17,8>,,text,text_len
|
||||||
|
|
||||||
|
mcall 13,<0,10>,<20,336>,0xffffff
|
||||||
|
|
||||||
|
mov ebx,[client_area_x_size]
|
||||||
|
sub ebx,10+100+395
|
||||||
|
add ebx,(10+100+395) shl 16
|
||||||
|
mcall
|
||||||
|
|
||||||
|
mcall 26,9
|
||||||
|
add eax,100
|
||||||
|
mov [time_counter],eax
|
||||||
|
|
||||||
|
mov [draw_window_flag],1
|
||||||
|
call show_process_info
|
||||||
|
mov [draw_window_flag],0
|
||||||
|
|
||||||
|
mov ebx,[client_area_x_size]
|
||||||
|
mov ecx,[client_area_y_size]
|
||||||
|
sub ecx,20+336
|
||||||
|
add ecx,(20+336) shl 16
|
||||||
|
mcall 13,,,0xffffff
|
||||||
|
|
||||||
push dword edit1
|
push dword edit1
|
||||||
call [edit_box_draw]
|
call [edit_box_draw]
|
||||||
@ -438,13 +524,8 @@ draw_window:
|
|||||||
push dword check1
|
push dword check1
|
||||||
call [check_box_draw]
|
call [check_box_draw]
|
||||||
|
|
||||||
mcall 26,9
|
|
||||||
add eax,100
|
|
||||||
mov [time_counter],eax
|
|
||||||
|
|
||||||
call show_process_info
|
|
||||||
; previous page button
|
; previous page button
|
||||||
mcall 8,<25,96>,<358,10>,51,0xaabbcc
|
mcall 8,<25,96>,<361,14>,51,0xccddee ;0xaabbcc
|
||||||
; next page button 52
|
; next page button 52
|
||||||
inc edx
|
inc edx
|
||||||
mcall ,<125,96>
|
mcall ,<125,96>
|
||||||
@ -452,7 +533,7 @@ draw_window:
|
|||||||
add ecx,20 shl 16
|
add ecx,20 shl 16
|
||||||
; run button 53
|
; run button 53
|
||||||
inc edx
|
inc edx
|
||||||
mcall ,<451,50>
|
mcall ,<456,50>
|
||||||
; reboot button
|
; reboot button
|
||||||
sub ebx,120*65536
|
sub ebx,120*65536
|
||||||
add ebx,60
|
add ebx,60
|
||||||
@ -461,9 +542,9 @@ draw_window:
|
|||||||
mcall
|
mcall
|
||||||
;"PREV PAGE", "NEXT PAGE" and "REBOOT" labels
|
;"PREV PAGE", "NEXT PAGE" and "REBOOT" labels
|
||||||
xor ecx,ecx
|
xor ecx,ecx
|
||||||
mcall 4,<45,360>,,tbts,tbte-tbts
|
mcall 4,<45,365>,,tbts,tbte-tbts
|
||||||
;"RUN" labels
|
;"RUN" labels
|
||||||
mcall ,<464,380>,,tbts_3,tbte_2-tbts_3
|
mcall ,<464,385>,,tbts_3,tbte_2-tbts_3
|
||||||
;print application name in text box
|
;print application name in text box
|
||||||
mcall 12, 2
|
mcall 12, 2
|
||||||
ret
|
ret
|
||||||
@ -473,13 +554,13 @@ show_process_info:
|
|||||||
mov edi,[list_start]
|
mov edi,[list_start]
|
||||||
mov [list_add],edi
|
mov [list_add],edi
|
||||||
mov dword [index],0
|
mov dword [index],0
|
||||||
mov dword [curposy],32
|
mov dword [curposy],20
|
||||||
;--------------------------------------
|
;--------------------------------------
|
||||||
align 4
|
align 4
|
||||||
.loop_draw:
|
.loop_draw:
|
||||||
call draw_next_process
|
call draw_next_process
|
||||||
inc dword [index]
|
inc dword [index]
|
||||||
add dword [curposy],10
|
add dword [curposy],14
|
||||||
cmp [index],display_processes
|
cmp [index],display_processes
|
||||||
jl .loop_draw
|
jl .loop_draw
|
||||||
ret
|
ret
|
||||||
@ -527,9 +608,9 @@ aCheck_box_mouse db 'check_box_mouse',0
|
|||||||
;aVersion_op db 'version_op',0
|
;aVersion_op db 'version_op',0
|
||||||
;------------------------------------------------------------------------------
|
;------------------------------------------------------------------------------
|
||||||
align 4
|
align 4
|
||||||
check1 check_box 10,378,6,11,0x80AABBCC,0,0,check_text,check_t_e,0;ch_flag_en
|
check1 check_box 10,383,6,11,0x80AABBCC,0,0,check_text,check_t_e,0;ch_flag_en
|
||||||
check1_end:
|
check1_end:
|
||||||
edit1 edit_box 350,95,376,0xffffff,0x6f9480,0,0xAABBCC,0,start_application_c,\
|
edit1 edit_box 350,95,381,0xffffff,0x6f9480,0,0xAABBCC,0,start_application_c,\
|
||||||
start_application,mouse_dd,ed_focus,start_application_e,start_application_e
|
start_application,mouse_dd,ed_focus,start_application_e,start_application_e
|
||||||
edit1_end:
|
edit1_end:
|
||||||
list_start dd 0
|
list_start dd 0
|
||||||
@ -628,6 +709,12 @@ curposy rd 1
|
|||||||
index rd 1
|
index rd 1
|
||||||
tasklist rd display_processes
|
tasklist rd display_processes
|
||||||
time_counter rd 1
|
time_counter rd 1
|
||||||
|
|
||||||
|
client_area_x_size rd 1
|
||||||
|
client_area_y_size rd 1
|
||||||
|
bar_bacground_color rd 1
|
||||||
|
btn_bacground_color rd 1
|
||||||
|
draw_window_flag rd 1
|
||||||
;------------------------------------------------------------------------------
|
;------------------------------------------------------------------------------
|
||||||
align 4
|
align 4
|
||||||
library_path:
|
library_path:
|
||||||
|
Loading…
Reference in New Issue
Block a user