Text wrapper conversion.

G_PrintGameText(), minitext_(), G_DrawTXDigiNumZ(), and menutext_() now wrap G_ScreenText().
G_GameTextLen() now wraps G_ScreenTextSize().
G_DrawDigiNum_() now wraps G_DrawTXDigiNumZ().

git-svn-id: https://svn.eduke32.com/eduke32@3836 1a8010ca-5511-0410-912e-c29ae57300e0
This commit is contained in:
hendricks266 2013-06-01 06:56:00 +00:00
parent 4504716fa0
commit bf9b91352b
3 changed files with 70 additions and 317 deletions

View file

@ -1142,14 +1142,14 @@ vec2_t G_ScreenText(const int32_t font,
// flags // flags
// 4: small font, wrap strings? // 4: small font, wrap strings?
int32_t G_PrintGameText(int32_t f, int32_t tile, int32_t x, int32_t y, const char *t, int32_t G_PrintGameText(int32_t hack, int32_t tile, int32_t x, int32_t y, const char *t,
int32_t s, int32_t p, int32_t o, int32_t s, int32_t p, int32_t o,
int32_t x1, int32_t y1, int32_t x2, int32_t y2, int32_t z) int32_t x1, int32_t y1, int32_t x2, int32_t y2, int32_t z)
{ {
int32_t ac; vec2_t dim;
const int32_t squishtext = (f&2) != 0 ? 1 : 0; int32_t f = TEXT_GAMETEXTNUMHACK;
const int32_t widthx = 320<<16; int32_t xbetween = 0;
int32_t origx = x, origy, j = 0; int32_t orient = 8|16|(o&1)|(o&32);
if (t == NULL) if (t == NULL)
return -1; return -1;
@ -1160,149 +1160,55 @@ int32_t G_PrintGameText(int32_t f, int32_t tile, int32_t x, int32_t y, const
y <<= 16; y <<= 16;
} }
origy = y; if (hack & 4)
if (x == (widthx>>1)) // center
{ {
const char *oldt = t; x = textsc(x);
int32_t newx = 0; z = textsc(z);
f |= TEXT_LINEWRAP;
}
else if (!(hack & 1))
orient = 2|o;
do if (hack & 8)
{ {
int32_t i; f |= TEXT_XOFFSETZERO;
xbetween = 8;
if (*t == 32)
{
newx += ((((f & 8) ? 8 : 5) - squishtext) * z);
continue;
} }
if (*t == '^' && isdigit(*(t+1))) // order is important, this bit comes after the rest
{ if (hack & 2) // squishtext
t++; --xbetween;
if (isdigit(*(t+1)))
t++;
// t += 1 + isdigit(*(t+2)); // This code is wrong, see C99 6.5 #2
continue;
}
ac = *t - '!' + tile; if (x == (160<<16))
f |= TEXT_XCENTER;
if (ac < tile || ac > (tile + 93)) dim = G_ScreenText(tile, x, y, z, 0, 0, t, s, p, orient|ROTATESPRITE_FULL16, 0, (5<<16), (8<<16), (xbetween<<16), 0, f, x1, y1, x2, y2);
break;
i = ((((f & 8) ? 8 : tilesizx[ac]) - squishtext) * z); x += dim.x;
newx += i;
if (*t >= '0' && *t <= '9') if (!(o & ROTATESPRITE_FULL16))
newx -= i - ((8 * z)); x >>= 16;
}
while (*(++t));
t = oldt; return x;
x = (f & 4) ?
(xres>>1)-textsc(newx>>1) :
(widthx>>1)-(newx>>1);
}
do
{
int32_t i;
if (*t == 32)
{
j += ((((f & 8) ? 8 : 5) - squishtext) * z);
continue;
}
if (*t == '^' && isdigit(*(t+1)))
{
char smallbuf[4];
if (!isdigit(*(++t+1)))
{
smallbuf[0] = *(t);
smallbuf[1] = '\0';
p = Batoi(smallbuf);
continue;
}
smallbuf[0] = *(t++);
smallbuf[1] = *(t);
smallbuf[2] = '\0';
p = Batoi(smallbuf);
continue;
}
ac = *t - '!' + tile;
if (ac < tile || ac > (tile + 93))
break;
if (f&4)
{
rotatesprite(textsc(x+j), (origy)+textsc((y-origy)), textsc(z),
0,ac,s,p,(8|16|(o&1)|(o&32)),x1,y1,x2,y2);
}
else
{
const int32_t orient = (f&1) ? (8|16|(o&1)|(o&32)) : (2|o);
rotatesprite(x+j, y, z,
0,ac,s,p,orient,x1,y1,x2,y2);
}
i = (f & 8) ?
((8 - squishtext) * z):
((tilesizx[ac] - squishtext) * z);
j += i;
if (*t >= '0' && *t <= '9')
j -= i-((8*z));
// wrapping long strings doesn't work for precise coordinates due to overflow
// XXX: above comment obsolete?
if (!(o&ROTATESPRITE_FULL16))
{
if (((f&4) ? textsc(x+j) : (x+j)) > (ud.config.ScreenWidth - USERQUOTE_RIGHTOFFSET)<<16)
j = 0, y += z<<3; // z == 65536 --> 8<<16
}
}
while (*(++t));
return origx + ((o & ROTATESPRITE_FULL16) ? j : (j>>16));
} }
int32_t G_GameTextLen(int32_t x,const char *t) int32_t G_GameTextLen(int32_t x,const char *t)
{ {
int32_t ac; vec2_t dim;
if (t == NULL) if (t == NULL)
return -1; return -1;
do dim = G_ScreenTextSize(STARTALPHANUM, x, 0, textsc(65536L), 0, t, 2, 5, 8, 0, 0, TEXT_GAMETEXTNUMHACK, 0, 0, xdim-1, ydim-1);
{
if (*t == 32)
{
x+=5;
continue;
}
ac = *t - '!' + STARTALPHANUM; x += dim.x;
if (ac < STARTALPHANUM || ac > (STARTALPHANUM + 93)) return x;
break;
x += (*t >= '0' && *t <= '9') ? 8 : tilesizx[ac];
}
while (*(++t));
return (textsc(x));
} }
int32_t mpgametext(int32_t y,const char *t,int32_t s,int32_t dabits) int32_t mpgametext(int32_t y,const char *t,int32_t s,int32_t dabits)
{ {
return(G_PrintGameText(4,STARTALPHANUM, 5,y,t,s,0,dabits,0, 0, xdim-1, ydim-1, 65536)); return G_PrintGameText(4,STARTALPHANUM, 5,y,t,s,0,dabits,0, 0, xdim-1, ydim-1, 65536);
} }
// minitext_yofs: in hud_scale-independent, (<<16)-scaled, 0-200-normalized y coords, // minitext_yofs: in hud_scale-independent, (<<16)-scaled, 0-200-normalized y coords,
@ -1311,11 +1217,9 @@ static int32_t minitext_yofs = 0;
static int32_t minitext_lowercase = 0; static int32_t minitext_lowercase = 0;
int32_t minitext_(int32_t x,int32_t y,const char *t,int32_t s,int32_t p,int32_t sb) int32_t minitext_(int32_t x,int32_t y,const char *t,int32_t s,int32_t p,int32_t sb)
{ {
int32_t ac, j = 0; vec2_t dim;
char ch, cmode; int32_t z = 65536L;
int32_t f = 0;
cmode = (sb&ROTATESPRITE_MAX)!=0;
sb &= (ROTATESPRITE_MAX-1)|RS_CENTERORIGIN;
if (t == NULL) if (t == NULL)
{ {
@ -1323,50 +1227,32 @@ int32_t minitext_(int32_t x,int32_t y,const char *t,int32_t s,int32_t p,int32_t
return 0; return 0;
} }
if (!(sb&ROTATESPRITE_FULL16)) if (!(sb & ROTATESPRITE_FULL16))
{ {
x<<=16; x<<=16;
y<<=16; y<<=16;
} }
do
{
if (*t == '^' && isdigit(*(t+1)))
{
char smallbuf[4];
if (!isdigit(*(++t+1)))
{
smallbuf[0] = *(t);
smallbuf[1] = '\0';
p = Batoi(smallbuf);
continue;
}
smallbuf[0] = *(t++);
smallbuf[1] = *(t);
smallbuf[2] = '\0';
p = Batoi(smallbuf);
continue;
}
if (!minitext_lowercase) if (!minitext_lowercase)
ch = Btoupper(*t); f |= TEXT_UPPERCASE;
else
ch = *t;
if (ch == 32) if (sb & ROTATESPRITE_MAX)
{ {
j+=5; x = sbarx16(x);
continue; y = minitext_yofs+sbary16(y);
z = sbarsc(z);
} }
else ac = ch - '!' + MINIFONT;
if (cmode) rotatesprite_fs(sbarx16(x+(j<<16)),minitext_yofs+sbary16(y),sbarsc(65536L),0,ac,s,p,sb); sb &= (ROTATESPRITE_MAX-1)|RS_CENTERORIGIN;
else rotatesprite_fs(x+(j<<16),y,65536L,0,ac,s,p,sb);
j += (tilesizx[ac] > 0 ? tilesizx[ac] : 3) + 1;
} dim = G_ScreenText(MINIFONT, x, y, z, 0, 0, t, s, p, sb|ROTATESPRITE_FULL16, 0, (4<<16), (8<<16), (1<<16), 0, f, 0, 0, xdim-1, ydim-1);
while (*(++t));
return x+(j<<((sb&ROTATESPRITE_FULL16)?16:0)); x += dim.x;
if (!(sb & ROTATESPRITE_FULL16))
x >>= 16;
return x;
} }
void G_AddUserQuote(const char *daquote) void G_AddUserQuote(const char *daquote)
@ -1795,25 +1681,13 @@ static void G_DrawWeapAmounts(const DukePlayer_t *p,int32_t x,int32_t y,int32_t
// yofs: in hud_scale-independent, (<<16)-scaled, 0-200-normalized y coords. // yofs: in hud_scale-independent, (<<16)-scaled, 0-200-normalized y coords.
static void G_DrawDigiNum_(int32_t x, int32_t yofs, int32_t y, int32_t n, char s, int32_t cs) static void G_DrawDigiNum_(int32_t x, int32_t yofs, int32_t y, int32_t n, char s, int32_t cs)
{ {
int32_t i, j = 0, k, p, c; if (!(cs & ROTATESPRITE_FULL16))
char b[12];
i = Bsprintf(b,"%d",n);
for (k=i-1; k>=0; k--)
{ {
p = DIGITALNUM + b[k]-'0'; x <<= 16;
j += tilesizx[p]+1; y <<= 16;
} }
c = x-(j>>1);
j = 0; G_DrawTXDigiNumZ(DIGITALNUM, sbarx16(x), yofs + sbary16(y), n, s, 0, cs|ROTATESPRITE_FULL16, 0, 0, xdim-1, ydim-1, sbarsc(65536L));
for (k=0; k<i; k++)
{
p = DIGITALNUM + b[k]-'0';
rotatesprite_fs(sbarx(c+j), yofs+sbary(y), sbarsc(65536), 0, p, s, 0, cs);
j += tilesizx[p]+1;
}
} }
static inline void G_DrawDigiNum(int32_t x, int32_t y, int32_t n, char s, int32_t cs) static inline void G_DrawDigiNum(int32_t x, int32_t y, int32_t n, char s, int32_t cs)
@ -1824,27 +1698,16 @@ static inline void G_DrawDigiNum(int32_t x, int32_t y, int32_t n, char s, int32_
void G_DrawTXDigiNumZ(int32_t starttile, int32_t x,int32_t y,int32_t n,int32_t s,int32_t pal, void G_DrawTXDigiNumZ(int32_t starttile, int32_t x,int32_t y,int32_t n,int32_t s,int32_t pal,
int32_t cs,int32_t x1, int32_t y1, int32_t x2, int32_t y2, int32_t z) int32_t cs,int32_t x1, int32_t y1, int32_t x2, int32_t y2, int32_t z)
{ {
int32_t i, j = 0, k, p, c;
char b[12]; char b[12];
const int32_t shift = (cs&ROTATESPRITE_FULL16)?0:16; Bsprintf(b,"%d",n);
i = Bsprintf(b,"%d",n); if (!(cs & ROTATESPRITE_FULL16))
// center the number string
for (k=i-1; k>=0; k--)
{ {
p = starttile + b[k]-'0'; x <<= 16;
j += ((1+tilesizx[p])*z); y <<= 16;
} }
c = (x<<shift)-(j>>1);
j = 0; G_ScreenText(starttile, x, y, z, 0, 0, b, s, pal, cs|2|ROTATESPRITE_FULL16, 0, (4<<16), (8<<16), (1<<16), 0, TEXT_XCENTER|TEXT_DIGITALNUMBER, x1, y1, x2, y2);
for (k=0; k<i; k++)
{
p = starttile + b[k]-'0';
rotatesprite(c+j,y<<shift,z,0,p,s,pal,2|cs,x1,y1,x2,y2);
j += ((1+tilesizx[p])*z);
}
} }
static void G_DrawAltDigiNum(int32_t x, int32_t y, int32_t n, char s, int32_t cs) static void G_DrawAltDigiNum(int32_t x, int32_t y, int32_t n, char s, int32_t cs)

View file

@ -307,7 +307,7 @@ int32_t A_Spawn(int32_t j,int32_t pn);
int32_t G_DoMoveThings(void); int32_t G_DoMoveThings(void);
//int32_t G_EndOfLevel(void); //int32_t G_EndOfLevel(void);
int32_t G_GameTextLen(int32_t x,const char *t); int32_t G_GameTextLen(int32_t x,const char *t);
int32_t G_PrintGameText(int32_t f,int32_t tile,int32_t x,int32_t y,const char *t,int32_t s,int32_t p,int32_t o,int32_t x1,int32_t y1,int32_t x2,int32_t y2,int32_t z); int32_t G_PrintGameText(int32_t hack,int32_t tile,int32_t x,int32_t y,const char *t,int32_t s,int32_t p,int32_t o,int32_t x1,int32_t y1,int32_t x2,int32_t y2,int32_t z);
int32_t GetTime(void); int32_t GetTime(void);
int32_t kopen4loadfrommod(const char *filename,char searchfirst); int32_t kopen4loadfrommod(const char *filename,char searchfirst);
int32_t minitext_(int32_t x,int32_t y,const char *t,int32_t s,int32_t p,int32_t sb); int32_t minitext_(int32_t x,int32_t y,const char *t,int32_t s,int32_t p,int32_t sb);

View file

@ -349,125 +349,15 @@ static int32_t Menu_EnterText(int32_t x,int32_t y,char *t,int32_t dalen,int32_t
int32_t menutext_(int32_t x,int32_t y,int32_t s,int32_t p,char *t,int32_t bits) int32_t menutext_(int32_t x,int32_t y,int32_t s,int32_t p,char *t,int32_t bits)
{ {
int16_t i, ac, centre; vec2_t dim;
// int32_t ht = usehightile; int32_t f = TEXT_BIGALPHANUM|TEXT_UPPERCASE|TEXT_LITERALESCAPE;
y -= 12; if (x == 160)
f |= TEXT_XCENTER;
i = centre = 0; dim = G_ScreenText(BIGALPHANUM, x, y-12, 65536L, 0, 0, t, s, p, bits, 0, 5, 16, 0, 0, f, 0, 0, xdim-1, ydim-1);
if (x == (320>>1)) return dim.x;
{
while (*(t+i))
{
if (*(t+i) == ' ')
{
centre += 5;
i++;
continue;
}
ac = 0;
if (*(t+i) >= '0' && *(t+i) <= '9')
ac = *(t+i) - '0' + BIGALPHANUM-10;
else if (*(t+i) >= 'a' && *(t+i) <= 'z')
ac = toupper(*(t+i)) - 'A' + BIGALPHANUM;
else if (*(t+i) >= 'A' && *(t+i) <= 'Z')
ac = *(t+i) - 'A' + BIGALPHANUM;
else switch (*(t+i))
{
case '-':
ac = BIGALPHANUM-11;
break;
case '.':
ac = BIGPERIOD;
break;
case '\'':
ac = BIGAPPOS;
break;
case ',':
ac = BIGCOMMA;
break;
case '!':
ac = BIGX_;
break;
case '?':
ac = BIGQ;
break;
case ';':
ac = BIGSEMI;
break;
case ':':
ac = BIGSEMI;
break;
default:
centre += 5;
i++;
continue;
}
centre += tilesizx[ac]-1;
i++;
}
}
if (centre)
x = (320-centre-10)>>1;
// usehightile = (ht && r_downsize < 3);
while (*t)
{
if (*t == ' ')
{
x+=5;
t++;
continue;
}
ac = 0;
if (*t >= '0' && *t <= '9')
ac = *t - '0' + BIGALPHANUM-10;
else if (*t >= 'a' && *t <= 'z')
ac = toupper(*t) - 'A' + BIGALPHANUM;
else if (*t >= 'A' && *t <= 'Z')
ac = *t - 'A' + BIGALPHANUM;
else switch (*t)
{
case '-':
ac = BIGALPHANUM-11;
break;
case '.':
ac = BIGPERIOD;
break;
case ',':
ac = BIGCOMMA;
break;
case '!':
ac = BIGX_;
break;
case '\'':
ac = BIGAPPOS;
break;
case '?':
ac = BIGQ;
break;
case ';':
ac = BIGSEMI;
break;
case ':':
ac = BIGCOLIN;
break;
default:
x += 5;
t++;
continue;
}
rotatesprite_fs(x<<16,y<<16,65536L,0,ac,s,p,bits);
x += tilesizx[ac];
t++;
}
// usehightile = ht;
return (x);
} }