diff --git a/skins/_old/Leency/Shkvorka/DEFAULT.DTP b/skins/_old/Leency/Shkvorka/DEFAULT.DTP new file mode 100644 index 0000000000..b73d804cf8 Binary files /dev/null and b/skins/_old/Leency/Shkvorka/DEFAULT.DTP differ diff --git a/skins/_old/Leency/Shkvorka/Tupfile.lua b/skins/_old/Leency/Shkvorka/Tupfile.lua new file mode 100644 index 0000000000..2da4aebce1 --- /dev/null +++ b/skins/_old/Leency/Shkvorka/Tupfile.lua @@ -0,0 +1,2 @@ +if tup.getconfig("NO_FASM") ~= "" then return end +tup.rule("default.asm", 'fasm "%f" "%o" ' .. tup.getconfig("KPACK_CMD"), "Shkvorka.skn") diff --git a/skins/_old/Leency/Shkvorka/build.bat b/skins/_old/Leency/Shkvorka/build.bat new file mode 100644 index 0000000000..2131bf7f71 --- /dev/null +++ b/skins/_old/Leency/Shkvorka/build.bat @@ -0,0 +1,3 @@ +fasm default.asm default.skn +kpack default.skn +pause \ No newline at end of file diff --git a/skins/_old/Leency/Shkvorka/center1.bmp b/skins/_old/Leency/Shkvorka/center1.bmp new file mode 100644 index 0000000000..137aa32e4d Binary files /dev/null and b/skins/_old/Leency/Shkvorka/center1.bmp differ diff --git a/skins/_old/Leency/Shkvorka/center2.bmp b/skins/_old/Leency/Shkvorka/center2.bmp new file mode 100644 index 0000000000..cd3ac04af5 Binary files /dev/null and b/skins/_old/Leency/Shkvorka/center2.bmp differ diff --git a/skins/_old/Leency/Shkvorka/default.asm b/skins/_old/Leency/Shkvorka/default.asm new file mode 100644 index 0000000000..6cd77089f9 --- /dev/null +++ b/skins/_old/Leency/Shkvorka/default.asm @@ -0,0 +1,31 @@ +include 'me_skin.inc' + +SKIN_PARAMS \ + height = bmp_center1.height,\ ; skin height + margins = [5:1:43:1],\ ; margins [left:top:right:bottom] + colors active = [binner=0xE1E1E1:\ ; border inner color + bouter=0x646464:\ ; border outer color + bframe=0xE1E1E1],\ ; border frame color + colors inactive = [binner=0xE1E1E1:\ ; border inner color + bouter=0x747474:\ ; border outer color + bframe=0xE1E1E1],\ ; border frame color + dtp = 'default.dtp' ; dtp colors + +SKIN_BUTTONS \ + close = [-31:1][27:17],\ ; buttons coordinates + minimize = [-58:1][27:17] ; [left:top][width:height] + +SKIN_BITMAPS \ + left active = bmp_left1,\ ; skin bitmaps pointers + left inactive = bmp_left2,\ + oper active = bmp_right1,\ + oper inactive = bmp_right2,\ + base active = bmp_center1,\ + base inactive = bmp_center2 + +BITMAP bmp_left1, 'left1.bmp' ; skin bitmaps +BITMAP bmp_left2, 'left2.bmp' +BITMAP bmp_right1, 'right1.bmp' +BITMAP bmp_right2, 'right2.bmp' +BITMAP bmp_center1,'center1.bmp' +BITMAP bmp_center2,'center2.bmp' diff --git a/skins/_old/Leency/Shkvorka/default.dtp.asm b/skins/_old/Leency/Shkvorka/default.dtp.asm new file mode 100644 index 0000000000..9a40dedaa5 --- /dev/null +++ b/skins/_old/Leency/Shkvorka/default.dtp.asm @@ -0,0 +1,14 @@ +struc system_colors + { + .frame dd 0x646464 + .grab dd 0x000000 + .grab_button dd 0x000000 + .grab_button_text dd 0x000000 + .grab_text dd 0x000000 + .work dd 0xE1E1E1 + .work_button dd 0x7D7D8A + .work_button_text dd 0xFFFFFF + .work_text dd 0x000000 + .work_graph dd 0x6B677A + } +struct system_colors \ No newline at end of file diff --git a/skins/_old/Leency/Shkvorka/left1.bmp b/skins/_old/Leency/Shkvorka/left1.bmp new file mode 100644 index 0000000000..9f9f1bf47f Binary files /dev/null and b/skins/_old/Leency/Shkvorka/left1.bmp differ diff --git a/skins/_old/Leency/Shkvorka/left2.bmp b/skins/_old/Leency/Shkvorka/left2.bmp new file mode 100644 index 0000000000..646d3752e2 Binary files /dev/null and b/skins/_old/Leency/Shkvorka/left2.bmp differ diff --git a/skins/_old/Leency/Shkvorka/me_skin.inc b/skins/_old/Leency/Shkvorka/me_skin.inc new file mode 100644 index 0000000000..ccbb3c191c --- /dev/null +++ b/skins/_old/Leency/Shkvorka/me_skin.inc @@ -0,0 +1,235 @@ +;============================================================================ +; This file should be used to generate skins of new standard +;============================================================================ +; skin file structure: +;---------------------------------------------------------------------------- +; header: +; dd 'SKIN' +; dd = version (1 for now) +; dd @ params +; dd @ buttons +; dd @ bitmaps +; ... +;---------------------------------------------------------------------------- +; NOTE: order of sections listed below is insignificant +; since they're identified by pointer in above header +;---------------------------------------------------------------------------- +; ... +; params: +; dd = skin height +; dw = right margin +; dw = left margin +; dw = bottom margin +; dw = top margin +; dd = inner line color +; dd = outer line color +; dd = frame color +; dd = dtp file size +; ?? = dtp file itself +; ... +;---------------------------------------------------------------------------- +; ... +; buttons: +; dd = button type (1 = close, 2 = minimize) +; dw = left button coord (could be negative) +; dw = top button coord (could be negative) +; dw = button width +; dw = button height +; ... etc for all buttons +; dd = 0 (end of buttons list) +; ... +;---------------------------------------------------------------------------- +; ... +; bitmaps: +; dw = bitmap kind (1 = left, 2 = oper, 3 = base) +; dw = bitmap type (1 = active, 0 = inactive) +; dd @ bitmap +; ... etc for all bitmaps +; dd 0 (end of bitmaps list) +; ... +;---------------------------------------------------------------------------- +; ... +; bitmap: +; dd = bitmap width +; dd = bitmap height +; ?? = raw bitmap data +; ... etc for all bitmaps +; ... +;============================================================================ + +dd 'SKIN',1,__params__,__buttons__,__bitmaps__ + +struc BITMAPFILEHEADER { + .bfType dw ? ; WORD + .bfSize dd ? ; DWORD + .bfReserved1 dw ? ; WORD + .bfReserved2 dw ? ; WORD + .bfOffBits dd ? ; DWORD +} + +struc BITMAPINFOHEADER { + .biSize dd ? ; DWORD + .biWidth dd ? ; LONG + .biHeight dd ? ; LONG + .biPlanes dw ? ; WORD + .biBitCount dw ? ; WORD + .biCompression dd ? ; DWORD + .biSizeImage dd ? ; DWORD + .biXPelsPerMeter dd ? ; LONG + .biYPelsPerMeter dd ? ; LONG + .biClrUsed dd ? ; DWORD + .biClrImportant dd ? ; DWORD +} + +struc _bmp { + .h BITMAPFILEHEADER + .i BITMAPINFOHEADER +} +virtual at 0 + _bmp _bmp +end virtual + +macro BITMAP _name*,_fname* +{ + local w,h,a,r,g,b + virtual at 0 + file _fname + load w dword from _bmp.i.biWidth + load h dword from _bmp.i.biHeight + end virtual + align 4 + label _name + .width = w + .height = h + dd w,h + a=54+(w*3+(w mod 4))*(h-1) + size = $ + repeat h + repeat w + virtual at 0 + file _fname + load r from a+0 + load g from a+1 + load b from a+2 + end virtual + db r,g,b + a=a+3 + end repeat + a=a-w*3*2-(w mod 4) + end repeat +} + +macro define_colors name,[col,val] +{ + common + local a,b,c + forward + match =binner,col \{ a = val \} + match =bouter,col \{ b = val \} + match =bframe,col \{ c = val \} + common + name equ a,b,c +} + +macro SKIN_PARAMS [a] +{ + common + local _height,_margins,_colors,_colors_1,_dtp,_dtp_sz + __params__: + forward + match qq == ww,a + \{ + match =height,qq \\{ _height = ww \\} + match =margins,qq \\{ + match [q1:q2:q3:q4],ww + \\\{ + _margins equ q3,q1,q4,q2 + \\\} + \\} + match =colors =active,qq + \\{ + match [q10==q11:q20==q21:q30==q31],ww + \\\{ + define_colors _colors,q10,q11,q20,q21,q30,q31 + \\\} + \\} + match =colors =inactive,qq + \\{ + match [q10==q11:q20==q21:q30==q31],ww + \\\{ + define_colors _colors_1,q10,q11,q20,q21,q30,q31 + \\\} + \\} + match =dtp,qq \\{ _dtp equ ww \\} + \} + common + dd _height + dw _margins + dd _colors,_colors_1 + virtual at 0 + file _dtp + _dtp_sz = $ + end virtual + dd _dtp_sz + file _dtp +} + +macro SKIN_BUTTONS [a] +{ + common + local btn + __buttons__: + forward + match qq == ww,a + \{ + btn = 0 + match =close,qq \\{ btn = 1 \\} + match =minimize,qq \\{ btn = 2 \\} + match [q1:q2][q3:q4],ww + \\{ + if btn <> 0 + dd btn + dw q1,q2,q3,q4 + end if + \\} + \} + common + dd 0 +} + +macro SKIN_BITMAPS [a] +{ + common + local bmp + __bitmaps__: + forward + match qq == ww,a + \{ + bmp=-1 + match qqq =active,qq \\{ bmp = 1 \\} + match qqq =inactive,qq \\{ bmp = 0 \\} + match =left qqq,qq + \\{ + if bmp >= 0 + dw 1,bmp + dd ww + end if + \\} + match =oper qqq,qq + \\{ + if bmp >= 0 + dw 2,bmp + dd ww + end if + \\} + match =base qqq,qq + \\{ + if bmp >= 0 + dw 3,bmp + dd ww + end if + \\} + \} + common + dd 0 +} \ No newline at end of file diff --git a/skins/_old/Leency/Shkvorka/right1.bmp b/skins/_old/Leency/Shkvorka/right1.bmp new file mode 100644 index 0000000000..0348384d7c Binary files /dev/null and b/skins/_old/Leency/Shkvorka/right1.bmp differ diff --git a/skins/_old/Leency/Shkvorka/right2.bmp b/skins/_old/Leency/Shkvorka/right2.bmp new file mode 100644 index 0000000000..6b659e738b Binary files /dev/null and b/skins/_old/Leency/Shkvorka/right2.bmp differ diff --git a/skins/skinlist.lua b/skins/skinlist.lua index ea47b99740..89a874da51 100644 --- a/skins/skinlist.lua +++ b/skins/skinlist.lua @@ -77,6 +77,7 @@ skinlist = { "_old/Leency/Octo_flat/Octo_flat.skn", "_old/Leency/OpusN/OpusN.skn", "_old/Leency/Sandwich/Sandwich.skn", +"_old/Leency/Shkvorka/Shkvorka.skn", "_old/Leency/Yeah/Yeah.skn", "_old/lightskin/lightskin.skn", "_old/macos_l/macos_l.skn",