[Decompilation] [th01] Non-entity boss animations: Byte-aligned blitting

And that's all we have for this class. Again, ever so slightly not
identical to the same CBossEntity function.

Part of P0120, funded by Yanga.
This commit is contained in:
nmlgc 2020-09-24 22:01:33 +02:00
parent 719668d51e
commit 8d39276732
3 changed files with 50 additions and 218 deletions

View File

@ -637,4 +637,43 @@ int CBossAnim::load(const char fn[PF_FN_LEN], int slot)
arc_file_free(); arc_file_free();
return 0; return 0;
} }
void CBossAnim::put_8(void) const
{
vram_offset_t vram_offset_row = vram_offset_divmul(left, top);
vram_offset_t vram_offset;
size_t bos_p = 0;
pixel_t bos_y;
vram_word_amount_t bos_word_x;
vram_y_t intended_y;
bos_image_t &bos = bos_anim_images[bos_slot].image[bos_image];
if(bos_image >= bos_image_count) {
return;
}
for(bos_y = 0; h > bos_y; bos_y++) {
vram_offset_t vram_offset = vram_offset_row;
intended_y = vram_intended_y_for(vram_offset_row, left);
for(bos_word_x = 0; (vram_w / 2) > bos_word_x; bos_word_x++) {
if((vram_offset / ROW_SIZE) == intended_y) {
if(bos.alpha[bos_p]) {
grcg_setcolor_rmw(0);
VRAM_PUT(B, vram_offset, bos.alpha[bos_p], 16);
grcg_off();
}
vram_or_emptyopt(B, vram_offset, bos.planes.B[bos_p], 16);
vram_or_emptyopt(R, vram_offset, bos.planes.R[bos_p], 16);
vram_or_emptyopt(G, vram_offset, bos.planes.G[bos_p], 16);
vram_or_emptyopt(E, vram_offset, bos.planes.E[bos_p], 16);
}
vram_offset += 2;
bos_p++;
}
vram_offset_row += ROW_SIZE;
if(vram_offset_row >= PLANE_SIZE) { // Clip at the bottom edge
break;
}
}
}
/// --------------------- /// ---------------------

View File

@ -216,6 +216,10 @@ public:
// keeps the .BOS metadata in this CBossEntity instance. Always returns 0. // keeps the .BOS metadata in this CBossEntity instance. Always returns 0.
// Identical to CBossEntity::load() with an added alpha negation loop. // Identical to CBossEntity::load() with an added alpha negation loop.
int load(const char fn[PF_FN_LEN], int slot); int load(const char fn[PF_FN_LEN], int slot);
// Blits [bos_image] to (⌊left/8⌋*8, top).
// Additionally clips at the bottom edge of VRAM.
void put_8(void) const;
}; };
// Frees all images in the given [slot]. // Frees all images in the given [slot].

View File

@ -8886,6 +8886,7 @@ main_21_TEXT segment byte public 'CODE' use16
extern @CBossEntity@hittest_orb$xqv:proc extern @CBossEntity@hittest_orb$xqv:proc
extern _bos_entity_free:proc extern _bos_entity_free:proc
extern @CBossAnim@load$qxnxci:proc extern @CBossAnim@load$qxnxci:proc
extern @CBossAnim@put_8$xqv:proc
main_21_TEXT ends main_21_TEXT ends
main_21__TEXT segment byte public 'CODE' use16 main_21__TEXT segment byte public 'CODE' use16
@ -8893,206 +8894,6 @@ main_21__TEXT segment byte public 'CODE' use16
;org 4 ;org 4
assume es:nothing, ss:nothing, ds:_DATA, fs:nothing, gs:nothing assume es:nothing, ss:nothing, ds:_DATA, fs:nothing, gs:nothing
; =============== S U B R O U T I N E =======================================
; Attributes: bp-based frame
sub_16D6A proc far
@@bos = dword ptr -0Ch
var_8 = word ptr -8
var_6 = word ptr -6
var_4 = word ptr -4
var_2 = word ptr -2
arg_0 = dword ptr 6
enter 0Ch, 0
push si
push di
les bx, [bp+arg_0]
mov ax, es:[bx]
mov bx, 8
cwd
idiv bx
mov bx, word ptr [bp+arg_0]
mov dx, es:[bx+2]
imul dx, 50h
add ax, dx
mov [bp+var_2], ax
xor si, si
mov al, es:[bx+0Ah]
mov ah, 0
imul ax, size bos_t
mov dl, es:[bx+9]
mov dh, 0
imul dx, size bos_image_t
add ax, dx
add ax, offset _bos_anim_images
mov word ptr [bp+@@bos+2], ds
mov word ptr [bp+@@bos], ax
mov al, es:[bx+9]
cmp al, es:[bx+8]
jnb loc_16F17
mov [bp+var_4], 0
jmp loc_16F09
; ---------------------------------------------------------------------------
loc_16DBF:
mov di, [bp+var_2]
les bx, [bp+arg_0]
cmp word ptr es:[bx], 0
jge short loc_16DD7
mov ax, [bp+var_2]
mov bx, 80
cwd
idiv bx
inc ax
jmp short loc_16DE0
; ---------------------------------------------------------------------------
loc_16DD7:
mov ax, [bp+var_2]
mov bx, 80
cwd
idiv bx
loc_16DE0:
mov [bp+var_8], ax
mov [bp+var_6], 0
jmp loc_16EE8
; ---------------------------------------------------------------------------
loc_16DEB:
mov ax, di
mov bx, 80
cwd
idiv bx
cmp ax, [bp+var_8]
jnz loc_16EE1
les bx, [bp+@@bos]
les bx, es:[bx+bos_image_t.BOS_alpha]
mov ax, si
add ax, ax
add bx, ax
cmp word ptr es:[bx], 0
jz short loc_16E33
call _grcg_setcolor_rmw stdcall, 0
pop cx
les bx, [bp+@@bos]
les bx, es:[bx+bos_image_t.BOS_alpha]
mov ax, si
add ax, ax
add bx, ax
mov ax, es:[bx]
les bx, _VRAM_PLANE_B
add bx, di
mov es:[bx], ax
call _grcg_off_func
loc_16E33:
les bx, [bp+@@bos]
les bx, es:[bx+bos_image_t.BOS_B]
mov ax, si
add ax, ax
add bx, ax
cmp word ptr es:[bx], 0
jz short loc_16E5D
les bx, [bp+@@bos]
les bx, es:[bx+bos_image_t.BOS_B]
mov ax, si
add ax, ax
add bx, ax
mov ax, es:[bx]
les bx, _VRAM_PLANE_B
add bx, di
or es:[bx], ax
loc_16E5D:
les bx, [bp+@@bos]
les bx, es:[bx+bos_image_t.BOS_R]
mov ax, si
add ax, ax
add bx, ax
cmp word ptr es:[bx], 0
jz short loc_16E89
les bx, [bp+@@bos]
les bx, es:[bx+bos_image_t.BOS_R]
mov ax, si
add ax, ax
add bx, ax
mov ax, es:[bx]
les bx, _VRAM_PLANE_R
add bx, di
or es:[bx], ax
loc_16E89:
les bx, [bp+@@bos]
les bx, es:[bx+bos_image_t.BOS_G]
mov ax, si
add ax, ax
add bx, ax
cmp word ptr es:[bx], 0
jz short loc_16EB5
les bx, [bp+@@bos]
les bx, es:[bx+bos_image_t.BOS_G]
mov ax, si
add ax, ax
add bx, ax
mov ax, es:[bx]
les bx, _VRAM_PLANE_G
add bx, di
or es:[bx], ax
loc_16EB5:
les bx, [bp+@@bos]
les bx, es:[bx+bos_image_t.BOS_E]
mov ax, si
add ax, ax
add bx, ax
cmp word ptr es:[bx], 0
jz short loc_16EE1
les bx, [bp+@@bos]
les bx, es:[bx+bos_image_t.BOS_E]
mov ax, si
add ax, ax
add bx, ax
mov ax, es:[bx]
les bx, _VRAM_PLANE_E
add bx, di
or es:[bx], ax
loc_16EE1:
add di, 2
inc si
inc [bp+var_6]
loc_16EE8:
les bx, [bp+arg_0]
mov ax, es:[bx+4]
cwd
sub ax, dx
sar ax, 1
cmp ax, [bp+var_6]
jg loc_16DEB
add [bp+var_2], 50h ; 'P'
cmp [bp+var_2], 7D00h
jge short loc_16F17
inc [bp+var_4]
loc_16F09:
les bx, [bp+arg_0]
mov ax, es:[bx+6]
cmp ax, [bp+var_4]
jg loc_16DBF
loc_16F17:
pop di
pop si
leave
retf
sub_16D6A endp
; =============== S U B R O U T I N E ======================================= ; =============== S U B R O U T I N E =======================================
; Attributes: bp-based frame ; Attributes: bp-based frame
@ -37004,14 +36805,10 @@ loc_28F32:
mov sariel_wand.BA_bos_image, 0 mov sariel_wand.BA_bos_image, 0
push 1 push 1
call _graph_accesspage_func call _graph_accesspage_func
push ds call @CBossAnim@put_8$xqv stdcall, offset sariel_wand, ds
push offset sariel_wand
call sub_16D6A
push 0 push 0
call _graph_accesspage_func call _graph_accesspage_func
push ds call @CBossAnim@put_8$xqv stdcall, offset sariel_wand, ds
push offset sariel_wand
call sub_16D6A
add sp, 0Ch add sp, 0Ch
jmp short loc_28FA3 jmp short loc_28FA3
; --------------------------------------------------------------------------- ; ---------------------------------------------------------------------------
@ -37022,14 +36819,10 @@ loc_28F67:
mov sariel_wand.BA_bos_image, 1 mov sariel_wand.BA_bos_image, 1
push 1 push 1
call _graph_accesspage_func call _graph_accesspage_func
push ds call @CBossAnim@put_8$xqv stdcall, offset sariel_wand, ds
push offset sariel_wand
call sub_16D6A
push 0 push 0
call _graph_accesspage_func call _graph_accesspage_func
push ds call @CBossAnim@put_8$xqv stdcall, offset sariel_wand, ds
push offset sariel_wand
call sub_16D6A
add sp, 0Ch add sp, 0Ch
mov word_35DDD, 0 mov word_35DDD, 0
mov ax, 1 mov ax, 1
@ -37088,14 +36881,10 @@ sub_28FC5 proc near
mov sariel_dress.BA_bos_image, al mov sariel_dress.BA_bos_image, al
push 1 push 1
call _graph_accesspage_func call _graph_accesspage_func
push ds call @CBossAnim@put_8$xqv stdcall, offset sariel_dress, ds
push offset sariel_dress
call sub_16D6A
push 0 push 0
call _graph_accesspage_func call _graph_accesspage_func
push ds call @CBossAnim@put_8$xqv stdcall, offset sariel_dress, ds
push offset sariel_dress
call sub_16D6A
add sp, 0Ch add sp, 0Ch
locret_29013: locret_29013: