Docky v0.5.4 - "Full Size Mode"; DeskCFG - Docky page ready

git-svn-id: svn://kolibrios.org@4234 a494cfbc-eb01-0410-851d-a64ba20cac60
This commit is contained in:
eAndrew 2013-11-15 17:54:11 +00:00
parent b8f49a3e81
commit 6c4c4aeaac
5 changed files with 157 additions and 16 deletions

View File

@ -1,5 +1,6 @@
[@] [@]
location=2 location=2
fsize=0
[Eolite] [Eolite]
path=file managers/eolite path=file managers/eolite
@ -70,6 +71,6 @@ icon=28
$=1 $=1
[Settings] [Settings]
path=dockycfg path=deskcfg
param= param=
icon=35 icon=35

View File

@ -5,11 +5,25 @@
dd 1, @code, @data, @mem, @stack, 0, 0 dd 1, @code, @data, @mem, @stack, 0, 0
;------------------------------------------------------------------------------- ;-------------------------------------------------------------------------------
include "../../macros.inc" include "../../macros.inc"
include "../../proc32.inc"
include "../../dll.inc"
;include "../../debug.inc"
;=============================================================================== ;===============================================================================
@code: @code:
mcall 9, buffer, -1
mov ecx, [buffer + 30]
mcall 18, 21
mov [win.sid], eax
;-------------------------------------------------------------------------------
mcall 68, 11
stdcall dll.Load, @import
;-------------------------------------------------------------------------------
mov [tabs.index], byte 2 mov [tabs.index], byte 2
;-------------------------------------------------------------------------------
mcall 48, 3, color, 40 mcall 48, 3, color, 40
;-------------------------------------------------------------------------------
invoke ini.iget, ini.docky, ini.docky.sect.cfg, ini.docky.keys.fsize, 0
mov [docky.fsize], al
;------------------------------------------------------------------------------- ;-------------------------------------------------------------------------------
main_loop: main_loop:
mcall 10 mcall 10
@ -40,8 +54,22 @@ event_button:
cmp ah, 0x13 cmp ah, 0x13
je .tabs.panel je .tabs.panel
cmp ah, 0x40
je .docky.button_top
cmp ah, 0x41
je .docky.button_left
cmp ah, 0x42
je .docky.button_bottom
cmp ah, 0x43
je .docky.button_right
cmp ah, 0x44 cmp ah, 0x44
je .checkbox_fsize je .docky.checkbox_fsize
cmp ah, 0x45
je .docky.kill
cmp ah, 0x46
je .docky.start
jmp main_loop jmp main_loop
@ -62,13 +90,44 @@ event_button:
call win.draw call win.draw
jmp main_loop jmp main_loop
.checkbox_fsize: .docky.button_top:
invoke ini.iset, ini.docky, ini.docky.sect.cfg, ini.docky.keys.location, 1
call docky.apply
jmp main_loop
.docky.button_left:
invoke ini.iset, ini.docky, ini.docky.sect.cfg, ini.docky.keys.location, 2
call docky.apply
jmp main_loop
.docky.button_bottom:
invoke ini.iset, ini.docky, ini.docky.sect.cfg, ini.docky.keys.location, 3
call docky.apply
jmp main_loop
.docky.button_right:
invoke ini.iset, ini.docky, ini.docky.sect.cfg, ini.docky.keys.location, 4
call docky.apply
jmp main_loop
.docky.checkbox_fsize:
mov al, 1 mov al, 1
sub al, byte [win.docky.fsize] sub al, byte [docky.fsize]
mov [win.docky.fsize], al mov [docky.fsize], al
push 183 push 183
push win.docky.fsize push docky.fsize
call checkbox.draw call checkbox.draw
xor eax, eax
mov al, [docky.fsize]
invoke ini.iset, ini.docky, ini.docky.sect.cfg, ini.docky.keys.fsize, eax
call docky.apply
jmp main_loop
.docky.kill:
call docky.kill
jmp main_loop
.docky.start:
call docky.kill
call docky.start
jmp main_loop jmp main_loop
;------------------------------------------------------------------------------- ;-------------------------------------------------------------------------------
win.draw: win.draw:
@ -173,8 +232,8 @@ tabs.docky.draw:
mcall 8, < 81, 84>, < 64, 24>, 0x40, [color.workE] mcall 8, < 81, 84>, < 64, 24>, 0x40, [color.workE]
mcall , < 58, 64>, < 91, 24>, 0x41 mcall , < 58, 64>, < 91, 24>, 0x41
mcall , <125, 64>, < 91, 24>, 0x42 mcall , < 81, 84>, <118, 24>, 0x42
mcall , < 81, 84>, <118, 24>, 0x43 mcall , <125, 64>, < 91, 24>, 0x43
mov ecx, [color.textE] mov ecx, [color.textE]
or ecx, 0x80000000 or ecx, 0x80000000
@ -199,20 +258,20 @@ tabs.docky.draw:
mcall 4, <20, 187>, , tabs.docky.checkbox_fsize_title mcall 4, <20, 187>, , tabs.docky.checkbox_fsize_title
push 183 push 183
push win.docky.fsize push docky.fsize
call checkbox.draw call checkbox.draw
; == FRAME: THEARD == ; ; == FRAME: THEARD == ;
mcall 13, <10, 226>, <220, 44>, [color.workE] mcall 13, <10, 226>, <219, 44>, [color.workE]
mcall , <11, 224>, <221, 42>, [color.textE] mcall , <11, 224>, <220, 42>, [color.textE]
mcall , <12, 222>, <222, 40>, [color.work] mcall , <12, 222>, <221, 40>, [color.work]
mov ecx, [color.text] mov ecx, [color.text]
or ecx, 0xC0000000 or ecx, 0xC0000000
mcall 4, <20, 217>, , tabs.docky.frame_theard_title, , [color.work] mcall 4, <20, 217>, , tabs.docky.frame_theard_title, , [color.work]
mcall 8, < 20, 98>, <230, 24>, 0x45, [color.workE] mcall 8, < 20, 98>, <231, 20>, 0x45, [color.workE]
mcall 8, <128, 98>, , 0x46 mcall , <128, 98>, , 0x46
mov ecx, [color.textE] mov ecx, [color.textE]
or ecx, 0x80000000 or ecx, 0x80000000
@ -258,7 +317,62 @@ checkbox.draw:
add edi, 3 add edi, 3
mcall 4, <189, edi>, [color.text], checkbox.off, 5 mcall 4, <189, edi>, [color.text], checkbox.off, 5
ret ret
;-------------------------------------------------------------------------------
docky.kill:
mov dl, 0
mcall 9, buffer, -1
mov ecx, eax
.search:
mcall 9, buffer
cmp [buffer + 10], dword "@doc"
je .kill
cmp [buffer + 10], dword "@DOC"
jne .continue
.kill:
mov dl, 1
mcall 18, 2
.continue:
dec ecx
cmp ecx, 0
jne .search
ret
;-------------------------------------------------------------------------------
docky.start:
mov [buffer + 0], dword 7
mov [buffer + 4], dword 0
mov [buffer + 8], dword 0
mov [buffer + 20], dword "@doc"
mov [buffer + 24], word "ky"
mov [buffer + 26], byte 0
mcall 70, buffer
mcall 5, 5
mcall 18, 3, [win.sid]
ret
;-------------------------------------------------------------------------------
docky.apply:
call docky.kill
cmp dl, byte 0
je .end
call docky.start
.end:
ret
;=============================================================================== ;===============================================================================
@import:
library ini, "libini.obj"
import ini, ini.iget, "ini_get_int", ini.iset, "ini_set_int"
;===============================================================================
ini.docky:
db "settings/docky.ini", 0
.sect.cfg:
db "@", 0
.keys.fsize:
db "fsize", 0
.keys.location:
db "location", 0
win.title: win.title:
db "Desktop configuration", 0 db "Desktop configuration", 0
@ -305,7 +419,10 @@ checkbox.off:
rb 2048 rb 2048
@stack: @stack:
;------------------------------------------------------------------------------- ;-------------------------------------------------------------------------------
win.docky.fsize: win.sid:
rd 1
docky.fsize:
rb 1 rb 1
tabs.index: tabs.index:
@ -323,4 +440,7 @@ color:
.text: .text:
rd 2 rd 2
buffer:
rb 1024
@mem: @mem:

View File

@ -19,6 +19,8 @@ ini_data:
db "@", 0 db "@", 0
.location_name: .location_name:
db "location", 0 db "location", 0
.fsize_name:
db "fsize", 0
;------------------------------------------------------------------------------- ;-------------------------------------------------------------------------------
load_lib_start: load_lib_start:
lib1 l_libs img.name, \ lib1 l_libs img.name, \

View File

@ -133,6 +133,8 @@ dock_items:
rb 1 * 20 rb 1 * 20
.location: .location:
rd 1 rd 1
.fsize:
rb 1
;------------------------------------------------------------------------------- ;-------------------------------------------------------------------------------
buf_128: buf_128:
rb 128 rb 128

View File

@ -32,6 +32,8 @@ main:
; ==== Config LibINI ==== ; ==== Config LibINI ====
invoke ini.get_int, ini_data.file_name, ini_data.settings_name, ini_data.location_name, 1 invoke ini.get_int, ini_data.file_name, ini_data.settings_name, ini_data.location_name, 1
mov [dock_items.location], eax mov [dock_items.location], eax
invoke ini.get_int, ini_data.file_name, ini_data.settings_name, ini_data.fsize_name, 0
mov [dock_items.fsize], eax
invoke ini.sections, ini_data.file_name, sections_callback invoke ini.sections, ini_data.file_name, sections_callback
@ -140,11 +142,18 @@ main:
;------------------------------------------------------------------------------- ;-------------------------------------------------------------------------------
.HORZ_WIDTH: .HORZ_WIDTH:
cmp [dock_items.fsize], byte 1
je @f
mov eax, BUTTON_SIZE mov eax, BUTTON_SIZE
mov ebx, [dock_items.count] mov ebx, [dock_items.count]
imul eax, ebx imul eax, ebx
add eax, 24 add eax, 24
dec eax dec eax
jmp .set_hw
@@:
mcall 14
shr eax, 16
.set_hw:
mov [win.width_opn], eax mov [win.width_opn], eax
mov [win.width_hdn], eax mov [win.width_hdn], eax
@ -212,10 +221,17 @@ main:
;------------------------------------------------------------------------------- ;-------------------------------------------------------------------------------
.VERT_HEIGHT: .VERT_HEIGHT:
cmp [dock_items.fsize], byte 1
je @f
mov eax, BUTTON_SIZE mov eax, BUTTON_SIZE
mov ebx, [dock_items.count] mov ebx, [dock_items.count]
imul eax, ebx imul eax, ebx
dec eax dec eax
jmp .set_vh
@@:
mcall 14
and eax, 0xFFFF
.set_vh:
mov [win.height_opn], eax mov [win.height_opn], eax
mov [win.height_hdn], eax mov [win.height_hdn], eax