forked from KolibriOS/kolibrios
add new function 'buf2d_filter_dither' from Heavyiron and diamond
git-svn-id: svn://kolibrios.org@3105 a494cfbc-eb01-0410-851d-a64ba20cac60
This commit is contained in:
parent
094c2e3213
commit
f12d8abc6a
@ -63,6 +63,7 @@ table { font-size: 15px; }
|
||||
<li><a href="#f_b_wdiv2">buf2d_img_wdiv2</a></li>
|
||||
<li><a href="#f_c_color">buf2d_crop_color</a></li>
|
||||
<li><a href="#f_flip_v">buf2d_flip_v</a></li>
|
||||
<li><a href="#f_filter_d">buf2d_filter_dither</a></li>
|
||||
|
||||
<li><a href="#f_v_brush_c">buf2d_vox_brush_create</a></li>
|
||||
</ul>
|
||||
@ -260,6 +261,12 @@ stdcall [buf2d_convert_text_matrix], buf_1</pre>
|
||||
<pre>stdcall buf2d_flip_v, buf_0</pre>
|
||||
<p>ăäĺ buf_0 - ńňđóęňóđŕ 24-ő áčňíîăî áóôĺđŕ.</p>
|
||||
|
||||
<h4><a name="f_filter_d">buf2d_filter_dither</a></h4>
|
||||
<p>Ôèëüòð, êîòîðûé ïðåîáðàçóåò èçîáðàæåíèå èç 24 áèòíîãî áóôåðà â 8-ìè öâåòíîå. Ðàçðÿäíîñòü áóôåðà íå ìåíÿåòñÿ. Ïðèìåð:</p>
|
||||
<pre>stdcall [buf2d_filter_dither], buf_0, 0</pre>
|
||||
<p>ãäå buf_0 - ñòðóêòóðà 24-õ áèòíîãî áóôåðà.</p>
|
||||
<p>0 - àëãîðèòì (âîçìîæíûå çíà÷åíèÿ: 0 - Sierra Lite, 1 - Floyd-Steinberg, 2 - Burkers).</p>
|
||||
|
||||
<h4><a name="f_v_brush_c">buf2d_vox_brush_create</a></h4>
|
||||
<p>Ńîçäŕíčĺ âîęńĺëüíîé ęčńňč. Ďđčěĺđ:</p>
|
||||
<pre>stdcall [buf2d_vox_brush_create], buf_vox, vox_6_7_z
|
||||
@ -353,6 +360,7 @@ import_buf2d_lib:
|
||||
buf2d_set_pixel dd sz_buf2d_set_pixel
|
||||
buf2d_get_pixel dd sz_buf2d_get_pixel
|
||||
buf2d_flip_v dd sz_buf2d_flip_v
|
||||
buf2d_filter_dither dd sz_buf2d_filter_dither
|
||||
|
||||
;âîęńĺëüíűĺ ôóíęöčč:
|
||||
buf2d_vox_brush_create dd sz_buf2d_vox_brush_create
|
||||
@ -396,6 +404,7 @@ import_buf2d_lib:
|
||||
sz_buf2d_set_pixel db 'buf2d_set_pixel',0
|
||||
sz_buf2d_get_pixel db 'buf2d_get_pixel',0
|
||||
sz_buf2d_flip_v db 'buf2d_flip_v',0
|
||||
sz_buf2d_filter_dither db 'buf2d_filter_dither',0
|
||||
|
||||
;âîęńĺëüíűĺ ôóíęöčč:
|
||||
sz_buf2d_vox_brush_create db 'buf2d_vox_brush_create',0
|
||||
@ -434,5 +443,6 @@ import_buf2d_lib:
|
||||
<p>11.08.12 - ôóíęöčč äë˙ ńćŕňč˙ čçîáđŕćĺíčé buf2d_img_hdiv2 č buf2d_img_wdiv2 đŕáîňŕţň ń 32 áčňíűěč áóôĺđŕěč.</p>
|
||||
<p>01.10.12 - äîáŕâëĺíŕ ôóíęöč˙ ďîâîđîňŕ čçîáđŕćĺíčé íŕ 90 č 180 ăđŕäóńîâ buf2d_rotate.</p>
|
||||
<p>15.11.12 - äîáŕâëĺíŕ ôóíęöč˙ îňđŕćĺíč˙ 24 áčňíűő čçîáđŕćĺíčé ďî âĺđňčęŕëč buf_flip_v, čńďđŕâëĺíč˙ â ôóíęöčč buf2d_img_hdiv2.</p>
|
||||
<p>14.12.12 - äîáàâëåíà ôóíêöèÿ íàëîæåíèÿ ôèëüòðà buf2d_filter_dither.</p>
|
||||
</body>
|
||||
</html>
|
@ -3451,6 +3451,296 @@ proc buf_curve_bezier, buffer:dword, coord_p0:dword,coord_p1:dword,coord_p2:dwor
|
||||
ret
|
||||
endp
|
||||
|
||||
;䨫ìâ¥à
|
||||
align 4
|
||||
proc buf_filter_dither, buffer:dword, algor:dword
|
||||
pushad
|
||||
mov edi,[buffer]
|
||||
cmp buf2d_bits,24
|
||||
jne .error
|
||||
mov edx,buf2d_w
|
||||
mov esi,buf2d_h
|
||||
mov edi,buf2d_data
|
||||
;edi - pointer to 24bit bitmap
|
||||
;edx - x size
|
||||
;esi - y size
|
||||
lea edx,[edx*3]
|
||||
imul esi,edx
|
||||
|
||||
;®¯à¥¤¥«ï¥¬ ª ª®© «£®à¨â¬ ¨á¯®«ì§®¢ âì
|
||||
cmp dword[algor],0
|
||||
jne @f
|
||||
call dither_0
|
||||
jmp .dither_end
|
||||
@@:
|
||||
cmp dword[algor],1
|
||||
jne @f
|
||||
call dither_1
|
||||
jmp .dither_end
|
||||
@@:
|
||||
call dither_2
|
||||
jmp .dither_end
|
||||
.error:
|
||||
stdcall print_err,sz_buf2d_filter_dither,txt_err_n24b
|
||||
.dither_end:
|
||||
popad
|
||||
ret
|
||||
endp
|
||||
|
||||
align 16
|
||||
dither_0: ; Sierra Filter Lite algoritm
|
||||
newp_0: ; Dithering cycle
|
||||
xor ebx,ebx ; At first threshold
|
||||
movzx ecx,byte[edi]
|
||||
cmp cl,255
|
||||
je newp_0.next
|
||||
test cl,cl
|
||||
jz newp_0.next
|
||||
jns @f
|
||||
dec ebx
|
||||
sub ecx,255
|
||||
@@:
|
||||
mov [edi],bl ; putpixel
|
||||
|
||||
sar ecx,1 ; error/2
|
||||
;adc ecx,0 ; round to integer
|
||||
|
||||
movzx eax,byte[edi+3] ; pixel (x+1;y)
|
||||
add eax,ecx ; add error/2 to (x+1;y)
|
||||
jge @f ; check_overflow
|
||||
xor eax,eax
|
||||
jmp .ok
|
||||
@@:
|
||||
cmp eax,255
|
||||
jle .ok
|
||||
or al,255
|
||||
.ok:
|
||||
mov [edi+3],al ; putpixel
|
||||
|
||||
sar ecx,1 ; error/4
|
||||
adc ecx,0 ; round to integer
|
||||
|
||||
movzx eax,byte[edi+edx-3] ; pixel (x-1;y+1)
|
||||
add eax,ecx ; add error/4 to (x-1;y+1)
|
||||
jge @f ; check_overflow
|
||||
xor eax,eax
|
||||
jmp .ok1
|
||||
@@:
|
||||
cmp eax,255
|
||||
jle .ok1
|
||||
or al,255
|
||||
.ok1:
|
||||
mov [edi+edx-3],al ; putpixel
|
||||
|
||||
movzx eax,byte[edi+edx] ; pixel (x;y+1)
|
||||
add eax,ecx ; add error/4 to (x;y+1)
|
||||
jge @f ; check_overflow
|
||||
xor eax,eax
|
||||
jmp .ok2
|
||||
@@:
|
||||
cmp eax,255
|
||||
jle .ok2
|
||||
or al,255
|
||||
.ok2:
|
||||
mov [edi+edx],al ; putpixel
|
||||
|
||||
.next:
|
||||
inc edi
|
||||
dec esi
|
||||
jnz newp_0
|
||||
ret
|
||||
|
||||
align 16
|
||||
dither_1: ; Floyd-Steinberg algoritm
|
||||
newp_1: ; Dithering cycle
|
||||
xor ebx,ebx ; At first threshold
|
||||
movzx ecx,byte[edi]
|
||||
cmp cl,255
|
||||
je newp_1.next
|
||||
test cl,cl
|
||||
jz newp_1.next
|
||||
jns @f
|
||||
dec ebx
|
||||
sub ecx,255
|
||||
@@:
|
||||
mov [edi],bl ; putpixel
|
||||
|
||||
sar ecx,4 ; error/16
|
||||
adc ecx,0 ; round to integer
|
||||
mov ebx,ecx
|
||||
|
||||
movzx eax,byte[edi+edx+3] ; pixel (x+1;y+1)
|
||||
add eax,ecx ; add error/16 to (x+1;y+1)
|
||||
jge @f ; check_overflow
|
||||
xor eax,eax
|
||||
jmp .ok
|
||||
@@:
|
||||
cmp eax,255
|
||||
jle .ok
|
||||
or al,255
|
||||
.ok:
|
||||
mov [edi+edx+3],al ;putpixel
|
||||
|
||||
imul ecx,3
|
||||
movzx eax,byte[edi+edx-3] ; pixel (x-1;y+1)
|
||||
add eax,ecx ; add 3*error/16 to (x-1;y+1)
|
||||
jge @f ; check_overflow
|
||||
xor eax,eax
|
||||
jmp .ok1
|
||||
@@:
|
||||
cmp eax,255
|
||||
jle .ok1
|
||||
or al,255
|
||||
.ok1:
|
||||
mov [edi+edx-3],al ;putpixel
|
||||
|
||||
mov ecx,ebx
|
||||
imul ecx,5
|
||||
movzx eax,byte[edi+edx] ; pixel (x;y+1)
|
||||
add eax,ecx ; add 5*error/16 to (x;y+1)
|
||||
jge @f ; check_overflow
|
||||
xor eax,eax
|
||||
jmp .ok2
|
||||
@@:
|
||||
cmp eax,255
|
||||
jle .ok2
|
||||
or al,255
|
||||
.ok2:
|
||||
mov [edi+edx],al ;putpixel
|
||||
|
||||
mov ecx,ebx
|
||||
imul ecx,7
|
||||
movzx eax,byte[edi+3] ; pixel (x+1;y)
|
||||
add eax,ecx ; add 7*error/16 to (x+1;y)
|
||||
jge @f ; check_overflow
|
||||
xor eax,eax
|
||||
jmp .ok3
|
||||
@@:
|
||||
cmp eax,255
|
||||
jle .ok3
|
||||
or al,255
|
||||
.ok3:
|
||||
mov [edi+3],al ;putpixel
|
||||
|
||||
.next:
|
||||
inc edi
|
||||
dec esi
|
||||
jnz newp_1
|
||||
ret
|
||||
|
||||
align 16
|
||||
dither_2: ; Burkers algoritm
|
||||
newp_2: ; Dithering cycle
|
||||
xor ebx,ebx ; At first threshold
|
||||
movsx ecx,byte[edi]
|
||||
cmp cl,255
|
||||
je newp_2.next
|
||||
test cl,cl
|
||||
jz newp_2.next
|
||||
jns @f
|
||||
dec ebx
|
||||
@@:
|
||||
mov [edi],bl ; putpixel
|
||||
|
||||
sar ecx,2 ; error/4
|
||||
adc ecx,0 ; round to integer
|
||||
|
||||
movzx eax,byte[edi+3] ; pixel (x+1;y)
|
||||
add eax,ecx ; add error/4 to (x+1;y)
|
||||
jge @f ; check_overflow
|
||||
xor eax,eax
|
||||
jmp .ok
|
||||
@@:
|
||||
cmp eax,255
|
||||
jle .ok
|
||||
or al,255
|
||||
.ok:
|
||||
mov [edi+3],al ; putpixel
|
||||
|
||||
movzx eax,byte[edi+edx] ; pixel (x;y+1)
|
||||
add eax,ecx ; add error/4 to (x;y+1)
|
||||
jge @f ; check_overflow
|
||||
xor eax,eax
|
||||
jmp .ok1
|
||||
@@:
|
||||
cmp eax,255
|
||||
jle .ok1
|
||||
or al,255
|
||||
.ok1:
|
||||
mov [edi+edx],al ; putpixel
|
||||
|
||||
sar ecx,1 ; error/8
|
||||
adc ecx,0 ; round to integer
|
||||
|
||||
movzx eax,byte[edi+6] ; pixel (x+2;y)
|
||||
add eax,ecx ; add error/8 to (x+2;y)
|
||||
jge @f ; check_overflow
|
||||
xor eax,eax
|
||||
jmp .ok2
|
||||
@@:
|
||||
cmp eax,255
|
||||
jle .ok2
|
||||
or al,255
|
||||
.ok2:
|
||||
mov [edi+6],al ; putpixel
|
||||
|
||||
movzx eax,byte[edi+edx-3] ; pixel (x-1;y+1)
|
||||
add eax,ecx ; add error/8 to (x-1;y+1)
|
||||
jge @f ; check_overflow
|
||||
xor eax,eax
|
||||
jmp .ok3
|
||||
@@:
|
||||
cmp eax,255
|
||||
jle .ok3
|
||||
or al,255
|
||||
.ok3:
|
||||
mov [edi+edx-3],al ; putpixel
|
||||
|
||||
movzx eax,byte[edi+edx+3] ; pixel (x+1;y+1)
|
||||
add eax,ecx ; add error/8 to (x+1;y+1)
|
||||
jge @f ; check_overflow
|
||||
xor eax,eax
|
||||
jmp .ok4
|
||||
@@:
|
||||
cmp eax,255
|
||||
jle .ok4
|
||||
or al,255
|
||||
.ok4:
|
||||
mov [edi+edx+3],al ; putpixel
|
||||
|
||||
sar ecx,1 ; error/16
|
||||
;adc ecx,0 ; round to integer
|
||||
|
||||
movzx eax,byte[edi+edx-6] ; pixel (x-2;y+1)
|
||||
add eax,ecx ; add error/16 to (x-2;y+1)
|
||||
jge @f ; check_overflow
|
||||
xor eax,eax
|
||||
jmp .ok5
|
||||
@@:
|
||||
cmp eax,255
|
||||
jle .ok5
|
||||
or al,255
|
||||
.ok5:
|
||||
mov [edi+edx-6],al ; putpixel
|
||||
|
||||
movzx eax,byte[edi+edx+6] ; pixel (x+2;y+1)
|
||||
add eax,ecx ; add error/16 to (x+2;y+1)
|
||||
jge @f ; check_overflow
|
||||
xor eax,eax
|
||||
jmp .ok6
|
||||
@@:
|
||||
cmp eax,255
|
||||
jle .ok6
|
||||
or al,255
|
||||
.ok6:
|
||||
mov [edi+edx+6],al ; putpixel
|
||||
|
||||
.next:
|
||||
inc edi
|
||||
dec esi
|
||||
jnz newp_2
|
||||
ret
|
||||
|
||||
|
||||
|
||||
;*** äãªæ¨¨ ¤«ï à ¡®âë á ¢®ªá¥«ì®© £à 䨪®© ***
|
||||
@ -4816,6 +5106,7 @@ EXPORTS:
|
||||
dd sz_buf2d_set_pixel, buf_set_pixel
|
||||
dd sz_buf2d_get_pixel, buf_get_pixel
|
||||
dd sz_buf2d_flip_v, buf_flip_v
|
||||
dd sz_buf2d_filter_dither, buf_filter_dither
|
||||
dd sz_buf2d_vox_brush_create, vox_brush_create
|
||||
dd sz_buf2d_vox_brush_delete, vox_brush_delete
|
||||
dd sz_buf2d_vox_obj_get_img_w_3g, buf_vox_obj_get_img_w_3g
|
||||
@ -4856,6 +5147,7 @@ EXPORTS:
|
||||
sz_buf2d_set_pixel db 'buf2d_set_pixel',0
|
||||
sz_buf2d_get_pixel db 'buf2d_get_pixel',0
|
||||
sz_buf2d_flip_v db 'buf2d_flip_v',0
|
||||
sz_buf2d_filter_dither db 'buf2d_filter_dither',0
|
||||
sz_buf2d_vox_brush_create db 'buf2d_vox_brush_create',0
|
||||
sz_buf2d_vox_brush_delete db 'buf2d_vox_brush_delete',0
|
||||
sz_buf2d_vox_obj_get_img_w_3g db 'buf2d_vox_obj_get_img_w_3g',0
|
||||
|
@ -16,6 +16,7 @@ if not exist bin\vaz2106.vox @copy ..\..\..\..\..\media\voxel_editor\trunk\vaz21
|
||||
@fasm.exe -m 16384 e5_lines_sm.asm bin\e5_lines_sm.kex
|
||||
@fasm.exe -m 16384 e6_vox_1g.asm bin\e6_vox_1g.kex
|
||||
@fasm.exe -m 16384 e7_vox_3g.asm bin\e7_vox_3g.kex
|
||||
@fasm.exe -m 16384 e8_filters.asm bin\e8_filters.kex
|
||||
|
||||
@kpack bin\e0_dr_lines.kex
|
||||
@kpack bin\e1_scaling.kex
|
||||
@ -25,4 +26,5 @@ if not exist bin\vaz2106.vox @copy ..\..\..\..\..\media\voxel_editor\trunk\vaz21
|
||||
@kpack bin\e5_lines_sm.kex
|
||||
@kpack bin\e6_vox_1g.kex
|
||||
@kpack bin\e7_vox_3g.kex
|
||||
@kpack bin\e8_filters.kex
|
||||
pause
|
@ -10,7 +10,7 @@ use32
|
||||
include '../../../../../macros.inc'
|
||||
include '../../../../../proc32.inc'
|
||||
include '../../../../../develop/libraries/box_lib/load_lib.mac'
|
||||
include 'mem.inc'
|
||||
include '../../../../../dll.inc'
|
||||
|
||||
@use_library_mem mem.Alloc,mem.Free,mem.ReAlloc, 0 ;dll.Load
|
||||
|
||||
|
@ -10,7 +10,7 @@ use32
|
||||
include '../../../../../macros.inc'
|
||||
include '../../../../../proc32.inc'
|
||||
include '../../../../../develop/libraries/box_lib/load_lib.mac'
|
||||
include 'mem.inc'
|
||||
include '../../../../../dll.inc'
|
||||
|
||||
@use_library_mem mem.Alloc,mem.Free,mem.ReAlloc, 0 ;dll.Load
|
||||
|
||||
|
@ -10,7 +10,7 @@ use32
|
||||
include '../../../../../macros.inc'
|
||||
include '../../../../../proc32.inc'
|
||||
include '../../../../../develop/libraries/box_lib/load_lib.mac'
|
||||
include 'mem.inc'
|
||||
include '../../../../../dll.inc'
|
||||
|
||||
@use_library_mem mem.Alloc,mem.Free,mem.ReAlloc, 0 ;dll.Load
|
||||
|
||||
|
@ -10,7 +10,7 @@ use32
|
||||
include '../../../../../macros.inc'
|
||||
include '../../../../../proc32.inc'
|
||||
include '../../../../../develop/libraries/box_lib/load_lib.mac'
|
||||
include 'mem.inc'
|
||||
include '../../../../../dll.inc'
|
||||
|
||||
@use_library_mem mem.Alloc,mem.Free,mem.ReAlloc, 0 ;dll.Load
|
||||
|
||||
|
@ -10,7 +10,7 @@ use32
|
||||
include '../../../../../macros.inc'
|
||||
include '../../../../../proc32.inc'
|
||||
include '../../../../../develop/libraries/box_lib/load_lib.mac'
|
||||
include 'mem.inc'
|
||||
include '../../../../../dll.inc'
|
||||
|
||||
@use_library_mem mem.Alloc,mem.Free,mem.ReAlloc, 0 ;dll.Load
|
||||
|
||||
|
@ -10,7 +10,7 @@ use32
|
||||
include '../../../../../macros.inc'
|
||||
include '../../../../../proc32.inc'
|
||||
include '../../../../../develop/libraries/box_lib/load_lib.mac'
|
||||
include 'mem.inc'
|
||||
include '../../../../../dll.inc'
|
||||
|
||||
@use_library_mem mem.Alloc,mem.Free,mem.ReAlloc, 0 ;dll.Load
|
||||
|
||||
|
296
programs/develop/libraries/buf2d/trunk/examples/e8_filters.asm
Normal file
296
programs/develop/libraries/buf2d/trunk/examples/e8_filters.asm
Normal file
@ -0,0 +1,296 @@
|
||||
use32
|
||||
org 0x0
|
||||
db 'MENUET01' ;¨¤¥â¨ä. ¨á¯®«ï¥¬®£® ä ©« ¢á¥£¤ 8 ¡ ©â
|
||||
dd 0x1
|
||||
dd start
|
||||
dd i_end ;à §¬¥à ¯à¨«®¦¥¨ï
|
||||
dd mem,stacktop
|
||||
dd 0,sys_path
|
||||
|
||||
include '../../../../../macros.inc'
|
||||
include '../../../../../proc32.inc'
|
||||
include '../../../../../develop/libraries/box_lib/load_lib.mac'
|
||||
include '../../../../../dll.inc'
|
||||
|
||||
@use_library_mem mem.Alloc,mem.Free,mem.ReAlloc, dll.Load
|
||||
|
||||
struct FileInfoBlock
|
||||
Function dd ?
|
||||
Position dd ?
|
||||
Flags dd ?
|
||||
Count dd ?
|
||||
Buffer dd ?
|
||||
db ?
|
||||
FileName dd ?
|
||||
ends
|
||||
|
||||
IMAGE_FILE1_SIZE equ 200*186*3 ;à §¬¥à ä ©« á ¨§®¡à ¦¥¨¥¬ 200 x 100
|
||||
|
||||
BUF_STRUCT_SIZE equ 21
|
||||
buf2d_data equ dword[edi] ;¤ ë¥ ¡ãä¥à ¨§®¡à ¦¥¨ï
|
||||
buf2d_w equ dword[edi+8] ;è¨à¨ ¡ãä¥à
|
||||
buf2d_h equ dword[edi+12] ;¢ëá®â ¡ãä¥à
|
||||
buf2d_l equ word[edi+4]
|
||||
buf2d_t equ word[edi+6] ;®âáâ㯠ᢥàåã
|
||||
buf2d_size_lt equ dword[edi+4] ;®âáâ㯠᫥¢ ¨ á¯à ¢ ¤«ï ¡ãä¥à
|
||||
buf2d_color equ dword[edi+16] ;梥â ä® ¡ãä¥à
|
||||
buf2d_bits equ byte[edi+20] ;ª®«¨ç¥á⢮ ¡¨â ¢ 1-© â®çª¥ ¨§®¡à ¦¥¨ï
|
||||
vox_offs_tree_table equ 4
|
||||
|
||||
macro load_image_file path,buf,size { ;¬ ªà®á ¤«ï § £à㧪¨ ¨§®¡à ¦¥¨©
|
||||
;path - ¬®¦¥â ¡ëâì ¯¥à¥¬¥®© ¨«¨ áâப®¢ë¬ ¯ à ¬¥â஬
|
||||
if path eqtype '' ;¯à®¢¥à塞 § ¤ «¨ áâப®© ¯ à ¬¥âà path
|
||||
jmp @f
|
||||
local .path_str
|
||||
.path_str db path ;ä®à¬¨à㥬 «®ª «ìãî ¯¥à¥¬¥ãî
|
||||
db 0
|
||||
@@:
|
||||
;32 - áâ ¤ àâë© ¤à¥á ¯® ª®â®à®¬ã ¤®«¦¥ ¡ëâì ¡ãä¥à á á¨áâ¥¬ë¬ ¯ã⥬
|
||||
copy_path .path_str,[32],file_name,0x0
|
||||
else
|
||||
copy_path path,[32],file_name,0x0 ;ä®à¬¨à㥬 ¯®«ë© ¯ãâì ª ä ©«ã ¨§®¡à ¦¥¨ï, ¯®¤à §ã¬¥¢ ¥¬ çâ® ® ¢ ®¤®© ¯ ¯ª¥ á ¯à®£à ¬¬®©
|
||||
end if
|
||||
|
||||
stdcall mem.Alloc, dword size ;¢ë¤¥«ï¥¬ ¯ ¬ïâì ¤«ï ¨§®¡à ¦¥¨ï
|
||||
mov [buf],eax
|
||||
|
||||
mov eax,70 ;70-ï äãªæ¨ï à ¡®â á ä ©« ¬¨
|
||||
mov [run_file_70.Function], 0
|
||||
mov [run_file_70.Position], 0
|
||||
mov [run_file_70.Flags], 0
|
||||
mov [run_file_70.Count], dword size
|
||||
m2m [run_file_70.Buffer], [buf]
|
||||
mov byte[run_file_70+20], 0
|
||||
mov [run_file_70.FileName], file_name
|
||||
mov ebx,run_file_70
|
||||
int 0x40 ;§ £à㦠¥¬ ä ©« ¨§®¡à ¦¥¨ï
|
||||
cmp ebx,0xffffffff
|
||||
je @f
|
||||
;®¯à¥¤¥«ï¥¬ ¢¨¤ ¨§®¡à ¦¥¨ï ¨ ¯¥à¥¢®¤¨¬ ¥£® ¢® ¢à¥¬¥ë© ¡ãä¥à image_data
|
||||
stdcall dword[img_decode], dword[buf],ebx,0
|
||||
mov dword[image_data],eax
|
||||
;¯à¥®¡à §ã¥¬ ¨§®¡à ¦¥¨¥ ª ä®à¬ âã rgb
|
||||
stdcall dword[img_to_rgb2], dword[image_data],dword[buf]
|
||||
;㤠«ï¥¬ ¢à¥¬¥ë© ¡ãä¥à image_data
|
||||
stdcall dword[img_destroy], dword[image_data]
|
||||
@@:
|
||||
}
|
||||
|
||||
align 4
|
||||
start:
|
||||
load_libraries l_libs_start,load_lib_end
|
||||
|
||||
;¯à®¢¥àª ᪮«ìª® ã¤ ç® § £ã§¨« áì è «¨¡
|
||||
mov ebp,lib0
|
||||
cmp dword [ebp+ll_struc_size-4],0
|
||||
jz @f
|
||||
mcall -1 ;exit not correct
|
||||
@@:
|
||||
mov ebp,lib1
|
||||
cmp dword [ebp+ll_struc_size-4],0
|
||||
jz @f
|
||||
mcall -1 ;exit not correct
|
||||
@@:
|
||||
|
||||
mcall 40,0x27
|
||||
mcall 48,3,sc,sizeof.system_colors ;¯®«ãç ¥¬ á¨áâ¥¬ë¥ æ¢¥â
|
||||
|
||||
load_image_file 'img1.png',image_data_rgb, IMAGE_FILE1_SIZE
|
||||
stdcall [buf2d_create_f_img], buf_0,[image_data_rgb] ;ᮧ¤ ¥¬ ¡ãä¥à
|
||||
stdcall [buf2d_create_f_img], buf_1,[image_data_rgb] ;ᮧ¤ ¥¬ ¡ãä¥à
|
||||
stdcall [buf2d_create_f_img], buf_2,[image_data_rgb] ;ᮧ¤ ¥¬ ¡ãä¥à
|
||||
stdcall mem.Free,[image_data_rgb] ;®á¢®¡®¦¤ ¥¬ ¯ ¬ïâì
|
||||
|
||||
stdcall [buf2d_filter_dither], buf_1,0
|
||||
stdcall [buf2d_filter_dither], buf_2,2
|
||||
|
||||
align 4
|
||||
red_win:
|
||||
call draw_window
|
||||
|
||||
align 4
|
||||
still: ;£« ¢ë© 横«
|
||||
mcall 10
|
||||
|
||||
cmp al,0x1 ;¨§¬¥¨«®áì ¯®«®¦¥¨¥ ®ª
|
||||
jz red_win
|
||||
cmp al,0x2
|
||||
jz key
|
||||
cmp al,0x3
|
||||
jz button
|
||||
|
||||
jmp still
|
||||
|
||||
align 4
|
||||
key:
|
||||
push eax ebx
|
||||
mcall 2
|
||||
;...
|
||||
pop ebx eax
|
||||
jmp still
|
||||
|
||||
|
||||
align 4
|
||||
draw_window:
|
||||
pushad
|
||||
mcall 12,1
|
||||
|
||||
mov edx,[sc.work]
|
||||
or edx,0x33000000
|
||||
mcall 0,(20 shl 16)+670,(20 shl 16)+520,,,caption ;ᮧ¤ ¨¥ ®ª
|
||||
|
||||
stdcall [buf2d_draw], buf_0
|
||||
stdcall [buf2d_draw], buf_1
|
||||
stdcall [buf2d_draw], buf_2
|
||||
|
||||
mcall 12,2
|
||||
popad
|
||||
ret
|
||||
|
||||
head_f_i:
|
||||
head_f_l db '‘¨á⥬ ï ®è¨¡ª ',0
|
||||
|
||||
system_dir0 db '/sys/lib/'
|
||||
name_buf2d db 'buf2d.obj',0
|
||||
err_message_found_lib0 db '<27>¥ 㤠«®áì ©â¨ ¡¨¡«¨®â¥ªã buf2d.obj',0
|
||||
err_message_import0 db 'Žè¨¡ª ¯à¨ ¨¬¯®à⥠¡¨¡«¨®â¥ª¨ buf2d.obj',0
|
||||
|
||||
system_dir1 db '/sys/lib/'
|
||||
name_libimg db 'libimg.obj',0
|
||||
err_message_found_lib1 db '<27>¥ 㤠«®áì ©â¨ ¡¨¡«¨®â¥ªã libimg.obj',0
|
||||
err_message_import1 db 'Žè¨¡ª ¯à¨ ¨¬¯®à⥠¡¨¡«¨®â¥ª¨ libimg.obj',0
|
||||
|
||||
;library structures
|
||||
l_libs_start:
|
||||
lib0 l_libs name_buf2d, sys_path, file_name, system_dir0, err_message_found_lib0, head_f_l, import_buf2d_lib, err_message_import0, head_f_i
|
||||
lib1 l_libs name_libimg, sys_path, file_name, system_dir1, err_message_found_lib1, head_f_l, import_libimg, err_message_import1, head_f_i
|
||||
load_lib_end:
|
||||
|
||||
align 4
|
||||
button:
|
||||
mcall 17 ;¯®«ãç¨âì ª®¤ ¦ ⮩ ª®¯ª¨
|
||||
cmp ah,1
|
||||
jne still
|
||||
.exit:
|
||||
stdcall [buf2d_delete],buf_0 ;㤠«ï¥¬ ¡ãä¥à
|
||||
stdcall [buf2d_delete],buf_1 ;㤠«ï¥¬ ¡ãä¥à
|
||||
stdcall [buf2d_delete],buf_2 ;㤠«ï¥¬ ¡ãä¥à
|
||||
mcall -1 ;¢ë室 ¨§ ¯à®£à ¬¬ë
|
||||
|
||||
image_data dd 0 ;¯ ¬ïâì ¤«ï ¯à¥®¡à §®¢ ¨ï ª à⨪¨ äãªæ¨ï¬¨ libimg
|
||||
image_data_gray dd 0 ;¯ ¬ïâì á ¯à¥®¡à §®¢ ë¬ ¨§®¡à ¦¥¨¥¬ ¢ ä®à¬ ⥠8-bit
|
||||
image_data_rgb dd 0 ;¯ ¬ïâì á ¯à¥®¡à §®¢ ë¬ ¨§®¡à ¦¥¨¥¬ ¢ ä®à¬ ⥠rgb
|
||||
image_data_foto dd 0
|
||||
|
||||
run_file_70 FileInfoBlock
|
||||
caption db 'Draw images 13.09.11',0 ;¯®¤¯¨áì ®ª
|
||||
sc system_colors ;á¨áâ¥¬ë¥ æ¢¥â
|
||||
|
||||
align 4
|
||||
buf_0:
|
||||
dd 0 ;㪠§ â¥«ì ¡ãä¥à ¨§®¡à ¦¥¨ï
|
||||
dw 5 ;+4 left
|
||||
dw 5 ;+6 top
|
||||
dd 200 ;+8 w
|
||||
dd 186 ;+12 h
|
||||
dd 0xffffff ;+16 color
|
||||
db 24 ;+20 bit in pixel
|
||||
|
||||
align 4
|
||||
buf_1:
|
||||
dd 0 ;㪠§ â¥«ì ¡ãä¥à ¨§®¡à ¦¥¨ï
|
||||
dw 5 ;+4 left
|
||||
dw 200 ;+6 top
|
||||
dd 200 ;+8 w
|
||||
dd 186 ;+12 h
|
||||
dd 0 ;+16 color
|
||||
db 24 ;+20 bit in pixel
|
||||
|
||||
align 4
|
||||
buf_2:
|
||||
dd 0 ;㪠§ â¥«ì ¡ãä¥à ¨§®¡à ¦¥¨ï
|
||||
dw 210 ;+4 left
|
||||
dw 200 ;+6 top
|
||||
dd 200 ;+8 w
|
||||
dd 186 ;+12 h
|
||||
dd 0 ;+16 color
|
||||
db 24 ;+20 bit in pixel
|
||||
|
||||
align 4
|
||||
import_libimg:
|
||||
dd alib_init1
|
||||
img_is_img dd aimg_is_img
|
||||
img_info dd aimg_info
|
||||
img_from_file dd aimg_from_file
|
||||
img_to_file dd aimg_to_file
|
||||
img_from_rgb dd aimg_from_rgb
|
||||
img_to_rgb dd aimg_to_rgb
|
||||
img_to_rgb2 dd aimg_to_rgb2
|
||||
img_decode dd aimg_decode
|
||||
img_encode dd aimg_encode
|
||||
img_create dd aimg_create
|
||||
img_destroy dd aimg_destroy
|
||||
img_destroy_layer dd aimg_destroy_layer
|
||||
img_count dd aimg_count
|
||||
img_lock_bits dd aimg_lock_bits
|
||||
img_unlock_bits dd aimg_unlock_bits
|
||||
img_flip dd aimg_flip
|
||||
img_flip_layer dd aimg_flip_layer
|
||||
img_rotate dd aimg_rotate
|
||||
img_rotate_layer dd aimg_rotate_layer
|
||||
img_draw dd aimg_draw
|
||||
|
||||
dd 0,0
|
||||
alib_init1 db 'lib_init',0
|
||||
aimg_is_img db 'img_is_img',0 ;®¯à¥¤¥«ï¥â ¯® ¤ ë¬, ¬®¦¥â «¨ ¡¨¡«¨®â¥ª ᤥ« âì ¨§ ¨å ¨§®¡à ¦¥¨¥
|
||||
aimg_info db 'img_info',0
|
||||
aimg_from_file db 'img_from_file',0
|
||||
aimg_to_file db 'img_to_file',0
|
||||
aimg_from_rgb db 'img_from_rgb',0
|
||||
aimg_to_rgb db 'img_to_rgb',0 ;¯à¥®¡à §®¢ ¨¥ ¨§®¡à ¦¥¨ï ¢ ¤ ë¥ RGB
|
||||
aimg_to_rgb2 db 'img_to_rgb2',0
|
||||
aimg_decode db 'img_decode',0 ; ¢â®¬ â¨ç¥áª¨ ®¯à¥¤¥«ï¥â ä®à¬ â £à ä¨ç¥áª¨å ¤ ëå
|
||||
aimg_encode db 'img_encode',0
|
||||
aimg_create db 'img_create',0
|
||||
aimg_destroy db 'img_destroy',0
|
||||
aimg_destroy_layer db 'img_destroy_layer',0
|
||||
aimg_count db 'img_count',0
|
||||
aimg_lock_bits db 'img_lock_bits',0
|
||||
aimg_unlock_bits db 'img_unlock_bits',0
|
||||
aimg_flip db 'img_flip',0
|
||||
aimg_flip_layer db 'img_flip_layer',0
|
||||
aimg_rotate db 'img_rotate',0
|
||||
aimg_rotate_layer db 'img_rotate_layer',0
|
||||
aimg_draw db 'img_draw',0
|
||||
|
||||
align 4
|
||||
import_buf2d_lib:
|
||||
dd sz_lib_init
|
||||
buf2d_create dd sz_buf2d_create
|
||||
buf2d_create_f_img dd sz_buf2d_create_f_img
|
||||
buf2d_clear dd sz_buf2d_clear
|
||||
buf2d_draw dd sz_buf2d_draw
|
||||
buf2d_delete dd sz_buf2d_delete
|
||||
buf2d_filter_dither dd sz_buf2d_filter_dither
|
||||
dd 0,0
|
||||
sz_lib_init db 'lib_init',0
|
||||
sz_buf2d_create db 'buf2d_create',0
|
||||
sz_buf2d_create_f_img db 'buf2d_create_f_img',0
|
||||
sz_buf2d_clear db 'buf2d_clear',0
|
||||
sz_buf2d_draw db 'buf2d_draw',0
|
||||
sz_buf2d_delete db 'buf2d_delete',0
|
||||
sz_buf2d_filter_dither db 'buf2d_filter_dither',0
|
||||
|
||||
i_end:
|
||||
rb 1024
|
||||
stacktop:
|
||||
sys_path rb 4096
|
||||
file_name:
|
||||
rb 4096
|
||||
plugin_path:
|
||||
rb 4096
|
||||
openfile_path:
|
||||
rb 4096
|
||||
filename_area:
|
||||
rb 256
|
||||
mem:
|
Loading…
Reference in New Issue
Block a user