forked from KolibriOS/kolibrios
5620ba7561
git-svn-id: svn://kolibrios.org@871 a494cfbc-eb01-0410-851d-a64ba20cac60
1017 lines
19 KiB
PHP
1017 lines
19 KiB
PHP
func color_24_to_4_bits
|
|
begin
|
|
push edx
|
|
mov dl,0
|
|
cmp al,85 ; blue
|
|
jbe .p13green
|
|
or dl,0x01
|
|
cmp al,170
|
|
jbe .p13green
|
|
or dl,0x08
|
|
.p13green:
|
|
shr eax,8
|
|
cmp al,85 ; green
|
|
jbe .p13red
|
|
or dl,0x02
|
|
cmp al,170
|
|
jbe .p13red
|
|
or dl,0x08
|
|
.p13red:
|
|
cmp ah,85 ; red
|
|
jbe .p13cont
|
|
or dl,0x04
|
|
cmp ah,170
|
|
jbe .p13cont
|
|
or dl,0x08
|
|
.p13cont:
|
|
mov eax,edx
|
|
pop edx
|
|
ret
|
|
endf
|
|
|
|
;-----------------------------------------------------------------------------
|
|
func vm_mike_draw_rect.04 ;///////////////////////////////////////////////////
|
|
;-----------------------------------------------------------------------------
|
|
; eax - x start
|
|
; ebx - y start
|
|
; ecx - x end
|
|
; edx - y end
|
|
; edi - color
|
|
;-----------------------------------------------------------------------------
|
|
;- eax(ebx) [x start]*65536 + [x size]
|
|
;- ebx(ecx) [y start]*65536 + [y size]
|
|
;- ecx(edx) color 0x00RRGGBB
|
|
;-----------------------------------------------------------------------------
|
|
begin
|
|
pushad
|
|
cli
|
|
jif eax,e,ecx,.exit
|
|
jif ebx,e,edx,.exit
|
|
|
|
call get_cursor_rect
|
|
|
|
push eax
|
|
mov eax,edi
|
|
call color_24_to_4_bits
|
|
mov edi,eax
|
|
pop eax
|
|
|
|
mov ebp,[TASK_BASE]
|
|
movsx esi,word[ebp-CURRENT_TASK+0]
|
|
add eax,esi
|
|
add ecx,esi
|
|
movsx esi,word[ebp-CURRENT_TASK+4]
|
|
add ebx,esi
|
|
add edx,esi
|
|
; add eax,[ebp-CURRENT_TASK+0]
|
|
; add ebx,[ebp-CURRENT_TASK+4]
|
|
; add ecx,[ebp-CURRENT_TASK+0]
|
|
; add edx,[ebp-CURRENT_TASK+4]
|
|
|
|
mov esi,[CURRENT_TASK]
|
|
mov esi,[CLIP_RECTS+esi*4]
|
|
mov ebp,[esi]
|
|
or ebp,ebp
|
|
jz .exit
|
|
add esi,4
|
|
.nx: jif ecx,le,[rr.left],.skip
|
|
jif eax,ge,[rr.right],.skip
|
|
jif edx,le,[rr.top],.skip
|
|
jif ebx,ge,[rr.bottom],.skip
|
|
pushad
|
|
jif eax,ge,[rr.left],@f
|
|
mov eax,[rr.left]
|
|
@@: jif ebx,ge,[rr.top],@f
|
|
mov ebx,[rr.top]
|
|
@@: jif ecx,l,[rr.right],@f
|
|
mov ecx,[rr.right]
|
|
@@: jif edx,l,[rr.bottom],@f
|
|
mov edx,[rr.bottom]
|
|
@@: call is_intersect_rc
|
|
jc .put
|
|
cmp byte[MOUSE_VISIBLE],0
|
|
je .put
|
|
call [SF.draw_mouse_under]
|
|
mov byte[MOUSE_VISIBLE],0
|
|
.put: sub edx,ebx
|
|
push edx edi ebx eax
|
|
mov edi,ebx
|
|
shl edi,6
|
|
shl ebx,4
|
|
add edi,ebx
|
|
shr eax,3
|
|
add edi,eax
|
|
add edi,VGABasePtr
|
|
pop eax ebx
|
|
|
|
mov ebx,eax
|
|
mov esi,ecx
|
|
sub esi,eax
|
|
mov dx,0x03CE
|
|
|
|
;edi = Offset in VMem
|
|
;esi = Length
|
|
;ebx = x
|
|
; dx = Graphix Controller
|
|
|
|
mov cl,bl ; Get StartBit
|
|
and ecx,07h
|
|
|
|
mov eax,esi
|
|
add eax,ecx
|
|
cmp eax,8 ; Is x+Length<One Byte
|
|
jb .D_One
|
|
|
|
mov ax,0xff08 ; 11111111b | BitMask Register
|
|
shr ah,cl ; BitMask
|
|
out dx,ax ; Write BitMask
|
|
push ecx
|
|
mov ah,[esp+4]
|
|
mov ecx,[esp+4+4]
|
|
push edi
|
|
.D_LL: ; Draw Left of Box
|
|
mov al,[edi]
|
|
mov [edi],ah
|
|
add edi,80 ; edi:=edi+80
|
|
dec ecx
|
|
jnz .D_LL
|
|
pop edi
|
|
inc edi
|
|
pop ecx
|
|
|
|
mov ax,0xFF08 ; BitMask Register
|
|
out dx,ax ; Write BitMask
|
|
|
|
mov eax,esi
|
|
mov ch,8
|
|
sub ch,cl
|
|
movzx ecx,ch
|
|
sub eax,ecx
|
|
shr eax,3 ; Length div 8
|
|
|
|
push edi ebx
|
|
mov ebx,[esp+8+4]
|
|
mov edx,eax
|
|
mov al,[esp+8]
|
|
.D_LC:
|
|
mov ecx,edx
|
|
rep stosb
|
|
add edi,80
|
|
sub edi,edx
|
|
dec ebx
|
|
jnz .D_LC
|
|
pop ebx edi
|
|
add edi,edx
|
|
|
|
mov ecx,ebx ; ecx:=x+Length
|
|
add ecx,esi
|
|
and ecx,07h ; ecx and 07
|
|
mov ah,0ffh
|
|
shr ah,cl ; BitMask
|
|
jz .D_End
|
|
|
|
not ah
|
|
mov al,8 ; BitMask Register
|
|
mov dx,03ceh ; Graphics Controller
|
|
out dx,ax ; Write BitMask
|
|
mov ecx,[esp+4]
|
|
mov al,[esp]
|
|
.D_LR:
|
|
mov ah,[edi]
|
|
mov [edi],al
|
|
add edi,80
|
|
dec ecx
|
|
jnz .D_LR
|
|
|
|
jmp .D_End
|
|
|
|
.D_One:
|
|
mov ah,0ffh
|
|
shr ah,cl ; Left BitMask
|
|
|
|
add ebx,esi
|
|
dec ebx
|
|
and ebx,07h
|
|
|
|
mov ecx,7
|
|
sub ecx,ebx
|
|
|
|
mov bl,0ffh
|
|
shl bl,cl ; Right BitMask
|
|
|
|
and ah,bl ; Full BitMask
|
|
mov al,8 ; BitMask Register
|
|
out dx,ax ; Write BitMask
|
|
mov ecx,[esp+4]
|
|
mov al,[esp]
|
|
.D_L:
|
|
mov dl,[edi] ; Fill Latches
|
|
mov [edi],al ; Write Pixel
|
|
add edi,80
|
|
dec ecx
|
|
jnz .D_L
|
|
.D_End:
|
|
pop edi
|
|
add esp,4
|
|
popad
|
|
.skip:
|
|
add esi,SR
|
|
dec ebp
|
|
jnz .nx
|
|
|
|
.exit:
|
|
sti
|
|
popad
|
|
retn
|
|
endf
|
|
|
|
;-----------------------------------------------------------------------------
|
|
func vm_mike_draw_line.04 ;///////////////////////////////////////////////////
|
|
;-----------------------------------------------------------------------------
|
|
; eax(ebx) [x start] shl 16 + [x end]
|
|
; ebx(ecx) [y start] shl 16 + [y end]
|
|
; ecx(edx) colour 0x00RRGGBB
|
|
; edi = 0x00000001 force
|
|
;-----------------------------------------------------------------------------
|
|
begin
|
|
push 0
|
|
pushad
|
|
cli
|
|
|
|
test ecx,0x01000000
|
|
jnz .exit
|
|
|
|
call get_cursor_rect
|
|
|
|
mov eax,ecx
|
|
call color_24_to_4_bits
|
|
; mov [esp+4*8],ecx
|
|
mov [esp+4*8],al
|
|
|
|
movsx eax,word[esp+4*7] ; x end
|
|
cmp ax,[esp+4*7+2] ; x start
|
|
je dl.vert_line
|
|
movsx eax,word[esp+4*4] ; y end
|
|
cmp ax,[esp+4*4+2] ; y start
|
|
je dl.horz_line
|
|
|
|
.exit:
|
|
sti
|
|
popad
|
|
add esp,4
|
|
retn
|
|
|
|
dl.vert_line:
|
|
push eax
|
|
mov cl,al
|
|
and cl,7
|
|
mov ax,0x8008
|
|
shr ah,cl
|
|
mov dx,0x03CE
|
|
out dx,ax
|
|
pop eax
|
|
mov ecx,[esp+4*8]
|
|
|
|
test edi,1
|
|
jnz .forced
|
|
mov esi,[CURRENT_TASK]
|
|
mov esi,[CLIP_RECTS+esi*4]
|
|
mov edi,[esi]
|
|
or edi,edi
|
|
jz .exit
|
|
add esi,4
|
|
.nx: movsx ebx,word[esp+4*4+2] ; y start
|
|
movsx edx,word[esp+4*4] ; y end
|
|
cmp ebx,edx
|
|
je .exit
|
|
jl @f
|
|
xchg ebx,edx
|
|
@@: jif eax,l,[rr.left],.skip
|
|
jif eax,ge,[rr.right],.skip
|
|
jif edx,l,[rr.top],.skip
|
|
jif ebx,ge,[rr.bottom],.skip
|
|
jif ebx,ge,[rr.top],@f
|
|
mov ebx,[rr.top]
|
|
@@: jif edx,l,[rr.bottom],@f
|
|
mov edx,[rr.bottom]
|
|
dec edx
|
|
.draw:
|
|
@@: call is_intersect_vln
|
|
jc .put
|
|
cmp byte[MOUSE_VISIBLE],0
|
|
je .put
|
|
call [SF.draw_mouse_under]
|
|
mov byte[MOUSE_VISIBLE],0
|
|
.put: push ebx eax
|
|
mov ebp,ebx
|
|
shl ebp,6
|
|
shl ebx,4
|
|
add ebp,ebx
|
|
shr eax,3
|
|
add ebp,eax
|
|
add ebp,VGABasePtr
|
|
pop eax ebx
|
|
@@: mov ch,[ebp]
|
|
mov [ebp],cl
|
|
add ebp,80
|
|
inc ebx
|
|
cmp ebx,edx
|
|
jle @b
|
|
.skip:
|
|
add esi,SR
|
|
dec edi
|
|
jnz .nx
|
|
.exit:
|
|
sti
|
|
popad
|
|
add esp,4
|
|
retn
|
|
.forced:
|
|
jif eax,l,[viewport.left],.exit
|
|
jif eax,ge,[viewport.right],.exit
|
|
movsx ebx,word[esp+4*4+2] ; y start
|
|
movsx edx,word[esp+4*4] ; y end
|
|
jif ebx,e,edx,.exit
|
|
jl @f
|
|
xchg ebx,edx
|
|
@@: jif edx,l,[viewport.top],.exit
|
|
jif ebx,ge,[viewport.bottom],.exit
|
|
jif ebx,ge,[viewport.top],@f
|
|
mov ebx,[viewport.top]
|
|
@@: jif edx,l,[viewport.bottom],@f
|
|
mov edx,[viewport.bottom]
|
|
dec edx
|
|
@@: mov edi,1
|
|
jmp .draw
|
|
|
|
dl.horz_line:
|
|
cld
|
|
mov ecx,[esp+4*8]
|
|
test edi,1
|
|
jnz .forced
|
|
mov esi,[CURRENT_TASK]
|
|
mov esi,[CLIP_RECTS+esi*4]
|
|
mov edi,[esi]
|
|
or edi,edi
|
|
jz .exit
|
|
add esi,4
|
|
.nx: movsx ebx,word[esp+4*7+2] ; x start
|
|
movsx edx,word[esp+4*7] ; x end
|
|
cmp ebx,edx
|
|
je .exit
|
|
jl @f
|
|
xchg ebx,edx
|
|
@@: jif eax,l,[rr.top],.skip
|
|
jif eax,ge,[rr.bottom],.skip
|
|
jif edx,l,[rr.left],.skip
|
|
jif ebx,ge,[rr.right],.skip
|
|
jif ebx,ge,[rr.left],@f
|
|
mov ebx,[rr.left]
|
|
@@: jif edx,l,[rr.right],@f
|
|
mov edx,[rr.right]
|
|
dec edx
|
|
.draw:
|
|
@@: call is_intersect_hln
|
|
jc .put
|
|
cmp byte[MOUSE_VISIBLE],0
|
|
je .put
|
|
call [SF.draw_mouse_under]
|
|
mov byte[MOUSE_VISIBLE],0
|
|
.put: push edi ebx eax
|
|
mov edi,eax
|
|
shl edi,6
|
|
shl eax,4
|
|
add edi,eax
|
|
shr ebx,3
|
|
add edi,ebx
|
|
add edi,VGABasePtr
|
|
pop eax ebx
|
|
|
|
push eax ebx edx esi ecx
|
|
mov esi,edx
|
|
sub esi,ebx
|
|
inc esi
|
|
mov dx,0x03CE
|
|
;edi = Offset in VMem
|
|
;esi = Length
|
|
;ebx = x
|
|
; dx = Graphix Controller
|
|
mov cl,bl ; Get StartBit
|
|
and ecx,07h
|
|
|
|
mov eax,esi
|
|
add eax,ecx
|
|
cmp eax,8 ; Is x+Length<One Byte
|
|
jb .D_One
|
|
|
|
mov ax,0xFF08 ; 11111111b | BitMask Register
|
|
shr ah,cl ; BitMask
|
|
out dx,ax ; Write BitMask
|
|
mov al,[edi]
|
|
mov eax,[esp]
|
|
mov [edi],al
|
|
inc edi
|
|
|
|
mov ax,0xFF08 ; BitMask | BitMask Register
|
|
out dx,ax ; Write BitMask
|
|
|
|
mov eax,esi
|
|
mov ch,8
|
|
sub ch,cl
|
|
mov cl,ch
|
|
xor ch,ch
|
|
sub eax,ecx
|
|
shr eax,3 ; Length div 8
|
|
mov ecx,eax
|
|
mov eax,[esp]
|
|
rep stosb
|
|
|
|
mov ecx,ebx ; ecx:=x+Length
|
|
add ecx,esi
|
|
and ecx,07h ; ecx and 07
|
|
mov ah,0ffh
|
|
shr ah,cl ; BitMask
|
|
jz .D_End
|
|
|
|
not ah
|
|
mov al,8 ; BitMask Register
|
|
out dx,ax ; Write BitMask
|
|
mov cl,[edi]
|
|
mov eax,[esp]
|
|
mov [edi],al
|
|
jmp .D_End
|
|
|
|
.D_One:
|
|
mov ax,0xff08 ; | BitMask Register
|
|
shr ah,cl ; Left BitMask
|
|
|
|
add ebx,esi
|
|
dec ebx
|
|
and ebx,07h
|
|
|
|
mov ecx,7
|
|
sub ecx,ebx
|
|
|
|
mov bl,0ffh
|
|
shl bl,cl ; Right BitMask
|
|
|
|
and ah,bl ; Full BitMask
|
|
out dx,ax ; Write BitMask
|
|
|
|
mov dl,[edi] ; Fill Latches
|
|
mov eax,[esp]
|
|
mov [edi],al ; Write Pixel
|
|
.D_End:
|
|
pop ecx esi edx ebx eax edi
|
|
|
|
; mov ebp,[BytesPerScanLine]
|
|
; imul ebp,eax
|
|
; lea ebp,[ebp+ebx*4]
|
|
; add ebp,[LFBAddress]
|
|
; @@: test ecx,0x01000000
|
|
; jz .dr
|
|
; mov ecx,[ebp]
|
|
; not ecx
|
|
; or ecx,0x01000000
|
|
; .dr: mov [ebp],ecx
|
|
; add ebp,4
|
|
; inc ebx
|
|
; cmp ebx,edx
|
|
; jle @b
|
|
.skip:
|
|
add esi,SR
|
|
dec edi
|
|
jnz .nx
|
|
.exit:
|
|
sti
|
|
popad
|
|
add esp,4
|
|
retn
|
|
.forced:
|
|
jif eax,l,[viewport.top],.exit
|
|
jif eax,ge,[viewport.bottom],.exit
|
|
movsx ebx,word[esp+4*7+2] ; x start
|
|
movsx edx,word[esp+4*7] ; x end
|
|
cmp ebx,edx
|
|
je .exit
|
|
jl @f
|
|
xchg ebx,edx
|
|
@@: jif edx,l,[viewport.left],.exit
|
|
jif ebx,ge,[viewport.right],.exit
|
|
jif ebx,ge,[viewport.left],@f
|
|
mov ebx,[viewport.left]
|
|
@@: jif edx,l,[viewport.right],@f
|
|
mov edx,[viewport.right]
|
|
dec edx
|
|
@@: mov edi,1
|
|
jmp .draw
|
|
endf
|
|
|
|
;-----------------------------------------------------------------------------
|
|
func vm_mike_put_pixel.04 ;///////////////////////////////////////////////////
|
|
;-----------------------------------------------------------------------------
|
|
; eax = x coordinate
|
|
; ebx = y coordinate
|
|
; ecx = ?? RR GG BB ; 0x01000000 negation
|
|
; edi = 0x00000001 force
|
|
;-----------------------------------------------------------------------------
|
|
begin
|
|
pushad
|
|
cli
|
|
; mov edx,[BytesPerScanLine]
|
|
; imul edx,ebx
|
|
; lea edx,[edx+eax*4]
|
|
; add edx,[LFBAddress]
|
|
; test ecx,0x01000000
|
|
; jz @f
|
|
; mov ecx,[edx]
|
|
; not ecx
|
|
@@: test edi,1
|
|
jnz .forced
|
|
mov esi,[CURRENT_TASK]
|
|
mov esi,[CLIP_RECTS+esi*4]
|
|
mov edi,[esi]
|
|
or edi,edi
|
|
jz .exit
|
|
add esi,4
|
|
@@: jif eax,l,[rr.left],.skip
|
|
jif eax,ge,[rr.right],.skip
|
|
jif ebx,l,[rr.top],.skip
|
|
jif ebx,ge,[rr.bottom],.skip
|
|
call get_cursor_rect
|
|
call is_intersect_pt
|
|
jc .put
|
|
cmp byte[MOUSE_VISIBLE],0
|
|
je .put
|
|
call [SF.draw_mouse_under]
|
|
mov byte[MOUSE_VISIBLE],0
|
|
.put:;mov [edx],ecx
|
|
; mov ax,SegA000 {Calculate Offset}
|
|
; mov es,ax
|
|
; mov bx,[y]
|
|
mov edi,ebx
|
|
shl edi,6 ; 80*y
|
|
shl ebx,4
|
|
add edi,ebx
|
|
|
|
push ecx
|
|
mov cl,al
|
|
shr eax,3 ; /8
|
|
add edi,eax ; 80*y + (x/8)
|
|
|
|
and cl,7 ; Get Bit that Changes
|
|
mov ax,0x8008
|
|
shr ah,cl
|
|
mov dx,0x03CE
|
|
out dx,ax
|
|
add edi,VGABasePtr
|
|
|
|
call color_24_to_4_bits
|
|
mov ah,[edi] ; dummy read
|
|
mov [edi],al
|
|
|
|
.exit:
|
|
sti
|
|
popad
|
|
retn
|
|
.skip:
|
|
add esi,SR
|
|
dec edi
|
|
jnz @b
|
|
jmp .exit
|
|
.forced:
|
|
jif eax,l,[viewport.left],.exit
|
|
jif ebx,l,[viewport.top],.exit
|
|
jif eax,ge,[viewport.right],.exit
|
|
jif ebx,ge,[viewport.bottom],.exit
|
|
|
|
; mov ax,SegA000 {Calculate Offset}
|
|
; mov es,ax
|
|
; mov bx,[y]
|
|
mov edi,ebx
|
|
shl edi,6 ; 80*y
|
|
shl ebx,4
|
|
add edi,ebx
|
|
|
|
push ecx
|
|
mov cl,al
|
|
shr eax,3 ; /8
|
|
add edi,eax ; 80*y + (x/8)
|
|
|
|
and cl,7 ; Get Bit that Changes
|
|
mov ax,0x8008
|
|
shr ah,cl
|
|
mov dx,0x03CE
|
|
out dx,ax
|
|
add edi,VGABasePtr
|
|
|
|
pop eax
|
|
call color_24_to_4_bits
|
|
mov ah,[edi] ; dummy read
|
|
mov [edi],al
|
|
|
|
sti
|
|
popad
|
|
retn
|
|
endf
|
|
|
|
;-----------------------------------------------------------------------------
|
|
func vm_mike_get_pixel.04 ;///////////////////////////////////////////////////
|
|
;-----------------------------------------------------------------------------
|
|
; eax = x coordinate
|
|
; ebx = y coordinate
|
|
;-----------------------------------------------------------------------------
|
|
|
|
clr_table dd \
|
|
0x00000000,0x00000080,0x00008000,0x00008080,\
|
|
0x00800000,0x00800080,0x00808000,0x00808080,\
|
|
0x00CCCCCC,0x000000FF,0x0000FF00,0x0000FFFF,\
|
|
0x00FF0000,0x00FF00FF,0x00FFFF00,0x00FFFFFF
|
|
|
|
begin
|
|
pushad
|
|
cli
|
|
|
|
mov edi,ebx
|
|
shl edi,6 ; 80*y
|
|
shl ebx,4
|
|
add edi,ebx
|
|
mov cl,al
|
|
shr eax,3 ; /8
|
|
add edi,eax ; 80*y + (x/8)
|
|
add edi,VGABasePtr
|
|
|
|
and ecx,7
|
|
neg ecx
|
|
add cl,7
|
|
mov dx,0x03CE
|
|
xor bl,bl
|
|
mov ah,3
|
|
@1:
|
|
mov al,4
|
|
out dx,al
|
|
inc dx
|
|
mov al,ah
|
|
out dx,al
|
|
dec dx
|
|
mov al,[edi]
|
|
shr al,cl
|
|
and al,1
|
|
xchg cl,ah
|
|
shl al,cl
|
|
xchg cl,ah
|
|
or bl,al
|
|
dec ah
|
|
jns @1
|
|
|
|
and ebx,0x0000000F
|
|
mov eax,[ebx*4+clr_table]
|
|
mov [esp+4*6],eax
|
|
|
|
sti
|
|
popad
|
|
retn
|
|
endf
|
|
|
|
;-----------------------------------------------------------------------------
|
|
func vm_mike_put_image.04 ;///////////////////////////////////////////////////
|
|
;-----------------------------------------------------------------------------
|
|
; eax(ebx) pointer to image in memory - RRGGBBRRGGBB..
|
|
; ebx(ecx) image size [x]*65536+[y]
|
|
; ecx(edx) image position in window [x]*65536+[y]
|
|
; ret: eax 0 succesful, 1 overlapped
|
|
;-----------------------------------------------------------------------------
|
|
begin
|
|
mov eax,ebx
|
|
mov ebx,ecx
|
|
mov ecx,edx
|
|
.direct:
|
|
pushad
|
|
cli
|
|
jif ebx,z,0x0000FFFF,.exit,test
|
|
jif ebx,z,0xFFFF0000,.exit,test
|
|
|
|
cld
|
|
|
|
call get_cursor_rect
|
|
|
|
mov ebp,eax
|
|
movsx eax,word[esp+4*6+2]
|
|
movsx ebx,word[esp+4*6]
|
|
movsx ecx,word[esp+4*4+2]
|
|
movsx edx,word[esp+4*4]
|
|
lea edi,[ecx*3]
|
|
push edi
|
|
add ecx,eax
|
|
add edx,ebx
|
|
mov edi,[TASK_BASE]
|
|
movsx esi,word[edi-CURRENT_TASK+0]
|
|
add eax,esi
|
|
add ecx,esi
|
|
movsx esi,word[edi-CURRENT_TASK+4]
|
|
add ebx,esi
|
|
add edx,esi
|
|
; add eax,[esi-CURRENT_TASK+0]
|
|
; add ebx,[esi-CURRENT_TASK+4]
|
|
; add ecx,[esi-CURRENT_TASK+0]
|
|
; add edx,[esi-CURRENT_TASK+4]
|
|
|
|
mov esi,[CURRENT_TASK]
|
|
mov esi,[CLIP_RECTS+esi*4]
|
|
mov edi,[esi]
|
|
or edi,edi
|
|
jz .exit
|
|
add esi,4
|
|
cld
|
|
.nx: jif ecx,l,[rr.left],.skip
|
|
jif eax,ge,[rr.right],.skip
|
|
jif edx,l,[rr.top],.skip
|
|
jif ebx,ge,[rr.bottom],.skip
|
|
pushad
|
|
jif eax,ge,[rr.left],@f
|
|
mov eax,[rr.left]
|
|
@@: jif ebx,ge,[rr.top],@f
|
|
mov ebx,[rr.top]
|
|
@@: jif ecx,l,[rr.right],@f
|
|
mov ecx,[rr.right]
|
|
@@: jif edx,l,[rr.bottom],@f
|
|
mov edx,[rr.bottom]
|
|
@@: call is_intersect_rc
|
|
jc .put
|
|
cmp byte[MOUSE_VISIBLE],0
|
|
je .put
|
|
call [SF.draw_mouse_under]
|
|
mov byte[MOUSE_VISIBLE],0
|
|
.put:
|
|
mov esi,ebx
|
|
sub esi,[esp+4*4]
|
|
imul esi,[esp+4*8]
|
|
mov edi,eax
|
|
sub edi,[esp+4*7]
|
|
lea edi,[edi*3]
|
|
add esi,edi
|
|
add esi,ebp
|
|
mov edi,ebx
|
|
mov ebp,ebx
|
|
shl edi,6 ; 80*y
|
|
shl ebp,4
|
|
add edi,ebp
|
|
add edi,VGABasePtr
|
|
.xxx: push eax edx esi edi ebx eax
|
|
or ebp,-1
|
|
mov edx,0x03CE
|
|
@@: mov eax,[esp]
|
|
push ecx edi
|
|
mov cl,al
|
|
shr eax,3 ; /8
|
|
add edi,eax ; 80*y + (x/8)
|
|
|
|
mov eax,0x8008
|
|
and cl,7 ; Get Bit that Changes
|
|
shr ah,cl
|
|
out dx,ax
|
|
|
|
lodsd
|
|
dec esi
|
|
and eax,0x00FFFFFF
|
|
cmp eax,ebp
|
|
jne .ppp
|
|
mov cl,bl
|
|
jmp .ppp.2
|
|
.ppp:
|
|
mov ebp,eax
|
|
call color_24_to_4_bits
|
|
mov bl,al
|
|
.ppp.2:
|
|
mov al,[edi] ; dummy read
|
|
mov [edi],cl
|
|
pop edi ecx
|
|
inc dword[esp]
|
|
cmp [esp],ecx
|
|
jl @b
|
|
pop eax ebx edi esi edx eax
|
|
inc ebx
|
|
add esi,[esp+4*8]
|
|
add edi,80
|
|
cmp ebx,edx
|
|
jl .xxx
|
|
popad
|
|
.skip:
|
|
add esi,SR
|
|
dec edi
|
|
jnz .nx
|
|
|
|
.exit:
|
|
add esp,4
|
|
sti
|
|
popad
|
|
xor eax,eax
|
|
retn
|
|
endf
|
|
|
|
;-----------------------------------------------------------------------------
|
|
func vm_mike_draw_bg.04 ;/////////////////////////////////////////////////////
|
|
;-----------------------------------------------------------------------------
|
|
begin
|
|
pushad
|
|
|
|
cmp byte[0x460000-12],1
|
|
je .tiled
|
|
|
|
mov eax,[viewport.left]
|
|
mov ebx,[viewport.top]
|
|
mov ecx,[viewport.right]
|
|
mov edx,[viewport.bottom]
|
|
mov edi,[0x00300000]
|
|
|
|
cli
|
|
jif eax,e,ecx,.exit
|
|
jif ebx,e,edx,.exit
|
|
|
|
call get_cursor_rect
|
|
|
|
push eax
|
|
mov eax,edi
|
|
call color_24_to_4_bits
|
|
mov edi,eax
|
|
pop eax
|
|
|
|
mov esi,[CLIP_RECTS+4]
|
|
mov ebp,[esi]
|
|
or ebp,ebp
|
|
jz .exit
|
|
add esi,4
|
|
.nx: jif ecx,le,[rr.left],.skip
|
|
jif eax,ge,[rr.right],.skip
|
|
jif edx,le,[rr.top],.skip
|
|
jif ebx,ge,[rr.bottom],.skip
|
|
pushad
|
|
jif eax,ge,[rr.left],@f
|
|
mov eax,[rr.left]
|
|
@@: jif ebx,ge,[rr.top],@f
|
|
mov ebx,[rr.top]
|
|
@@: jif ecx,l,[rr.right],@f
|
|
mov ecx,[rr.right]
|
|
@@: jif edx,l,[rr.bottom],@f
|
|
mov edx,[rr.bottom]
|
|
@@: call is_intersect_rc
|
|
jc .put
|
|
cmp byte[MOUSE_VISIBLE],0
|
|
je .put
|
|
call [SF.draw_mouse_under]
|
|
mov byte[MOUSE_VISIBLE],0
|
|
.put: sub edx,ebx
|
|
push edx edi ebx eax
|
|
mov edi,ebx
|
|
shl edi,6
|
|
shl ebx,4
|
|
add edi,ebx
|
|
shr eax,3
|
|
add edi,eax
|
|
add edi,VGABasePtr
|
|
pop eax ebx
|
|
|
|
mov ebx,eax
|
|
mov esi,ecx
|
|
sub esi,eax
|
|
mov dx,0x03CE
|
|
|
|
;edi = Offset in VMem
|
|
;esi = Length
|
|
;ebx = x
|
|
; dx = Graphix Controller
|
|
|
|
mov cl,bl ; Get StartBit
|
|
and ecx,07h
|
|
|
|
mov eax,esi
|
|
add eax,ecx
|
|
cmp eax,8 ; Is x+Length<One Byte
|
|
jb .D_One
|
|
|
|
mov ax,0xff08 ; 11111111b | BitMask Register
|
|
shr ah,cl ; BitMask
|
|
out dx,ax ; Write BitMask
|
|
push ecx
|
|
mov ah,[esp+4]
|
|
mov ecx,[esp+4+4]
|
|
push edi
|
|
.D_LL: ; Draw Left of Box
|
|
mov al,[edi]
|
|
mov [edi],ah
|
|
add edi,80 ; edi:=edi+80
|
|
dec ecx
|
|
jnz .D_LL
|
|
pop edi
|
|
inc edi
|
|
pop ecx
|
|
|
|
mov ax,0xFF08 ; BitMask Register
|
|
out dx,ax ; Write BitMask
|
|
|
|
mov eax,esi
|
|
mov ch,8
|
|
sub ch,cl
|
|
movzx ecx,ch
|
|
sub eax,ecx
|
|
shr eax,3 ; Length div 8
|
|
|
|
push edi ebx
|
|
mov ebx,[esp+8+4]
|
|
mov edx,eax
|
|
mov al,[esp+8]
|
|
.D_LC:
|
|
mov ecx,edx
|
|
rep stosb
|
|
add edi,80
|
|
sub edi,edx
|
|
dec ebx
|
|
jnz .D_LC
|
|
pop ebx edi
|
|
add edi,edx
|
|
|
|
mov ecx,ebx ; ecx:=x+Length
|
|
add ecx,esi
|
|
and ecx,07h ; ecx and 07
|
|
mov ah,0ffh
|
|
shr ah,cl ; BitMask
|
|
jz .D_End
|
|
|
|
not ah
|
|
mov al,8 ; BitMask Register
|
|
mov dx,03ceh ; Graphics Controller
|
|
out dx,ax ; Write BitMask
|
|
mov ecx,[esp+4]
|
|
mov al,[esp]
|
|
.D_LR:
|
|
mov ah,[edi]
|
|
mov [edi],al
|
|
add edi,80
|
|
dec ecx
|
|
jnz .D_LR
|
|
|
|
jmp .D_End
|
|
|
|
.D_One:
|
|
mov ah,0ffh
|
|
shr ah,cl ; Left BitMask
|
|
|
|
add ebx,esi
|
|
dec ebx
|
|
and ebx,07h
|
|
|
|
mov ecx,7
|
|
sub ecx,ebx
|
|
|
|
mov bl,0ffh
|
|
shl bl,cl ; Right BitMask
|
|
|
|
and ah,bl ; Full BitMask
|
|
mov al,8 ; BitMask Register
|
|
out dx,ax ; Write BitMask
|
|
mov ecx,[esp+4]
|
|
mov al,[esp]
|
|
.D_L:
|
|
mov dl,[edi] ; Fill Latches
|
|
mov [edi],al ; Write Pixel
|
|
add edi,80
|
|
dec ecx
|
|
jnz .D_L
|
|
.D_End:
|
|
pop edi
|
|
add esp,4
|
|
popad
|
|
.skip:
|
|
add esi,SR
|
|
dec ebp
|
|
jnz .nx
|
|
|
|
.exit:
|
|
sti
|
|
popad
|
|
retn
|
|
|
|
.tiled:
|
|
mov eax,IMG_BACKGROUND
|
|
mov ebx,[bg_width-2]
|
|
mov bx,word[bg_height]
|
|
xor ecx,ecx
|
|
xor edx,edx
|
|
.lp1: push eax
|
|
call vm_mike_put_image.04.direct
|
|
pop eax
|
|
add edx,[bg_width]
|
|
cmp edx,[ScreenWidth]
|
|
jae @f
|
|
shl edx,16
|
|
add ecx,edx
|
|
shr edx,16
|
|
jmp .lp1
|
|
@@: and ecx,0x0000FFFF
|
|
xor edx,edx
|
|
add ecx,[bg_height]
|
|
cmp ecx,[ScreenHeight]
|
|
jb .lp1
|
|
popad
|
|
retn
|
|
endf |