2015-02-11 19:34:08 +01:00

109 lines
2.7 KiB
C

/* ------------------------------------------------------------------------
System : Manx Aztec C65 Version 3.2b
MS-DOS cross-development environment
Platform : Apple IIe 128K PRODOS 8
Program : d2font.c
Description : G2 Library Routine
Double Hi-Res 140 x 192 x 16 color font routine
for ProDOS 8 Sys Programs
Uses Page 2 Double Hi-Res to avoid
ProDOS Sys Program Load Address at 0x2000
Written by : Bill Buckels
Date Written : February 2013
Revision : 1.0 First Release
Licence : You may use this code for whatever you wish as long
as you agree that Bill Buckels has no warranty or
liability obligations whatsoever from said use.
------------------------------------------------------------------------ */
extern char __chr[1096];
int d2msk[]={0x1,0x2,0x4,0x8,0x10,0x20,0x40};
int d2font(str,row,col,fg,bg,scale,pitch,justify)
char *str;
int row,col,fg,bg,scale,pitch;
char justify;
{
int target, scanline, offset, r, r2, c, d, byte, nibble, x, spaces = 0;
unsigned char ch;
if (scale > 2)scale = 1;
if (pitch != 6)pitch = 7;
target = strlen(str);
for (byte=0;byte<target;byte++) {
d = str[byte]&0x7f;
if (d < 32)d = 32;
if (d == 32 || d == 'l' || d == '1' || d == '.' || d == '!')spaces +=1;
}
if (justify == 'm' || justify == 'M') {
offset = ((target * pitch)- spaces)/2;
col = col - offset;
}
for(scanline=0;scanline<8;scanline++)
{
/* set values for vertical term */
/* expand x scale in the vertical direction */
r = (scanline * scale) + row; /* max 16 high */
if (r > 191)break;
r2 = r + 1;
/* run the string 8 times
if scale = 2 then print a double line
each time which gives us a font of 16 high */
spaces = 0;
for (byte=0;byte<target;byte++)
{
/* calculate the starting column for each
run in the width of 6 or 7 pixels */
c = ((byte * pitch) + col)-spaces;
if (c > 139)continue;
d = str[byte]&0x7f;
if (d < 32)d = 32;
if (d == 32 || d == 'l' || d == '1'|| d == '.'||d == '!')spaces +=1;
if (d == 32 && bg < 0)continue;
offset = ((d-32) * 8) + scanline;
ch = __chr[offset];
if (ch == 0 && bg < 0)continue;
for (nibble=0;nibble<pitch;nibble++)
{
x = c+nibble;
if (x > 139)break;
if (ch & d2msk[nibble]){
if (scale > 1 && r2 < 192)
d2vline(x,r,r2,fg);
else
d2vline(x,r,r,fg);
}
else {
if (bg < 0)continue;
if (scale > 1 && r2 < 192)
d2vline(x,r,r2,bg);
else
d2vline(x,r,r,bg);
}
}
}
}
return 0;
}