[Back to EGAVGA SWAG index] [Back to Main SWAG index] [Original]
{
David Proper posted a cross-fade routine here, some days ago. This is an update
on that one. It now fades all texts. Quite a pain to figure this out, realy.
Put it in the SWAG if you want, Kerry - Done!.
}
program xfade;
{ made by Bas van Gaalen, Holland, PD,
fido 2:285/213.8, internet bas.van.gaalen@schotman.nl }
uses crt;
const
vseg=$a000; fseg=$f000; fofs=$fa6e; lines=13;
creds:array[0..lines-1] of string[20]=(
{.........|.........|}
'This cross-fade',
'routine was made by',
'Bas van Gaalen',
'Code and idea',
'inspired by',
'David Proper',
'This routine was',
'enhanced a bit',
'in comparison with',
'David''s one...',
'cu later',
'alligator!',
'');
procedure setpal(c,r,g,b:byte); assembler; asm
mov dx,3c8h; mov al,[c]; out dx,al; inc dx; mov al,[r]
out dx,al; mov al,[g]; out dx,al; mov al,[b]; out dx,al; end;
procedure retrace; assembler; asm
mov dx,3dah; @vert1: in al,dx; test al,8; jz @vert1
@vert2: in al,dx; test al,8; jnz @vert2; end;
procedure cleartxt(col,new:byte);
var x,y,vofs:word;
begin
for x:=0 to 319 do for y:=100 to 107 do begin
vofs:=y*320+x;
if mem[vseg:vofs]=col then mem[vseg:vofs]:=0
else if mem[vseg:vofs]<>0 then mem[vseg:vofs]:=new;
end;
end;
procedure writetxt(col,cur:byte; txt:string);
var x,y,vofs:word; i,j,k:byte;
begin
x:=(320-8*length(txt)) div 2; y:=100;
for i:=1 to length(txt) do for j:=0 to 7 do for k:=0 to 7 do
if ((mem[fseg:fofs+ord(txt[i])*8+j] shl k) and 128) <> 0 then begin
vofs:=(y+j)*320+(i*8)+x+k;
if mem[vseg:vofs]=cur then mem[vseg:vofs]:=col+cur else
mem[vseg:vofs]:=col; end;
end;
var txtidx,curcol,i:byte;
begin
asm mov ax,13h; int 10h; end;
setpal(1,0,0,0); setpal(2,0,0,0); setpal(3,63 div 2,63,63 div 2);
curcol:=1; txtidx:=0;
repeat
cleartxt(curcol,3-curcol);
writetxt(curcol,3-curcol,creds[txtidx]);
for i:=0 to 63 do begin
retrace;
setpal(curcol,i div 2,i,i div 2);
setpal(3-curcol,(63-i) div 2,63-i,(63-i) div 2);
end;
delay(500);
curcol:=1+(curcol mod 2);
txtidx:=(1+txtidx) mod lines;
until keypressed;
textmode(lastmode);
end.
[Back to EGAVGA SWAG index] [Back to Main SWAG index] [Original]