forked from KolibriOS/kolibrios
zSea rc4
1) background image to the proportional stretching with cropping 2) optimize scaling.obj 3) scaling.obj and convert.obj support RAW header to all cases is now git-svn-id: svn://kolibrios.org@2163 a494cfbc-eb01-0410-851d-a64ba20cac60
This commit is contained in:
parent
48e49905d0
commit
d250796055
@ -3,10 +3,10 @@
|
|||||||
background:
|
background:
|
||||||
cmp [soi],0
|
cmp [soi],0
|
||||||
je .end
|
je .end
|
||||||
|
|
||||||
cmp [bgrmode],dword 2
|
cmp [bgrmode],dword 2
|
||||||
jbe @f
|
ja .stretch_crop
|
||||||
jmp .end
|
|
||||||
@@:
|
|
||||||
mov ecx,[img_width] ; øèðèíà
|
mov ecx,[img_width] ; øèðèíà
|
||||||
test ecx,ecx
|
test ecx,ecx
|
||||||
jz .end
|
jz .end
|
||||||
@ -24,20 +24,149 @@ background:
|
|||||||
|
|
||||||
cmp [img_resolution],24
|
cmp [img_resolution],24
|
||||||
je @f
|
je @f
|
||||||
|
|
||||||
push dword image_file
|
push dword image_file
|
||||||
call [convert_Conv_24b]
|
call [convert_Conv_24b]
|
||||||
|
|
||||||
mov ecx,[raw_pointer_2]
|
mov ecx,[raw_pointer_2]
|
||||||
mcall 15,5 ;15,5 set data
|
add ecx,44
|
||||||
mov ecx,[raw_pointer_2]
|
mcall 15,5 ;15,5 set data
|
||||||
mcall 68,13
|
mcall 68,13,[raw_pointer_2]
|
||||||
jmp .set_mode
|
jmp .set_mode
|
||||||
@@:
|
@@:
|
||||||
mcall 15,5 ; 15,5 set data
|
mcall 15,5 ; 15,5 set data
|
||||||
.set_mode:
|
.set_mode:
|
||||||
mov ecx,[bgrmode]
|
mcall 15,4,[bgrmode] ; 15,4 set mode
|
||||||
mcall 15,4 ; 15,4 set mode
|
dec ebx ; 15,3 redraw background
|
||||||
dec ebx ; 15,3 redraw background
|
|
||||||
mcall
|
mcall
|
||||||
.end:
|
.end:
|
||||||
ret
|
ret
|
||||||
;---------------------------------------------------------------------
|
;---------------------------------------------------------------------
|
||||||
|
.stretch_crop:
|
||||||
|
; cmp [bgrmode],dword 3
|
||||||
|
; jne .stretch_inscribe
|
||||||
|
xor eax,eax
|
||||||
|
mov [stretch_start_coordinates],eax
|
||||||
|
|
||||||
|
mcall 14
|
||||||
|
|
||||||
|
mov ebx,eax
|
||||||
|
and eax,0xffff
|
||||||
|
inc eax
|
||||||
|
mov [screen_high],eax
|
||||||
|
shr ebx,16
|
||||||
|
inc ebx
|
||||||
|
mov [screen_width],ebx
|
||||||
|
|
||||||
|
xchg eax,ebx
|
||||||
|
call calculate_relation
|
||||||
|
mov [screen_relation],eax
|
||||||
|
|
||||||
|
mov eax,[img_width]
|
||||||
|
mov ebx,[img_high]
|
||||||
|
call calculate_relation
|
||||||
|
mov [picture_relation],eax
|
||||||
|
|
||||||
|
cmp eax,[screen_relation]
|
||||||
|
jb @f
|
||||||
|
; Y = Yimg
|
||||||
|
; X = Yimg*Xscreen/Yscreen
|
||||||
|
mov eax,[img_high]
|
||||||
|
mov [stretch_img_high],eax
|
||||||
|
mov eax,[img_high]
|
||||||
|
imul eax,dword [screen_width]
|
||||||
|
mov ebx,[screen_high]
|
||||||
|
call integer_division
|
||||||
|
mov [stretch_img_width],eax
|
||||||
|
mov ebx,[img_width]
|
||||||
|
sub ebx,eax
|
||||||
|
shr ebx,1
|
||||||
|
mov [stretch_start_coordinates.x],bx
|
||||||
|
jmp .continue
|
||||||
|
@@:
|
||||||
|
; X = Ximg
|
||||||
|
; Y = Ximg*Yscreen/Xscreen
|
||||||
|
mov eax,[img_width]
|
||||||
|
mov [stretch_img_width],eax
|
||||||
|
mov eax,[img_width]
|
||||||
|
imul eax,dword [screen_high]
|
||||||
|
mov ebx,[screen_width]
|
||||||
|
call integer_division
|
||||||
|
mov [stretch_img_high],eax
|
||||||
|
mov ebx,[img_high]
|
||||||
|
sub ebx,eax
|
||||||
|
shr ebx,1
|
||||||
|
mov [stretch_start_coordinates.y],bx
|
||||||
|
.continue:
|
||||||
|
mov ebx,[screen_width]
|
||||||
|
shl ebx,16
|
||||||
|
add ebx,[screen_high]
|
||||||
|
|
||||||
|
mov eax,[stretch_img_width]
|
||||||
|
shl eax,16
|
||||||
|
add eax,[stretch_img_high]
|
||||||
|
|
||||||
|
push dword eax ; eax - crop size
|
||||||
|
push dword 0 ; edi - background color
|
||||||
|
push dword 1 ; esi - filtering
|
||||||
|
push dword 0 ; edx - scaling mode
|
||||||
|
push dword [stretch_start_coordinates] ; ecx - start_coordinates
|
||||||
|
push ebx ; ebx - new_size
|
||||||
|
push dword image_file ; eax - convert data table
|
||||||
|
|
||||||
|
call [Scaling_Start]
|
||||||
|
call background_1
|
||||||
|
ret
|
||||||
|
|
||||||
|
;---------------------------------------------------------------------
|
||||||
|
;.stretch_inscribe:
|
||||||
|
; ret
|
||||||
|
;---------------------------------------------------------------------
|
||||||
|
background_1:
|
||||||
|
mov ecx,[screen_width] ;[crop_img_width] ; øèðèíà
|
||||||
|
test ecx,ecx
|
||||||
|
jz .end
|
||||||
|
mov edx,[screen_high] ;[crop_img_high] ; âûñîòà
|
||||||
|
test edx,edx
|
||||||
|
jz .end
|
||||||
|
mcall 15,1 ; set size
|
||||||
|
|
||||||
|
mov esi,ecx
|
||||||
|
imul esi,edx
|
||||||
|
lea esi,[esi*3]
|
||||||
|
mov ecx,[raw_pointer_2] ;[soi]
|
||||||
|
mov eax,[ecx+28]
|
||||||
|
add ecx,eax
|
||||||
|
|
||||||
|
xor edx,edx
|
||||||
|
|
||||||
|
mov eax,[raw_pointer_2]
|
||||||
|
mov eax,[eax+12] ;overall depth of the pixel
|
||||||
|
cmp al,24
|
||||||
|
je @f
|
||||||
|
|
||||||
|
mov eax,[raw_pointer_2]
|
||||||
|
mov [crop_raw_pointer],eax
|
||||||
|
|
||||||
|
push dword crop_image_file
|
||||||
|
call [convert_Conv_24b]
|
||||||
|
|
||||||
|
mov ecx,[crop_raw_pointer_2]
|
||||||
|
add ecx,44
|
||||||
|
mcall 15,5 ;15,5 set data
|
||||||
|
mcall 68,13,[crop_raw_pointer_2]
|
||||||
|
jmp .set_mode
|
||||||
|
@@:
|
||||||
|
mcall 15,5 ; 15,5 set data
|
||||||
|
.set_mode:
|
||||||
|
xor ecx,ecx
|
||||||
|
inc ecx
|
||||||
|
; mov ecx,[bgrmode]
|
||||||
|
mcall 15,4 ; 15,4 set mode
|
||||||
|
dec ebx ; 15,3 redraw background
|
||||||
|
mcall
|
||||||
|
.end:
|
||||||
|
mov ecx,[raw_pointer_2]
|
||||||
|
mcall 68,13
|
||||||
|
ret
|
||||||
|
;---------------------------------------------------------------------
|
@ -38,7 +38,7 @@ lsz fitext,\
|
|||||||
db 0
|
db 0
|
||||||
;---------------------------------------------------------------------
|
;---------------------------------------------------------------------
|
||||||
Authors_text:
|
Authors_text:
|
||||||
.1: db 'zSea version: 1.00 RC3 Date: 24/08/2011',0
|
.1: db 'zSea version: 1.00 RC4 Date: 07/09/2011',0
|
||||||
.2: db 'Authors:',0
|
.2: db 'Authors:',0
|
||||||
.3: db 'Marat Zakiyanov aka Mario(Mario79)',0
|
.3: db 'Marat Zakiyanov aka Mario(Mario79)',0
|
||||||
.4: db 'zSea program, modules: cnv_bmp.obj,',0
|
.4: db 'zSea program, modules: cnv_bmp.obj,',0
|
||||||
@ -198,6 +198,22 @@ zoom_factors:
|
|||||||
dd 5000
|
dd 5000
|
||||||
|
|
||||||
zoom_factors_old dd 0
|
zoom_factors_old dd 0
|
||||||
|
|
||||||
|
;---------------------------------------------------------------------
|
||||||
|
; not change this section!!!
|
||||||
|
; start section
|
||||||
|
;---------------------------------------------------------------------
|
||||||
|
align 4
|
||||||
|
crop_image_file dd 0 ;+0
|
||||||
|
crop_raw_pointer dd 0 ;+4
|
||||||
|
crop_return_code dd 0 ;+8
|
||||||
|
crop_img_size dd 0 ;+12
|
||||||
|
crop_deflate_unpack dd 0 ;+16
|
||||||
|
crop_raw_pointer_2 dd 0 ;+20
|
||||||
|
;---------------------------------------------------------------------
|
||||||
|
; end section
|
||||||
|
;---------------------------------------------------------------------
|
||||||
|
|
||||||
;---------------------------------------------------------------------
|
;---------------------------------------------------------------------
|
||||||
; not change this section!!!
|
; not change this section!!!
|
||||||
; start section
|
; start section
|
||||||
@ -234,23 +250,36 @@ background_color dd 0xffffff
|
|||||||
|
|
||||||
skin_height dd 0
|
skin_height dd 0
|
||||||
|
|
||||||
RAW1_pointer dd 0
|
screen_high dd 0
|
||||||
RAW1_size_x dd 0
|
screen_width dd 0
|
||||||
RAW1_size dd 0
|
|
||||||
Repeat_N dd 0
|
stretch_start_coordinates:
|
||||||
Total_Repeat_N dd 1
|
.y dw 0
|
||||||
|
.x dw 0
|
||||||
|
|
||||||
|
screen_relation dd 0
|
||||||
|
picture_relation dd 0
|
||||||
|
|
||||||
|
stretch_img_high dd 0
|
||||||
|
stretch_img_width dd 0
|
||||||
|
|
||||||
|
RAW1_pointer dd 0
|
||||||
|
RAW1_size_x dd 0
|
||||||
|
RAW1_size dd 0
|
||||||
|
Repeat_N dd 0
|
||||||
|
Total_Repeat_N dd 1
|
||||||
previous_frame_pointer dd 0
|
previous_frame_pointer dd 0
|
||||||
Animation_timer dd 0
|
Animation_timer dd 0
|
||||||
Frame_delay dw 0
|
Frame_delay dw 0
|
||||||
Transp_flag db 0
|
Transp_flag db 0
|
||||||
Transp_index db 0
|
Transp_index db 0
|
||||||
Disposal_Method db 0
|
Disposal_Method db 0
|
||||||
RAW1_flag db 0
|
RAW1_flag db 0
|
||||||
no_fill db 0
|
no_fill db 0
|
||||||
redraw_wallpaper_flag db 0
|
redraw_wallpaper_flag db 0
|
||||||
|
|
||||||
calc_next_value_plus db 0
|
calc_next_value_plus db 0
|
||||||
calc_next_value_minus db 0
|
calc_next_value_minus db 0
|
||||||
;---------------------------------------------------------------------
|
;---------------------------------------------------------------------
|
||||||
align 4
|
align 4
|
||||||
;plugin dd 0
|
;plugin dd 0
|
||||||
@ -871,9 +900,9 @@ op_text:
|
|||||||
.e1:
|
.e1:
|
||||||
.2 db 'Stretch'
|
.2 db 'Stretch'
|
||||||
.e2:
|
.e2:
|
||||||
.3 db 'Stretch + V crop'
|
.3 db 'Stretch + Crop'
|
||||||
.e3:
|
.e3:
|
||||||
.4 db 'Stretch + H crop'
|
.4 db 'Stretch + Inscribe'
|
||||||
.e4:
|
.e4:
|
||||||
|
|
||||||
option_group1 dd op1
|
option_group1 dd op1
|
||||||
|
@ -42,449 +42,448 @@ include '../../../../macros.inc'
|
|||||||
START:
|
START:
|
||||||
pushad
|
pushad
|
||||||
mov eax,dword [esp+36]
|
mov eax,dword [esp+36]
|
||||||
mov [pointer],eax
|
mov [pointer],eax
|
||||||
mov eax,[eax+4]
|
mov eax,[eax+4]
|
||||||
mov [image_file],eax
|
mov [image_file],eax
|
||||||
mov esi,[eax+28]
|
mov esi,[eax+28]
|
||||||
add esi,eax
|
add esi,eax
|
||||||
mov edi,esi
|
mov edi,esi
|
||||||
mov ecx,[eax+32]
|
mov ecx,[eax+32]
|
||||||
; xor ebx,ebx
|
|
||||||
; mov [raw_area],ebx
|
|
||||||
|
|
||||||
; mov ebx,[pointer]
|
cmp [eax+16],word 16
|
||||||
; movzx eax,word [eax+18]
|
je .16b
|
||||||
; mov [ebx+24],eax
|
cmp [eax+12],dword 1
|
||||||
; jmp .ret_ok
|
je .1b
|
||||||
|
cmp [eax+12],dword 2
|
||||||
cmp [eax+16],word 16
|
je .2b
|
||||||
je .16b
|
cmp [eax+12],dword 4
|
||||||
cmp [eax+12],dword 1
|
je .4b
|
||||||
je .1b
|
|
||||||
cmp [eax+12],dword 2
|
|
||||||
je .2b
|
|
||||||
cmp [eax+12],dword 4
|
|
||||||
je .4b
|
|
||||||
;---------------------------------------------------------------------
|
;---------------------------------------------------------------------
|
||||||
.ret_ok:
|
.ret_ok:
|
||||||
; mov ebx,[pointer]
|
mov ebx,[image_file]
|
||||||
; mov eax,[raw_area]
|
cmp [ebx+18],word 2
|
||||||
; mov [ebx+20],eax ; store RAW pointer
|
jne @f
|
||||||
; mov [ebx+24],ecx
|
mov eax,[ebx+12]
|
||||||
|
shr eax,1
|
||||||
mov ebx,[image_file]
|
mov [ebx+12],eax
|
||||||
cmp [ebx+18],word 2
|
|
||||||
jne @f
|
|
||||||
mov eax,[ebx+12]
|
|
||||||
shr eax,1
|
|
||||||
mov [ebx+12],eax
|
|
||||||
@@:
|
@@:
|
||||||
|
|
||||||
popad
|
popad
|
||||||
ret 4
|
ret 4
|
||||||
;---------------------------------------------------------------------
|
;---------------------------------------------------------------------
|
||||||
.less_8b:
|
.less_8b:
|
||||||
mov edx,[image_file]
|
mov edx,[image_file]
|
||||||
mov ecx,[area_size]
|
mov ecx,[area_size]
|
||||||
add ecx,[edx+28]
|
add ecx,[edx+28]
|
||||||
mcall 68,20
|
mcall 68,20
|
||||||
mov [image_file],eax
|
mov [image_file],eax
|
||||||
|
|
||||||
|
mov ecx,[area_size]
|
||||||
mov ecx,[area_size]
|
mov eax,ecx
|
||||||
mov eax,ecx
|
shr ecx,2
|
||||||
shr ecx,2
|
test eax,3
|
||||||
test eax,3
|
jz @f
|
||||||
jz @f
|
inc ecx
|
||||||
inc ecx
|
|
||||||
@@:
|
@@:
|
||||||
mov esi,[raw_area]
|
mov esi,[raw_area]
|
||||||
mov edi,[image_file]
|
mov edi,[image_file]
|
||||||
add edi,[edi+28]
|
add edi,[edi+28]
|
||||||
cld
|
cld
|
||||||
rep movsd
|
rep movsd
|
||||||
|
|
||||||
mov ecx,[raw_area]
|
mcall 68,13,[raw_area]
|
||||||
mcall 68,13
|
mov eax,[image_file]
|
||||||
mov eax,[image_file]
|
mov ebx,[pointer]
|
||||||
mov ebx,[pointer]
|
mov [ebx+4],eax
|
||||||
mov [ebx+4],eax
|
|
||||||
popad
|
popad
|
||||||
ret 4
|
ret 4
|
||||||
;---------------------------------------------------------------------
|
;---------------------------------------------------------------------
|
||||||
.16b:
|
.16b:
|
||||||
cmp [eax+18],word 3
|
; eax - RAW image_file
|
||||||
je @f ;.convert_16_in_8
|
cmp [eax+18],word 3
|
||||||
cmp [eax+18],word 4
|
je @f
|
||||||
jne .16b_1
|
cmp [eax+18],word 4
|
||||||
|
jne .16b_1
|
||||||
@@:
|
@@:
|
||||||
xor ebx,ebx
|
xor ebx,ebx
|
||||||
mov bx,[eax+18]
|
mov bx,[eax+18]
|
||||||
|
|
||||||
xchg eax,ecx
|
xchg eax,ecx
|
||||||
xor edx,edx
|
xor edx,edx
|
||||||
div ebx
|
div ebx
|
||||||
xchg ecx,eax
|
xchg ecx,eax
|
||||||
|
|
||||||
shr ecx,1
|
shr ecx,1
|
||||||
|
|
||||||
mov [eax+16],word 8
|
mov [eax+16],word 8
|
||||||
mov ebx,[eax+12]
|
mov ebx,[eax+12]
|
||||||
shr ebx,1
|
shr ebx,1
|
||||||
mov [eax+12],ebx
|
mov [eax+12],ebx
|
||||||
|
|
||||||
mov ebx,eax
|
mov ebx,eax
|
||||||
; jmp .ret_ok
|
|
||||||
|
|
||||||
.convert_16_in_8: ; converting 16 bit sample to 8 bit
|
.convert_16_in_8: ; converting 16 bit sample to 8 bit
|
||||||
cld
|
cld
|
||||||
lodsw
|
lodsw
|
||||||
mov al,ah
|
mov al,ah
|
||||||
stosb
|
stosb
|
||||||
|
|
||||||
lodsw
|
lodsw
|
||||||
mov al,ah
|
mov al,ah
|
||||||
stosb
|
stosb
|
||||||
|
|
||||||
lodsw
|
lodsw
|
||||||
mov al,ah
|
mov al,ah
|
||||||
stosb
|
stosb
|
||||||
|
|
||||||
cmp [ebx+18],word 4
|
cmp [ebx+18],word 4
|
||||||
jne @f
|
jne @f
|
||||||
lodsw
|
lodsw
|
||||||
mov al,ah
|
mov al,ah
|
||||||
stosb
|
stosb
|
||||||
@@:
|
@@:
|
||||||
dec ecx
|
dec ecx
|
||||||
jnz .convert_16_in_8
|
jnz .convert_16_in_8
|
||||||
jmp .16b_end
|
|
||||||
|
jmp .16b_end
|
||||||
;---------------------------------------------------------------------
|
;---------------------------------------------------------------------
|
||||||
.16b_1:
|
.16b_1:
|
||||||
cmp [eax+18],word 1
|
; eax - RAW image_file
|
||||||
je @f ;.convert_16_in_8_1
|
cmp [eax+18],word 1
|
||||||
cmp [eax+18],word 2
|
je @f
|
||||||
jne .16b_end
|
cmp [eax+18],word 2
|
||||||
|
jne .16b_end
|
||||||
@@:
|
@@:
|
||||||
shr ecx,1
|
shr ecx,1
|
||||||
|
|
||||||
mov [eax+16],word 8
|
mov [eax+16],word 8
|
||||||
mov ebx,[eax+12]
|
mov ebx,[eax+12]
|
||||||
shr ebx,1
|
shr ebx,1
|
||||||
mov [eax+12],ebx
|
mov [eax+12],ebx
|
||||||
|
|
||||||
.convert_16_in_8_1:
|
.convert_16_in_8_1:
|
||||||
cld
|
cld
|
||||||
lodsw
|
lodsw
|
||||||
; shr ax,8
|
|
||||||
; mov al,ah
|
|
||||||
stosb
|
stosb
|
||||||
dec ecx
|
dec ecx
|
||||||
jnz .convert_16_in_8_1
|
jnz .convert_16_in_8_1
|
||||||
;---------------------------------------------------------------------
|
;---------------------------------------------------------------------
|
||||||
.16b_end:
|
.16b_end:
|
||||||
xor eax,eax
|
xor eax,eax
|
||||||
mov [raw_area],eax
|
mov [raw_area],eax
|
||||||
jmp .ret_ok
|
jmp .ret_ok
|
||||||
;---------------------------------------------------------------------
|
;---------------------------------------------------------------------
|
||||||
.4b:
|
.4b:
|
||||||
call .get_memory
|
call .get_memory
|
||||||
mov edx,ebx
|
mov edx,ebx
|
||||||
inc ebx
|
inc ebx
|
||||||
shr ebx,1
|
shr ebx,1
|
||||||
.4b_1:
|
.4b_1:
|
||||||
push ebx edi
|
push ebx edi
|
||||||
@@:
|
@@:
|
||||||
cld
|
cld
|
||||||
lodsb
|
lodsb
|
||||||
shl eax,8
|
shl eax,8
|
||||||
mov al,ah
|
mov al,ah
|
||||||
and ah,0xf
|
and ah,0xf
|
||||||
shr al,4
|
shr al,4
|
||||||
stosw
|
stosw
|
||||||
|
|
||||||
dec ebx
|
dec ebx
|
||||||
jnz @b
|
jnz @b
|
||||||
pop edi ebx
|
pop edi ebx
|
||||||
add edi,edx
|
add edi,edx
|
||||||
dec ecx
|
dec ecx
|
||||||
jnz .4b_1
|
jnz .4b_1
|
||||||
|
|
||||||
jmp .less_8b ;.ret_ok
|
jmp .less_8b
|
||||||
;---------------------------------------------------------------------
|
;---------------------------------------------------------------------
|
||||||
.2b:
|
.2b:
|
||||||
call .get_memory
|
call .get_memory
|
||||||
; jmp .ret_ok
|
mov edx,ebx
|
||||||
; shr ecx,1
|
mov eax,ebx
|
||||||
mov edx,ebx
|
shr ebx,2
|
||||||
mov eax,ebx
|
test eax,3
|
||||||
shr ebx,2
|
jz @f
|
||||||
test eax,3
|
inc ebx
|
||||||
jz @f
|
|
||||||
inc ebx
|
|
||||||
@@:
|
@@:
|
||||||
mov ebp,ebx
|
mov ebp,ebx
|
||||||
.2b_1:
|
.2b_1:
|
||||||
push ebp edi
|
push ebp edi
|
||||||
@@:
|
@@:
|
||||||
cld
|
cld
|
||||||
lodsb
|
lodsb
|
||||||
|
|
||||||
mov bl,al
|
mov bl,al
|
||||||
|
|
||||||
and al,11b
|
and al,11b
|
||||||
shl ax,8
|
shl ax,8
|
||||||
|
|
||||||
mov al,bl
|
mov al,bl
|
||||||
shr al,2
|
shr al,2
|
||||||
and al,11b
|
and al,11b
|
||||||
shl eax,8
|
shl eax,8
|
||||||
|
|
||||||
mov al,bl
|
mov al,bl
|
||||||
shr al,4
|
shr al,4
|
||||||
and al,11b
|
and al,11b
|
||||||
shl eax,8
|
shl eax,8
|
||||||
|
|
||||||
mov al,bl
|
mov al,bl
|
||||||
shr al,6
|
shr al,6
|
||||||
and al,11b
|
and al,11b
|
||||||
|
|
||||||
stosd
|
stosd
|
||||||
|
|
||||||
dec ebp
|
dec ebp
|
||||||
jnz @b
|
jnz @b
|
||||||
pop edi ebp
|
pop edi ebp
|
||||||
|
|
||||||
add edi,edx
|
add edi,edx
|
||||||
dec ecx
|
dec ecx
|
||||||
jnz .2b_1
|
jnz .2b_1
|
||||||
|
|
||||||
jmp .less_8b ;.ret_ok
|
jmp .less_8b
|
||||||
;---------------------------------------------------------------------
|
;---------------------------------------------------------------------
|
||||||
.1b:
|
.1b:
|
||||||
call .get_memory
|
call .get_memory
|
||||||
mov edx,ebx
|
mov edx,ebx
|
||||||
mov eax,ebx
|
mov eax,ebx
|
||||||
shr ebx,3
|
shr ebx,3
|
||||||
test eax,7
|
test eax,7
|
||||||
jz @f
|
jz @f
|
||||||
inc ebx
|
inc ebx
|
||||||
@@:
|
@@:
|
||||||
mov ebp,ebx
|
mov ebp,ebx
|
||||||
.1b_1:
|
.1b_1:
|
||||||
push ebp edi
|
push ebp edi
|
||||||
@@:
|
@@:
|
||||||
cld
|
cld
|
||||||
lodsb
|
lodsb
|
||||||
|
|
||||||
mov bl,al
|
mov bl,al
|
||||||
shr al,4
|
shr al,4
|
||||||
and al,1b
|
and al,1b
|
||||||
shl ax,8
|
shl ax,8
|
||||||
|
|
||||||
mov al,bl
|
mov al,bl
|
||||||
shr al,5
|
shr al,5
|
||||||
and al,1b
|
and al,1b
|
||||||
shl eax,8
|
shl eax,8
|
||||||
|
|
||||||
mov al,bl
|
mov al,bl
|
||||||
shr al,6
|
shr al,6
|
||||||
and al,1b
|
and al,1b
|
||||||
shl eax,8
|
shl eax,8
|
||||||
|
|
||||||
mov al,bl
|
mov al,bl
|
||||||
shr al,7
|
shr al,7
|
||||||
; and al,1b
|
|
||||||
; shl eax,8
|
|
||||||
|
|
||||||
stosd
|
stosd
|
||||||
|
|
||||||
mov al,bl
|
mov al,bl
|
||||||
and al,1b
|
and al,1b
|
||||||
shl ax,8
|
shl ax,8
|
||||||
|
|
||||||
mov al,bl
|
mov al,bl
|
||||||
shr al,1
|
shr al,1
|
||||||
and al,1b
|
and al,1b
|
||||||
shl eax,8
|
shl eax,8
|
||||||
|
|
||||||
mov al,bl
|
mov al,bl
|
||||||
shr al,2
|
shr al,2
|
||||||
and al,1b
|
and al,1b
|
||||||
shl eax,8
|
shl eax,8
|
||||||
|
|
||||||
mov al,bl
|
mov al,bl
|
||||||
shr al,3
|
shr al,3
|
||||||
and al,1b
|
and al,1b
|
||||||
|
|
||||||
stosd
|
stosd
|
||||||
|
|
||||||
dec ebp
|
dec ebp
|
||||||
jnz @b
|
jnz @b
|
||||||
pop edi ebp
|
pop edi ebp
|
||||||
|
|
||||||
add edi,edx
|
add edi,edx
|
||||||
dec ecx
|
dec ecx
|
||||||
jnz .1b_1
|
jnz .1b_1
|
||||||
jmp .less_8b ;.ret_ok
|
|
||||||
|
jmp .less_8b
|
||||||
;---------------------------------------------------------------------
|
;---------------------------------------------------------------------
|
||||||
.get_memory:
|
.get_memory:
|
||||||
mov ebx,dword 8
|
; eax - RAW image_file
|
||||||
mov [eax+16],bx
|
mov ebx,dword 8
|
||||||
mov [eax+12],ebx
|
mov [eax+16],bx
|
||||||
; mov esi,[eax+28]
|
mov [eax+12],ebx
|
||||||
; add esi,eax
|
mov ecx,[eax+4]
|
||||||
; push ecx
|
imul ecx,[eax+8]
|
||||||
mov ecx,[eax+4]
|
push eax
|
||||||
imul ecx,[eax+8]
|
mov [area_size],ecx
|
||||||
push eax
|
mcall 68,12
|
||||||
mov [area_size],ecx
|
mov [raw_area],eax
|
||||||
mcall 68,12
|
mov edi,eax
|
||||||
; pop ecx
|
pop eax
|
||||||
mov [raw_area],eax
|
mov ebx,[eax+4]
|
||||||
mov edi,eax
|
mov ecx,[eax+8]
|
||||||
pop eax
|
|
||||||
mov ebx,[eax+4]
|
|
||||||
mov ecx,[eax+8]
|
|
||||||
ret
|
ret
|
||||||
;---------------------------------------------------------------------
|
;---------------------------------------------------------------------
|
||||||
Convert24b:
|
Convert24b:
|
||||||
pushad
|
pushad
|
||||||
mov eax,dword [esp+36]
|
mov eax,dword [esp+36]
|
||||||
mov [pointer],eax
|
mov [pointer],eax
|
||||||
mov eax,[eax+4]
|
mov eax,[eax+4]
|
||||||
mov [image_file],eax
|
mov [image_file],eax
|
||||||
|
|
||||||
mov esi,[eax+28]
|
mov esi,[eax+28]
|
||||||
add esi,eax
|
add esi,eax
|
||||||
|
|
||||||
mov ebp,[eax+20]
|
mov ebp,[eax+20]
|
||||||
add ebp,eax
|
add ebp,eax
|
||||||
|
|
||||||
mov ecx,[eax+4]
|
mov ecx,[eax+4]
|
||||||
imul ecx,[eax+8]
|
imul ecx,[eax+8]
|
||||||
push eax ecx
|
push eax ecx
|
||||||
lea ecx,[ecx*3]
|
lea ecx,[ecx*3]
|
||||||
mcall 68,12
|
mov edx,ecx
|
||||||
mov [raw_area],eax
|
add ecx,44 ; header
|
||||||
mov edi,eax
|
mcall 68,12 ;get new RAW area
|
||||||
pop ecx eax
|
mov [raw_area],eax
|
||||||
|
mov edi,eax
|
||||||
|
|
||||||
cmp [eax+12],dword 32
|
push esi
|
||||||
je .32b
|
mov esi,[image_file]
|
||||||
cmp [eax+12],dword 16
|
mov ecx,3
|
||||||
je .16b
|
cld
|
||||||
cmp [eax+12],dword 15
|
rep movsd ;copy the 3 first dword for the structure of RAW
|
||||||
je .15b
|
pop esi
|
||||||
cmp [eax+12],dword 8
|
|
||||||
je .8b
|
sub edi,12
|
||||||
|
mov [edi+12],dword 24 ;overall depth of the pixel
|
||||||
|
mov [edi+16],word 8 ;channel depth of the pixel
|
||||||
|
xor eax,eax
|
||||||
|
mov [edi+20],eax ;palette area pointer
|
||||||
|
mov [edi+24],eax ;palette area size
|
||||||
|
mov [edi+28],dword 44 ;rgb area pointer
|
||||||
|
mov [edi+32],edx ;rgb area size
|
||||||
|
mov [edi+36],eax ;transparency area pointer
|
||||||
|
mov [edi+40],eax ;transparency area size
|
||||||
|
pop ecx eax
|
||||||
|
|
||||||
|
add edi,44
|
||||||
|
|
||||||
|
cmp [eax+12],dword 32
|
||||||
|
je .32b
|
||||||
|
cmp [eax+12],dword 16
|
||||||
|
je .16b
|
||||||
|
cmp [eax+12],dword 15
|
||||||
|
je .15b
|
||||||
|
cmp [eax+12],dword 8
|
||||||
|
je .8b
|
||||||
|
|
||||||
.ret_ok:
|
.ret_ok:
|
||||||
mov ebx,[pointer]
|
mov ebx,[pointer]
|
||||||
mov eax,[raw_area]
|
mov eax,[raw_area]
|
||||||
mov [ebx+20],eax ; store RAW pointer
|
mov [ebx+20],eax ; store RAW pointer
|
||||||
popad
|
popad
|
||||||
ret 4
|
ret 4
|
||||||
|
|
||||||
;---------------------------------------------------------------------
|
;---------------------------------------------------------------------
|
||||||
.32b:
|
.32b:
|
||||||
cld
|
cld
|
||||||
lodsd
|
lodsd
|
||||||
|
|
||||||
stosw
|
stosw
|
||||||
shr eax,16
|
shr eax,16
|
||||||
stosb
|
stosb
|
||||||
|
|
||||||
dec ecx
|
dec ecx
|
||||||
jnz .32b
|
jnz .32b
|
||||||
|
|
||||||
jmp .ret_ok
|
jmp .ret_ok
|
||||||
;---------------------------------------------------------------------
|
;---------------------------------------------------------------------
|
||||||
.16b:
|
.16b:
|
||||||
cld
|
cld
|
||||||
lodsw
|
lodsw
|
||||||
|
|
||||||
xor ebx,ebx
|
xor ebx,ebx
|
||||||
ror ax,11
|
ror ax,11
|
||||||
mov bl,al
|
mov bl,al
|
||||||
and bl,11111b
|
and bl,11111b
|
||||||
shl bl,3
|
shl bl,3
|
||||||
shl ebx,8
|
shl ebx,8
|
||||||
rol ax,6
|
rol ax,6
|
||||||
mov bl,al
|
mov bl,al
|
||||||
and bl,111111b
|
and bl,111111b
|
||||||
shl bl,2
|
shl bl,2
|
||||||
shl ebx,8
|
shl ebx,8
|
||||||
rol ax,5
|
rol ax,5
|
||||||
mov bl,al
|
mov bl,al
|
||||||
and bl,11111b
|
and bl,11111b
|
||||||
shl bl,3
|
shl bl,3
|
||||||
mov eax,ebx
|
mov eax,ebx
|
||||||
|
|
||||||
cld
|
cld
|
||||||
stosw
|
stosw
|
||||||
shr eax,16
|
shr eax,16
|
||||||
stosb
|
stosb
|
||||||
|
|
||||||
dec ecx
|
dec ecx
|
||||||
jnz .16b
|
jnz .16b
|
||||||
|
|
||||||
jmp .ret_ok
|
jmp .ret_ok
|
||||||
;---------------------------------------------------------------------
|
;---------------------------------------------------------------------
|
||||||
.15b:
|
.15b:
|
||||||
cld
|
cld
|
||||||
lodsw
|
lodsw
|
||||||
|
|
||||||
xor ebx,ebx
|
xor ebx,ebx
|
||||||
ror ax,10
|
ror ax,10
|
||||||
mov bl,al
|
mov bl,al
|
||||||
and bl,11111b
|
and bl,11111b
|
||||||
shl bl,3
|
shl bl,3
|
||||||
shl ebx,8
|
shl ebx,8
|
||||||
rol ax,5
|
rol ax,5
|
||||||
mov bl,al
|
mov bl,al
|
||||||
and bl,11111b
|
and bl,11111b
|
||||||
shl bl,3
|
shl bl,3
|
||||||
shl ebx,8
|
shl ebx,8
|
||||||
rol ax,5
|
rol ax,5
|
||||||
mov bl,al
|
mov bl,al
|
||||||
and bl,11111b
|
and bl,11111b
|
||||||
shl bl,3
|
shl bl,3
|
||||||
mov eax,ebx
|
mov eax,ebx
|
||||||
|
|
||||||
cld
|
cld
|
||||||
stosw
|
stosw
|
||||||
shr eax,16
|
shr eax,16
|
||||||
stosb
|
stosb
|
||||||
|
|
||||||
dec ecx
|
dec ecx
|
||||||
jnz .15b
|
jnz .15b
|
||||||
|
|
||||||
jmp .ret_ok
|
jmp .ret_ok
|
||||||
;---------------------------------------------------------------------
|
;---------------------------------------------------------------------
|
||||||
.8b:
|
.8b:
|
||||||
xor eax,eax
|
xor eax,eax
|
||||||
cld
|
cld
|
||||||
lodsb
|
lodsb
|
||||||
shl eax,2
|
shl eax,2
|
||||||
mov eax,[eax+ebp]
|
mov eax,[eax+ebp]
|
||||||
|
|
||||||
cld
|
cld
|
||||||
stosw
|
stosw
|
||||||
shr eax,16
|
shr eax,16
|
||||||
stosb
|
stosb
|
||||||
|
|
||||||
dec ecx
|
dec ecx
|
||||||
jnz .8b
|
jnz .8b
|
||||||
|
|
||||||
jmp .ret_ok
|
jmp .ret_ok
|
||||||
;---------------------------------------------------------------------
|
;---------------------------------------------------------------------
|
||||||
align 16
|
align 16
|
||||||
EXPORTS:
|
EXPORTS:
|
||||||
dd szStart, START
|
dd szStart, START
|
||||||
dd szVersion, 0x00010002
|
dd szVersion, 0x00010003
|
||||||
dd szConv_24b, Convert24b
|
dd szConv_24b, Convert24b
|
||||||
dd 0
|
dd 0
|
||||||
|
|
||||||
szStart db 'START',0
|
szStart db 'START',0
|
||||||
szVersion db 'version',0
|
szVersion db 'version',0
|
||||||
|
@ -38,220 +38,215 @@ include '../../../../macros.inc'
|
|||||||
;---------------------------------------------------------------------
|
;---------------------------------------------------------------------
|
||||||
START:
|
START:
|
||||||
pushad
|
pushad
|
||||||
mov edi,dword [esp+56]
|
mov eax,dword [esp+60] ; eax - crop size
|
||||||
mov esi,dword [esp+52]
|
mov ebx,eax
|
||||||
mov edx,dword [esp+48]
|
and eax,0xffff
|
||||||
mov ecx,dword [esp+44]
|
shr ebx,16
|
||||||
mov ebx,dword [esp+40]
|
mov [crop_x],ebx
|
||||||
mov eax,dword [esp+36]
|
mov [crop_y],eax
|
||||||
mov [pointer],eax
|
mov edi,dword [esp+56] ; edi - background color
|
||||||
test bx,bx
|
mov esi,dword [esp+52] ; esi - filtering
|
||||||
jnz @f
|
mov edx,dword [esp+48] ; edx - scaling mode
|
||||||
inc bx
|
mov ecx,dword [esp+44] ; ecx - start_coordinates
|
||||||
@@:
|
mov ebx,dword [esp+40] ; ebx - new_size
|
||||||
ror ebx,16
|
mov eax,dword [esp+36] ; eax - convert data table
|
||||||
test bx,bx
|
mov [pointer],eax
|
||||||
jnz @f
|
test bx,bx
|
||||||
inc bx
|
jnz @f
|
||||||
@@:
|
|
||||||
rol ebx,16
|
|
||||||
mov [new_size],ebx
|
|
||||||
mov [start_coordinates],ecx
|
|
||||||
mov [scaling_mode],edx
|
|
||||||
mov [filtering],esi
|
|
||||||
mov [background_color],edi
|
|
||||||
mov eax,[eax+4]
|
|
||||||
mov [image_file],eax
|
|
||||||
|
|
||||||
mov esi,[eax+28]
|
inc bx
|
||||||
add esi,eax
|
@@:
|
||||||
|
ror ebx,16
|
||||||
|
test bx,bx
|
||||||
|
jnz @f
|
||||||
|
|
||||||
mov ebx,[eax+20]
|
inc bx
|
||||||
add ebx,eax
|
@@:
|
||||||
mov [palette],ebx
|
rol ebx,16
|
||||||
|
mov [new_size],ebx
|
||||||
|
mov [start_coordinates],ecx
|
||||||
|
mov [scaling_mode],edx
|
||||||
|
mov [filtering],esi
|
||||||
|
mov [background_color],edi
|
||||||
|
mov eax,[eax+4]
|
||||||
|
mov [image_file],eax
|
||||||
|
|
||||||
mov ebx,[eax+12]
|
mov esi,[eax+28]
|
||||||
mov [resolution],ebx
|
add esi,eax
|
||||||
cmp ebx,32
|
|
||||||
jne @f
|
mov ebx,[eax+20]
|
||||||
mov ebp,dword START.32
|
add ebx,eax
|
||||||
jmp .1
|
mov [palette],ebx
|
||||||
|
|
||||||
|
mov ebx,[eax+12]
|
||||||
|
mov [resolution],ebx
|
||||||
|
cmp ebx,32
|
||||||
|
jne @f
|
||||||
|
mov ebp,dword START.32
|
||||||
|
jmp .1
|
||||||
@@:
|
@@:
|
||||||
cmp ebx,24
|
cmp ebx,24
|
||||||
jne @f
|
jne @f
|
||||||
mov ebp,dword START.24
|
mov ebp,dword START.24
|
||||||
jmp .1
|
jmp .1
|
||||||
@@:
|
@@:
|
||||||
cmp ebx,16
|
cmp ebx,16
|
||||||
jne @f
|
jne @f
|
||||||
mov ebp,dword START.16
|
mov ebp,dword START.16
|
||||||
jmp .1
|
jmp .1
|
||||||
@@:
|
@@:
|
||||||
cmp ebx,15
|
cmp ebx,15
|
||||||
jne @f
|
jne @f
|
||||||
inc ebx
|
inc ebx
|
||||||
mov ebp,dword START.16
|
mov ebp,dword START.16
|
||||||
jmp .1
|
jmp .1
|
||||||
@@:
|
@@:
|
||||||
cmp ebx,8
|
cmp ebx,8
|
||||||
jne @f
|
jne @f
|
||||||
mov ebp,dword START.8
|
mov ebp,dword START.8
|
||||||
@@:
|
@@:
|
||||||
.1:
|
.1:
|
||||||
shr ebx,3
|
shr ebx,3
|
||||||
mov [bytes_to_pixel],ebx
|
mov [bytes_to_pixel],ebx
|
||||||
|
|
||||||
mov ebx,[eax+8]
|
mov ebx,[eax+8]
|
||||||
mov [y],ebx
|
mov [y],ebx
|
||||||
mov ebx,[eax+4]
|
mov ebx,[eax+4]
|
||||||
mov [x],ebx
|
mov [x],ebx
|
||||||
imul ebx,[bytes_to_pixel]
|
imul ebx,[bytes_to_pixel]
|
||||||
mov [size_x],ebx
|
mov [size_x],ebx
|
||||||
|
|
||||||
mov eax,100
|
mov eax,[crop_y]
|
||||||
shl eax,12
|
test eax,eax
|
||||||
mov ebx,[scaling_mode]
|
jz @f
|
||||||
test ebx,ebx
|
mov [y],eax
|
||||||
jnz @f
|
|
||||||
inc ebx
|
|
||||||
@@:
|
@@:
|
||||||
xor edx,edx
|
mov eax,[crop_x]
|
||||||
div ebx
|
test eax,eax
|
||||||
mov [scaling_delta],eax
|
jz @f
|
||||||
|
mov [x],eax
|
||||||
call .get_memory
|
|
||||||
cmp [scaling_mode],0
|
|
||||||
jne @f
|
|
||||||
call .scaling
|
|
||||||
jmp .ret_ok
|
|
||||||
@@:
|
@@:
|
||||||
call .scaling_2
|
mov eax,100
|
||||||
|
shl eax,12
|
||||||
|
mov ebx,[scaling_mode]
|
||||||
|
test ebx,ebx
|
||||||
|
jnz @f
|
||||||
|
inc ebx
|
||||||
|
@@:
|
||||||
|
xor edx,edx
|
||||||
|
div ebx
|
||||||
|
mov [scaling_delta],eax
|
||||||
|
|
||||||
|
call .get_memory
|
||||||
|
call .scaling
|
||||||
;---------------------------------------------------------------------
|
;---------------------------------------------------------------------
|
||||||
.ret_ok:
|
.ret_ok:
|
||||||
mcall 68,13,[area_for_x]
|
mcall 68,13,[area_for_x]
|
||||||
mov ebx,[pointer]
|
mov ebx,[pointer]
|
||||||
mov eax,[raw_area]
|
mov eax,[raw_area]
|
||||||
mov [ebx+20],eax ; store RAW pointer
|
mov [ebx+20],eax ; store RAW pointer
|
||||||
; movzx eax,word [new_size.x1]
|
; movzx eax,word [new_size.x1]
|
||||||
; mov [ebx+24],esi ;eax
|
; mov [ebx+24],esi ;eax
|
||||||
; movzx eax,word [new_size.y1]
|
; movzx eax,word [new_size.y1]
|
||||||
; mov [ebx+28],eax
|
; mov [ebx+28],eax
|
||||||
; mov eax,[size_x]
|
; mov eax,[size_x]
|
||||||
; mov [ebx+32],eax
|
; mov [ebx+32],eax
|
||||||
; mov eax,[bytes_to_pixel]
|
; mov eax,[bytes_to_pixel]
|
||||||
; mov [ebx+36],eax
|
; mov [ebx+36],eax
|
||||||
; mov eax,[x]
|
; mov eax,[x]
|
||||||
; mov [ebx+40],eax
|
; mov [ebx+40],eax
|
||||||
; mov eax,[y]
|
; mov eax,[y]
|
||||||
; mov [ebx+44],eax
|
; mov [ebx+44],eax
|
||||||
.exit:
|
.exit:
|
||||||
popad
|
popad
|
||||||
ret 24
|
ret 28
|
||||||
;---------------------------------------------------------------------
|
;---------------------------------------------------------------------
|
||||||
align 4
|
align 4
|
||||||
.scaling:
|
.scaling:
|
||||||
xor ecx,ecx
|
xor eax,eax
|
||||||
.y:
|
mov ax,[start_coordinates.y]
|
||||||
xor ebx,ebx
|
imul eax,[size_x]
|
||||||
;-------------------------
|
add esi,eax
|
||||||
.x:
|
xor eax,eax
|
||||||
call ebp
|
mov ax,[start_coordinates.x]
|
||||||
inc ebx
|
imul eax,[bytes_to_pixel]
|
||||||
cmp bx,[new_size.x1]
|
add esi,eax
|
||||||
jb .x
|
|
||||||
;-------------------------
|
|
||||||
inc ecx
|
|
||||||
cmp cx,[new_size.y1]
|
|
||||||
jb .y
|
|
||||||
ret
|
|
||||||
;---------------------------------------------------------------------
|
|
||||||
align 4
|
|
||||||
.scaling_2:
|
|
||||||
xor eax,eax
|
|
||||||
mov ax,[start_coordinates.y]
|
|
||||||
imul eax,[size_x]
|
|
||||||
add esi,eax
|
|
||||||
xor eax,eax
|
|
||||||
mov ax,[start_coordinates.x]
|
|
||||||
imul eax,[bytes_to_pixel]
|
|
||||||
add esi,eax
|
|
||||||
|
|
||||||
xor eax,eax
|
xor eax,eax
|
||||||
dec eax
|
dec eax
|
||||||
mov [temp_y],eax
|
mov [temp_y],eax
|
||||||
|
|
||||||
xor ecx,ecx
|
xor ecx,ecx
|
||||||
align 4
|
align 4
|
||||||
.y_2:
|
.y_2:
|
||||||
xor ebx,ebx
|
xor ebx,ebx
|
||||||
;-------------------------
|
;-------------------------
|
||||||
align 4
|
align 4
|
||||||
.x_2:
|
.x_2:
|
||||||
call ebp
|
call ebp
|
||||||
inc ebx
|
inc ebx
|
||||||
cmp bx,[new_size.x1]
|
cmp bx,[new_size.x1]
|
||||||
jb .x_2
|
jb .x_2
|
||||||
;-------------------------
|
;-------------------------
|
||||||
inc ecx
|
inc ecx
|
||||||
cmp cx,[new_size.y1]
|
cmp cx,[new_size.y1]
|
||||||
jb .y_2
|
jb .y_2
|
||||||
ret
|
ret
|
||||||
;---------------------------------------------------------------------
|
;---------------------------------------------------------------------
|
||||||
align 4
|
align 4
|
||||||
.32:
|
.32:
|
||||||
push ecx ebx
|
push ecx ebx
|
||||||
call .calculate_pixel
|
call .calculate_pixel
|
||||||
mov eax,[ecx]
|
mov eax,[ecx]
|
||||||
call .check_filtering_32
|
call .check_filtering_32
|
||||||
pop ebx ecx
|
pop ebx ecx
|
||||||
cld
|
cld
|
||||||
stosd
|
stosd
|
||||||
ret
|
ret
|
||||||
;---------------------------------------------------------------------
|
;---------------------------------------------------------------------
|
||||||
align 4
|
align 4
|
||||||
.24:
|
.24:
|
||||||
push ecx ebx
|
push ecx ebx
|
||||||
call .calculate_pixel
|
call .calculate_pixel
|
||||||
mov eax,[ecx]
|
mov eax,[ecx]
|
||||||
call .check_filtering_24
|
call .check_filtering_24
|
||||||
cld
|
cld
|
||||||
stosw
|
stosw
|
||||||
shr eax,16
|
shr eax,16
|
||||||
pop ebx ecx
|
pop ebx ecx
|
||||||
cld
|
cld
|
||||||
stosb
|
stosb
|
||||||
ret
|
ret
|
||||||
;---------------------------------------------------------------------
|
;---------------------------------------------------------------------
|
||||||
align 4
|
align 4
|
||||||
.16:
|
.16:
|
||||||
push ecx ebx
|
push ecx ebx
|
||||||
call .calculate_pixel
|
call .calculate_pixel
|
||||||
xor eax,eax
|
xor eax,eax
|
||||||
mov ax,[ecx]
|
mov ax,[ecx]
|
||||||
call .check_filtering_16
|
call .check_filtering_16
|
||||||
pop ebx ecx
|
pop ebx ecx
|
||||||
cld
|
cld
|
||||||
stosw
|
stosw
|
||||||
ret
|
ret
|
||||||
;---------------------------------------------------------------------
|
;---------------------------------------------------------------------
|
||||||
align 4
|
align 4
|
||||||
.8:
|
.8:
|
||||||
push ecx ebx
|
push ecx ebx
|
||||||
call .calculate_pixel
|
call .calculate_pixel
|
||||||
cmp [filtering],0
|
cmp [filtering],0
|
||||||
jne @f
|
jne @f
|
||||||
mov al,[ecx]
|
mov al,[ecx]
|
||||||
pop ebx ecx
|
pop ebx ecx
|
||||||
cld
|
cld
|
||||||
stosb
|
stosb
|
||||||
ret
|
ret
|
||||||
@@:
|
@@:
|
||||||
call .check_filtering_8
|
call .check_filtering_8
|
||||||
cld
|
cld
|
||||||
stosw
|
stosw
|
||||||
shr eax,16
|
shr eax,16
|
||||||
pop ebx ecx
|
pop ebx ecx
|
||||||
cld
|
cld
|
||||||
stosb
|
stosb
|
||||||
ret
|
ret
|
||||||
@ -259,181 +254,240 @@ align 4
|
|||||||
;---------------------------------------------------------------------
|
;---------------------------------------------------------------------
|
||||||
align 4
|
align 4
|
||||||
.calculate_pixel:
|
.calculate_pixel:
|
||||||
test ecx,ecx
|
test ecx,ecx
|
||||||
jz .offset_x
|
jz .offset_x
|
||||||
;.offset_y:
|
;.offset_y:
|
||||||
mov eax,ecx
|
mov eax,ecx
|
||||||
|
|
||||||
mov ecx,[temp_y]
|
mov ecx,[temp_y]
|
||||||
cmp eax,ecx
|
cmp eax,ecx
|
||||||
jne .new_y
|
jne .new_y
|
||||||
mov eax,[temp_y_offset]
|
mov eax,[temp_y_offset]
|
||||||
mov ecx,eax
|
mov ecx,eax
|
||||||
jmp .offset_x
|
jmp .offset_x
|
||||||
;--------------------------------
|
;--------------------------------
|
||||||
align 4
|
align 4
|
||||||
.new_y:
|
.new_y:
|
||||||
mov [temp_y],eax
|
mov [temp_y],eax
|
||||||
|
mov ebx,[scaling_mode]
|
||||||
|
test ebx,ebx
|
||||||
|
jz @f
|
||||||
|
|
||||||
mov ebx,[scaling_mode]
|
imul eax,[scaling_delta]
|
||||||
test ebx,ebx
|
|
||||||
jz @f
|
|
||||||
imul eax,[scaling_delta]
|
|
||||||
;--------------------------------
|
;--------------------------------
|
||||||
push ebx
|
push ebx
|
||||||
mov ebx,eax
|
mov ebx,eax
|
||||||
shr eax,12
|
shr eax,12
|
||||||
and ebx,0xFFF
|
and ebx,0xFFF
|
||||||
shl ebx,7 ;multiply 128
|
shl ebx,7 ;multiply 128
|
||||||
shr ebx,12
|
shr ebx,12
|
||||||
mov [next_pixel_y],ebx
|
mov [next_pixel_y],ebx
|
||||||
pop ebx
|
pop ebx
|
||||||
|
;--------------------------------
|
||||||
|
jmp .ex_1
|
||||||
;--------------------------------
|
;--------------------------------
|
||||||
jmp .ex_1
|
|
||||||
align 4
|
align 4
|
||||||
@@:
|
@@:
|
||||||
|
imul eax,dword [y]
|
||||||
;--------------------------------
|
;--------------------------------
|
||||||
imul eax,dword [y]
|
align 4
|
||||||
mov bx,word [new_size.y1]
|
@@:
|
||||||
|
mov bx,word [new_size.y1]
|
||||||
;--------------------------------
|
;--------------------------------
|
||||||
align 4
|
align 4
|
||||||
.y_div:
|
.y_div:
|
||||||
test ebx,ebx
|
test ebx,ebx
|
||||||
jnz @f
|
jnz @f
|
||||||
inc ebx
|
inc ebx
|
||||||
|
;--------------------------------
|
||||||
align 4
|
align 4
|
||||||
@@:
|
@@:
|
||||||
xor edx,edx
|
xor edx,edx
|
||||||
div ebx
|
div ebx
|
||||||
;--------------------------------
|
;--------------------------------
|
||||||
push eax
|
push eax
|
||||||
mov eax,edx
|
mov eax,edx
|
||||||
shl eax,7 ;multiply 128
|
shl eax,7 ;multiply 128
|
||||||
xor edx,edx
|
xor edx,edx
|
||||||
div ebx
|
div ebx
|
||||||
mov [next_pixel_y],eax
|
mov [next_pixel_y],eax
|
||||||
pop eax
|
pop eax
|
||||||
;--------------------------------
|
;--------------------------------
|
||||||
align 4
|
align 4
|
||||||
.ex_1:
|
.ex_1:
|
||||||
mov [temp_y1],eax
|
mov [temp_y1],eax
|
||||||
imul eax,[size_x]
|
imul eax,[size_x]
|
||||||
|
|
||||||
mov [temp_y_offset],eax
|
mov [temp_y_offset],eax
|
||||||
mov ecx,eax
|
mov ecx,eax
|
||||||
align 4
|
align 4
|
||||||
.offset_x:
|
.offset_x:
|
||||||
test ebx,ebx
|
test ebx,ebx
|
||||||
jz .finish
|
jz .finish
|
||||||
mov eax,[esp+4] ;ebx
|
mov eax,[esp+4] ;ebx
|
||||||
|
|
||||||
mov edx,[esp+8]
|
mov edx,[esp+8]
|
||||||
test edx,edx
|
test edx,edx
|
||||||
jz .continue
|
jz .continue
|
||||||
shl eax,3
|
shl eax,3
|
||||||
add eax,[area_for_x]
|
add eax,[area_for_x]
|
||||||
mov edx,[eax+4]
|
mov edx,[eax+4]
|
||||||
mov [next_pixel_x],edx
|
mov [next_pixel_x],edx
|
||||||
mov eax,[eax]
|
mov eax,[eax]
|
||||||
jmp .ex_3
|
jmp .ex_3
|
||||||
;--------------------------------
|
;--------------------------------
|
||||||
align 4
|
align 4
|
||||||
.continue:
|
.continue:
|
||||||
mov ebx,[scaling_mode]
|
mov ebx,[scaling_mode]
|
||||||
test ebx,ebx
|
test ebx,ebx
|
||||||
jz @f
|
jz @f
|
||||||
imul eax,[scaling_delta]
|
imul eax,[scaling_delta]
|
||||||
;--------------------------------
|
;--------------------------------
|
||||||
mov ebx,eax
|
mov ebx,eax
|
||||||
shr eax,12
|
shr eax,12
|
||||||
and ebx,0xFFF
|
and ebx,0xFFF
|
||||||
shl ebx,7 ;multiply 128
|
shl ebx,7 ;multiply 128
|
||||||
shr ebx,12
|
shr ebx,12
|
||||||
mov [next_pixel_x],ebx
|
mov [next_pixel_x],ebx
|
||||||
;--------------------------------
|
;--------------------------------
|
||||||
jmp .ex_2
|
jmp .ex_2
|
||||||
;--------------------------------
|
;--------------------------------
|
||||||
align 4
|
align 4
|
||||||
@@:
|
@@:
|
||||||
imul eax,dword [x]
|
imul eax,dword [x]
|
||||||
mov bx,word [new_size.x1]
|
;--------------------------------
|
||||||
|
align 4
|
||||||
|
@@:
|
||||||
|
mov bx,word [new_size.x1]
|
||||||
;--------------------------------
|
;--------------------------------
|
||||||
align 4
|
align 4
|
||||||
.x_div:
|
.x_div:
|
||||||
test ebx,ebx
|
test ebx,ebx
|
||||||
jnz @f
|
jnz @f
|
||||||
inc ebx
|
inc ebx
|
||||||
align 4
|
align 4
|
||||||
@@:
|
@@:
|
||||||
xor edx,edx
|
xor edx,edx
|
||||||
div ebx
|
div ebx
|
||||||
;--------------------------------
|
;--------------------------------
|
||||||
push eax
|
push eax
|
||||||
mov eax,edx
|
mov eax,edx
|
||||||
shl eax,7 ;multiply 128
|
shl eax,7 ;multiply 128
|
||||||
xor edx,edx
|
xor edx,edx
|
||||||
div ebx
|
div ebx
|
||||||
mov [next_pixel_x],eax
|
mov [next_pixel_x],eax
|
||||||
pop eax
|
pop eax
|
||||||
;--------------------------------
|
;--------------------------------
|
||||||
align 4
|
align 4
|
||||||
.ex_2:
|
.ex_2:
|
||||||
mov edx,[bytes_to_pixel]
|
mov edx,[bytes_to_pixel]
|
||||||
mov ebx,eax
|
mov ebx,eax
|
||||||
xor eax,eax
|
xor eax,eax
|
||||||
align 4
|
align 4
|
||||||
@@:
|
@@:
|
||||||
add eax,ebx
|
add eax,ebx
|
||||||
dec edx
|
dec edx
|
||||||
jnz @r
|
jnz @r
|
||||||
|
|
||||||
mov ebx,[esp+4]
|
mov ebx,[esp+4]
|
||||||
shl ebx,3
|
shl ebx,3
|
||||||
add ebx,[area_for_x]
|
add ebx,[area_for_x]
|
||||||
mov [ebx],eax
|
mov [ebx],eax
|
||||||
mov edx,[next_pixel_x]
|
mov edx,[next_pixel_x]
|
||||||
mov [ebx+4],edx
|
mov [ebx+4],edx
|
||||||
align 4
|
align 4
|
||||||
.ex_3:
|
.ex_3:
|
||||||
mov [temp_x1],eax
|
mov [temp_x1],eax
|
||||||
add ecx,eax
|
add ecx,eax
|
||||||
align 4
|
align 4
|
||||||
.finish:
|
.finish:
|
||||||
add ecx,esi
|
add ecx,esi
|
||||||
ret
|
ret
|
||||||
;---------------------------------------------------------------------
|
;---------------------------------------------------------------------
|
||||||
align 4
|
align 4
|
||||||
.get_memory:
|
.get_memory:
|
||||||
|
xor ecx,ecx
|
||||||
|
mov cx,[new_size.x1]
|
||||||
|
shl ecx,3
|
||||||
|
mcall 68,12
|
||||||
|
mov [area_for_x],eax
|
||||||
|
|
||||||
xor ecx,ecx
|
xor ecx,ecx
|
||||||
mov cx,[new_size.x1]
|
mov ebx,[new_size]
|
||||||
shl ecx,3
|
mov cx,bx
|
||||||
mcall 68,12
|
shr ebx,16
|
||||||
mov [area_for_x],eax
|
imul ecx,ebx ;[eax+8]
|
||||||
|
mov eax,[bytes_to_pixel]
|
||||||
xor ecx,ecx
|
cmp eax,1
|
||||||
mov ebx,[new_size]
|
jne @f
|
||||||
mov cx,bx
|
mov eax,3
|
||||||
shr ebx,16
|
|
||||||
imul ecx,ebx ;[eax+8]
|
|
||||||
mov eax,[bytes_to_pixel]
|
|
||||||
cmp eax,1
|
|
||||||
jne @f
|
|
||||||
mov eax,3
|
|
||||||
@@:
|
@@:
|
||||||
imul ecx,eax
|
imul ecx,eax
|
||||||
mcall 68,12
|
mov edx,ecx
|
||||||
mov [raw_area],eax
|
add ecx,44
|
||||||
mov edi,eax
|
mov eax,[image_file]
|
||||||
|
add ecx,[eax+24] ;palette area size
|
||||||
|
mcall 68,12
|
||||||
|
mov [raw_area],eax
|
||||||
|
mov edi,eax
|
||||||
|
|
||||||
|
; create RAW header
|
||||||
|
push esi
|
||||||
|
mov esi,[image_file]
|
||||||
|
mov ecx,44/4
|
||||||
|
cld
|
||||||
|
rep movsd ;copy the 3 first dword for the structure of RAW
|
||||||
|
mov edi,[raw_area]
|
||||||
|
movzx eax,word [new_size.x1]
|
||||||
|
mov [edi+4],eax
|
||||||
|
movzx eax,word [new_size.y1]
|
||||||
|
mov [edi+8],eax
|
||||||
|
mov [edi+32],edx ;rgb area size
|
||||||
|
xor eax,eax
|
||||||
|
mov [edi+36],eax ;transparency area pointer
|
||||||
|
mov [edi+40],eax ;transparency area size
|
||||||
|
|
||||||
|
cmp [filtering],eax ;0 or 1
|
||||||
|
je @f
|
||||||
|
|
||||||
|
mov [edi+20],eax ;palette area pointer
|
||||||
|
mov [edi+24],eax ;palette area size
|
||||||
|
mov [edi+28],dword 44 ;rgb area pointer
|
||||||
|
cmp [edi+12],dword 8 ;overall depth of the pixel
|
||||||
|
ja .not_overall_depth_8
|
||||||
|
|
||||||
|
mov [edi+12],dword 24 ;overall depth of the pixel
|
||||||
|
mov [edi+16],word 8 ;channel depth of the pixel
|
||||||
|
.not_overall_depth_8:
|
||||||
|
add edi,44
|
||||||
|
jmp .end
|
||||||
|
@@:
|
||||||
|
mov eax,[edi+24]
|
||||||
|
add edi,44
|
||||||
|
test eax,eax ;palette area is present?
|
||||||
|
jz @f
|
||||||
|
|
||||||
|
sub esi,44
|
||||||
|
|
||||||
|
mov ecx,[esi+24]
|
||||||
|
shr ecx,2
|
||||||
|
add esi,[esi+20]
|
||||||
|
cld
|
||||||
|
rep movsd ;copy palette area
|
||||||
|
@@:
|
||||||
|
|
||||||
|
.end:
|
||||||
|
pop esi
|
||||||
|
|
||||||
ret
|
ret
|
||||||
;---------------------------------------------------------------------
|
;---------------------------------------------------------------------
|
||||||
include 'b_filter.inc'
|
include 'b_filter.inc'
|
||||||
;---------------------------------------------------------------------
|
;---------------------------------------------------------------------
|
||||||
align 4
|
align 4
|
||||||
EXPORTS:
|
EXPORTS:
|
||||||
dd szStart, START
|
dd szStart, START
|
||||||
dd szVersion, 0x00010002
|
dd szVersion, 0x00010003
|
||||||
dd 0
|
dd 0
|
||||||
|
|
||||||
szStart db 'START',0
|
szStart db 'START',0
|
||||||
szVersion db 'version',0
|
szVersion db 'version',0
|
||||||
@ -442,14 +496,17 @@ align 4
|
|||||||
pointer dd 0
|
pointer dd 0
|
||||||
image_file dd 0
|
image_file dd 0
|
||||||
new_size:
|
new_size:
|
||||||
.y1: dw 0
|
.y1: dw 0
|
||||||
.x1: dw 0
|
.x1: dw 0
|
||||||
|
|
||||||
x: dd 0
|
x: dd 0
|
||||||
y: dd 0
|
y: dd 0
|
||||||
|
|
||||||
|
crop_x dd 0
|
||||||
|
crop_y dd 0
|
||||||
|
|
||||||
size_x dd 0
|
size_x dd 0
|
||||||
bytes_to_pixel dd 0
|
bytes_to_pixel dd 0
|
||||||
|
|
||||||
start_coordinates:
|
start_coordinates:
|
||||||
.y dw 0
|
.y dw 0
|
||||||
@ -457,31 +514,31 @@ start_coordinates:
|
|||||||
|
|
||||||
scaling_mode dd 0
|
scaling_mode dd 0
|
||||||
raw_area dd 0
|
raw_area dd 0
|
||||||
scaling_delta dd 0
|
scaling_delta dd 0
|
||||||
|
|
||||||
area_for_x dd 0
|
area_for_x dd 0
|
||||||
|
|
||||||
temp_y dd 0
|
temp_y dd 0
|
||||||
temp_y_offset dd 0
|
temp_y_offset dd 0
|
||||||
|
|
||||||
resolution dd 0
|
resolution dd 0
|
||||||
|
|
||||||
filtering dd 0
|
filtering dd 0
|
||||||
|
|
||||||
next_pixel_y dd 0
|
next_pixel_y dd 0
|
||||||
next_pixel_x dd 0
|
next_pixel_x dd 0
|
||||||
|
|
||||||
temp_y1 dd 0
|
temp_y1 dd 0
|
||||||
temp_x1 dd 0
|
temp_x1 dd 0
|
||||||
|
|
||||||
B_sample dd 0
|
B_sample dd 0
|
||||||
G_sample dd 0
|
G_sample dd 0
|
||||||
R_sample dd 0
|
R_sample dd 0
|
||||||
|
|
||||||
B_sample_1 dd 0
|
B_sample_1 dd 0
|
||||||
G_sample_1 dd 0
|
G_sample_1 dd 0
|
||||||
R_sample_1 dd 0
|
R_sample_1 dd 0
|
||||||
|
|
||||||
palette dd 0
|
palette dd 0
|
||||||
|
|
||||||
background_color dd 0
|
background_color dd 0
|
@ -44,9 +44,23 @@ thread4: ; start of bgrd thread
|
|||||||
jmp .still
|
jmp .still
|
||||||
;---------------------------------------------------------------------
|
;---------------------------------------------------------------------
|
||||||
@@:
|
@@:
|
||||||
|
cmp [option_group1],op2
|
||||||
|
jne @f
|
||||||
mov [bgrmode],dword 2
|
mov [bgrmode],dword 2
|
||||||
jmp .still
|
jmp .still
|
||||||
;---------------------------------------------------------------------
|
;---------------------------------------------------------------------
|
||||||
|
@@:
|
||||||
|
cmp [option_group1],op3
|
||||||
|
jne @f
|
||||||
|
mov [bgrmode],dword 3
|
||||||
|
jmp .still
|
||||||
|
;---------------------------------------------------------------------
|
||||||
|
@@:
|
||||||
|
; cmp [option_group1],op4
|
||||||
|
; jne .still
|
||||||
|
mov [bgrmode],dword 4
|
||||||
|
jmp .still
|
||||||
|
;---------------------------------------------------------------------
|
||||||
.key:
|
.key:
|
||||||
mcall
|
mcall
|
||||||
cmp ah,27
|
cmp ah,27
|
||||||
|
@ -77,6 +77,7 @@ thread2: ; start of info thread
|
|||||||
|
|
||||||
add edx,10
|
add edx,10
|
||||||
mcall ,,[Total_Repeat_N]
|
mcall ,,[Total_Repeat_N]
|
||||||
|
|
||||||
; mcall 47,0x80000,[PID2],<200, 5>,0xffffff
|
; mcall 47,0x80000,[PID2],<200, 5>,0xffffff
|
||||||
; mcall 47,0x800a0000,[error_locate],<140,5>,0x10ffffff
|
; mcall 47,0x800a0000,[error_locate],<140,5>,0x10ffffff
|
||||||
mcall 12,2
|
mcall 12,2
|
||||||
|
@ -25,7 +25,7 @@
|
|||||||
; (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
|
; (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
|
||||||
; SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
; SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
||||||
;*****************************************************************************
|
;*****************************************************************************
|
||||||
; v.1.0 rń3 24.08.2011
|
; v.1.0 rń4 07.09.2011
|
||||||
;******************************************************************************
|
;******************************************************************************
|
||||||
use32
|
use32
|
||||||
org 0x0
|
org 0x0
|
||||||
|
@ -40,11 +40,11 @@ rotate_counter_clockwise:
|
|||||||
push dword image_file
|
push dword image_file
|
||||||
; call [plugin_rotate]
|
; call [plugin_rotate]
|
||||||
call [rotate_Start]
|
call [rotate_Start]
|
||||||
mov ebx,[raw_pointer]
|
mov ebx,[raw_pointer]
|
||||||
mov eax,[ebx+4]
|
mov eax,[ebx+4]
|
||||||
mov [img_width],eax
|
mov [img_width],eax
|
||||||
mov eax,[ebx+8]
|
mov eax,[ebx+8]
|
||||||
mov [img_high],eax
|
mov [img_high],eax
|
||||||
call convert.img_resolution_ok
|
call convert.img_resolution_ok
|
||||||
jmp kopen.1
|
jmp kopen.1
|
||||||
;---------------------------------------------------------------------
|
;---------------------------------------------------------------------
|
||||||
@ -67,10 +67,6 @@ no_scaling:
|
|||||||
mov [zoom_factors],dword zoom_factors.100
|
mov [zoom_factors],dword zoom_factors.100
|
||||||
mov eax,[eax]
|
mov eax,[eax]
|
||||||
jmp zoom_plus.2
|
jmp zoom_plus.2
|
||||||
|
|
||||||
; call calculate_arrows_offset
|
|
||||||
; call draw_zoom_factors
|
|
||||||
; jmp red
|
|
||||||
;---------------------------------------------------------------------
|
;---------------------------------------------------------------------
|
||||||
scaling:
|
scaling:
|
||||||
mov eax,[soi]
|
mov eax,[soi]
|
||||||
@ -114,10 +110,6 @@ scaling:
|
|||||||
.fill_for_L_R:
|
.fill_for_L_R:
|
||||||
cmp [no_fill],1
|
cmp [no_fill],1
|
||||||
je @f
|
je @f
|
||||||
; xor eax,eax
|
|
||||||
; mov [no_fill],al
|
|
||||||
; ret
|
|
||||||
;@@:
|
|
||||||
pusha
|
pusha
|
||||||
mov ebx,[image_start_coordinates]
|
mov ebx,[image_start_coordinates]
|
||||||
mov ecx,ebx
|
mov ecx,ebx
|
||||||
@ -130,7 +122,6 @@ scaling:
|
|||||||
add bx,ax
|
add bx,ax
|
||||||
add bx,[wa_width_2]
|
add bx,[wa_width_2]
|
||||||
mov ax,[wa_width_1]
|
mov ax,[wa_width_1]
|
||||||
; add ax,5
|
|
||||||
sub ax,bx
|
sub ax,bx
|
||||||
rol ebx,16
|
rol ebx,16
|
||||||
mov bx,ax
|
mov bx,ax
|
||||||
@ -142,10 +133,6 @@ scaling:
|
|||||||
.fill_for_U_D:
|
.fill_for_U_D:
|
||||||
cmp [no_fill],1
|
cmp [no_fill],1
|
||||||
je @f
|
je @f
|
||||||
; xor eax,eax
|
|
||||||
; mov [no_fill],al
|
|
||||||
; ret
|
|
||||||
;@@:
|
|
||||||
pusha
|
pusha
|
||||||
mov ebx,[image_start_coordinates]
|
mov ebx,[image_start_coordinates]
|
||||||
mov ecx,ebx
|
mov ecx,ebx
|
||||||
@ -222,12 +209,13 @@ scaling:
|
|||||||
movzx esi,byte [filtering_flag]
|
movzx esi,byte [filtering_flag]
|
||||||
; mov edi,[background_color]
|
; mov edi,[background_color]
|
||||||
|
|
||||||
push dword [background_color] ;edi - background color
|
push dword 0 ; eax - crop size
|
||||||
push esi ; esi - filtering
|
push dword [background_color] ; edi - background color
|
||||||
push dword [scaling_mode] ;edx - scaling mode
|
push esi ; esi - filtering
|
||||||
push ecx ; ecx - start_coordinates
|
push dword [scaling_mode] ; edx - scaling mode
|
||||||
push ebx ; ebx - new_size
|
push ecx ; ecx - start_coordinates
|
||||||
push dword image_file ;eax - convert data table
|
push ebx ; ebx - new_size
|
||||||
|
push dword image_file ; eax - convert data table
|
||||||
|
|
||||||
; pusha
|
; pusha
|
||||||
; mcall 26,9
|
; mcall 26,9
|
||||||
@ -255,16 +243,16 @@ scaling:
|
|||||||
|
|
||||||
mov edx,[image_start_coordinates]
|
mov edx,[image_start_coordinates]
|
||||||
|
|
||||||
mov eax,edx
|
mov eax,edx
|
||||||
shl eax,16
|
shl eax,16
|
||||||
mov ax,cx
|
mov ax,cx
|
||||||
mov [scroll_bar_data_vertical.y],eax
|
mov [scroll_bar_data_vertical.y],eax
|
||||||
|
|
||||||
mov eax,edx
|
mov eax,edx
|
||||||
mov ebx,ecx
|
mov ebx,ecx
|
||||||
shr ebx,16
|
shr ebx,16
|
||||||
mov ax,bx
|
mov ax,bx
|
||||||
mov [scroll_bar_data_horizontal.x],eax
|
mov [scroll_bar_data_horizontal.x],eax
|
||||||
|
|
||||||
; call correct_cur_area
|
; call correct_cur_area
|
||||||
|
|
||||||
@ -297,18 +285,24 @@ scaling:
|
|||||||
add edx,eax
|
add edx,eax
|
||||||
call .fill_for_U_D
|
call .fill_for_U_D
|
||||||
@@:
|
@@:
|
||||||
mov esi,[img_resolution]
|
; mov esi,[img_resolution]
|
||||||
cmp [img_resolution_2],15
|
; cmp [img_resolution_2],15
|
||||||
jne @f
|
; jne @f
|
||||||
mov esi,15
|
; mov esi,15
|
||||||
@@:
|
;@@:
|
||||||
|
mov eax,[raw_pointer_2]
|
||||||
|
mov esi,[eax+12]
|
||||||
|
|
||||||
mov eax,[raw_pointer]
|
mov eax,[raw_pointer]
|
||||||
mov edi,[eax+20]
|
mov edi,[eax+20]
|
||||||
add edi,eax
|
add edi,eax
|
||||||
; mov edi,[img_palette]
|
; mov edi,[img_palette]
|
||||||
|
|
||||||
xor ebp,ebp
|
xor ebp,ebp
|
||||||
|
|
||||||
mov ebx,[raw_pointer_2]
|
mov ebx,[raw_pointer_2]
|
||||||
|
mov eax,[ebx+28]
|
||||||
|
add ebx,eax
|
||||||
|
|
||||||
mov eax,ecx
|
mov eax,ecx
|
||||||
test ax,ax
|
test ax,ax
|
||||||
@ -317,12 +311,12 @@ scaling:
|
|||||||
test eax,eax
|
test eax,eax
|
||||||
jz .no_draw ;@f
|
jz .no_draw ;@f
|
||||||
|
|
||||||
cmp [filtering_flag],0
|
; cmp [filtering_flag],0
|
||||||
je @f
|
; je @f
|
||||||
cmp esi,8
|
; cmp esi,8
|
||||||
jne @f
|
; jne @f
|
||||||
mov esi,24
|
; mov esi,24
|
||||||
@@:
|
;@@:
|
||||||
mcall 65
|
mcall 65
|
||||||
.no_draw:
|
.no_draw:
|
||||||
; mov eax,ecx
|
; mov eax,ecx
|
||||||
@ -341,36 +335,42 @@ scaling:
|
|||||||
; and eax,0xffff
|
; and eax,0xffff
|
||||||
; mov [test4],eax
|
; mov [test4],eax
|
||||||
|
|
||||||
push ebx
|
|
||||||
call draw_file_name_to_work_area
|
call draw_file_name_to_work_area
|
||||||
pop ebx
|
mcall 68,13,[raw_pointer_2]
|
||||||
mov ecx,ebx ;[raw_pointer_2]
|
|
||||||
mcall 68,13
|
|
||||||
|
|
||||||
|
|
||||||
xor eax,eax
|
xor eax,eax
|
||||||
mov ax,[wa_width_2]
|
mov ax,[wa_width_2]
|
||||||
; imul eax,100
|
|
||||||
; ÅÀÕ = ÅÀÕ * 100
|
|
||||||
shl eax,2 ; óìíîæåíèå íà 4
|
|
||||||
lea eax,[eax+eax*4] ; óìíîæåíèå íà 5
|
|
||||||
lea eax,[eax+eax*4] ; óìíîæåíèå íà 5
|
|
||||||
mov ebx,[img_width]
|
mov ebx,[img_width]
|
||||||
test ebx,ebx
|
; imul eax,100
|
||||||
jnz @f
|
call calculate_relation
|
||||||
inc ebx
|
|
||||||
@@:
|
|
||||||
xor edx,edx
|
|
||||||
div ebx
|
|
||||||
shl edx,1
|
|
||||||
cmp ebx,edx
|
|
||||||
jb @f
|
|
||||||
inc eax
|
|
||||||
@@:
|
|
||||||
mov [zoom_auto_factor],eax
|
mov [zoom_auto_factor],eax
|
||||||
|
|
||||||
ret
|
ret
|
||||||
;---------------------------------------------------------------------
|
;---------------------------------------------------------------------
|
||||||
|
calculate_relation:
|
||||||
|
; relation = X*100/Y
|
||||||
|
; eax = eax*100/ebx
|
||||||
|
; ÅÀÕ = ÅÀÕ * 100
|
||||||
|
shl eax,2 ; óìíîæåíèå íà 4
|
||||||
|
lea eax,[eax+eax*4] ; óìíîæåíèå íà 5
|
||||||
|
lea eax,[eax+eax*4] ; óìíîæåíèå íà 5
|
||||||
|
integer_division:
|
||||||
|
; eax = eax/ebx
|
||||||
|
test ebx,ebx
|
||||||
|
jnz @f
|
||||||
|
inc ebx
|
||||||
|
@@:
|
||||||
|
xor edx,edx
|
||||||
|
div ebx
|
||||||
|
; shl edx,1
|
||||||
|
; cmp ebx,edx
|
||||||
|
; jb @f
|
||||||
|
; inc eax
|
||||||
|
;@@:
|
||||||
|
ret
|
||||||
|
;---------------------------------------------------------------------
|
||||||
calculation_next_value_plus:
|
calculation_next_value_plus:
|
||||||
mov ebx,[zoom_auto_factor]
|
mov ebx,[zoom_auto_factor]
|
||||||
mov ecx,zoom_factors.min
|
mov ecx,zoom_factors.min
|
||||||
|
Loading…
Reference in New Issue
Block a user