mirror of
https://github.com/ZDoom/raze-gles.git
synced 2025-01-26 00:40:56 +00:00
Text renderer: letters are now saved on a stack, misc. fixes. Quickplay: Added timeout so that user cannot create many eduke32 instances in a short time
git-svn-id: https://svn.eduke32.com/eduke32@1066 1a8010ca-5511-0410-912e-c29ae57300e0
This commit is contained in:
parent
88af77d484
commit
746071a4f4
1 changed files with 85 additions and 76 deletions
|
@ -3226,13 +3226,15 @@ void dumpalphabets()
|
||||||
|
|
||||||
void rendertext(short startspr)
|
void rendertext(short startspr)
|
||||||
{
|
{
|
||||||
char ch, buffer[80];
|
char ch, buffer[80], doingspace=0;
|
||||||
short daang, t, alphidx, basetile, linebegspr, curspr;
|
short daang, t, alphidx, basetile, linebegspr, curspr;
|
||||||
int i, j, k, dax, day;
|
int i, j, k, dax, day;
|
||||||
static unsigned char hgap=0, vgap=4;
|
static unsigned char hgap=0, vgap=4;
|
||||||
static unsigned char spcgap[MAX_ALPHABETS], firstrun=1;
|
static unsigned char spcgap[MAX_ALPHABETS], firstrun=1;
|
||||||
spritetype *sp;
|
spritetype *sp;
|
||||||
|
|
||||||
|
short *spritenums;
|
||||||
|
int stackallocsize=32, numletters=0;
|
||||||
|
|
||||||
if (firstrun)
|
if (firstrun)
|
||||||
{
|
{
|
||||||
|
@ -3268,9 +3270,10 @@ void rendertext(short startspr)
|
||||||
basetile = t;
|
basetile = t;
|
||||||
if (spcgap[i] == 0)
|
if (spcgap[i] == 0)
|
||||||
spcgap[i] = 3*tilesizx[t]/2;
|
spcgap[i] = 3*tilesizx[t]/2;
|
||||||
break;
|
goto ENDFOR1;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
ENDFOR1:
|
||||||
if (alphidx==-1)
|
if (alphidx==-1)
|
||||||
{
|
{
|
||||||
message("Must point at a text sprite.");
|
message("Must point at a text sprite.");
|
||||||
|
@ -3281,12 +3284,12 @@ void rendertext(short startspr)
|
||||||
curspr = linebegspr = startspr;
|
curspr = linebegspr = startspr;
|
||||||
|
|
||||||
t = sprite[startspr].picnum;
|
t = sprite[startspr].picnum;
|
||||||
daang = sprite[startspr].ang;
|
|
||||||
dax = sprite[startspr].x;
|
|
||||||
day = sprite[startspr].y;
|
|
||||||
sprite[startspr].xoffset = -(((picanm[t])>>8)&255);
|
sprite[startspr].xoffset = -(((picanm[t])>>8)&255);
|
||||||
sprite[startspr].yoffset = -(((picanm[t])>>16)&255);
|
sprite[startspr].yoffset = -(((picanm[t])>>16)&255);
|
||||||
|
|
||||||
|
spritenums = Bmalloc(stackallocsize * sizeof(short));
|
||||||
|
if (!spritenums) goto ERROR1;
|
||||||
|
|
||||||
bflushchars();
|
bflushchars();
|
||||||
while (keystatus[0x1] == 0)
|
while (keystatus[0x1] == 0)
|
||||||
{
|
{
|
||||||
|
@ -3376,6 +3379,13 @@ void rendertext(short startspr)
|
||||||
|
|
||||||
// ---
|
// ---
|
||||||
sp = &sprite[curspr];
|
sp = &sprite[curspr];
|
||||||
|
if (!doingspace)
|
||||||
|
{
|
||||||
|
dax = sp->x; day = sp->y;
|
||||||
|
daang = sp->ang;
|
||||||
|
}
|
||||||
|
sprite[linebegspr].shade = sprite[curspr].shade;
|
||||||
|
sprite[linebegspr].pal = sprite[curspr].pal;
|
||||||
|
|
||||||
if (ch>=33 && ch<=126 && alphabets[alphidx].pic[ch-33] >= 0)
|
if (ch>=33 && ch<=126 && alphabets[alphidx].pic[ch-33] >= 0)
|
||||||
{
|
{
|
||||||
|
@ -3383,20 +3393,18 @@ void rendertext(short startspr)
|
||||||
|
|
||||||
// mapping char->tilenum
|
// mapping char->tilenum
|
||||||
t = alphabets[alphidx].pic[ch-33];
|
t = alphabets[alphidx].pic[ch-33];
|
||||||
|
j = sp->xrepeat*(hgap+tilesizx[sp->picnum]+tilesizx[t]);
|
||||||
|
|
||||||
|
dax += (j*sintable[daang])>>17;
|
||||||
|
day -= (j*sintable[(daang+512)&2047])>>17;
|
||||||
|
dax += (j*sintable[(sprite[curspr].ang+2560)&2047])>>17;
|
||||||
|
day += (j*sintable[(sprite[curspr].ang+2048)&2047])>>17;
|
||||||
|
|
||||||
// inside(...): too restricitve?
|
|
||||||
// if somebody wants to change this, keep BACKSPACE in mind,
|
|
||||||
// it iterates over sprites of only one sector
|
|
||||||
sect = sprite[curspr].sectnum;
|
sect = sprite[curspr].sectnum;
|
||||||
dax += ((sp->xrepeat*(hgap+tilesizx[sp->picnum]+tilesizx[t])*sintable[daang])>>17);
|
|
||||||
day -= ((sp->xrepeat*(hgap+tilesizx[sp->picnum]+tilesizx[t])*sintable[(daang+512)&2047])>>17);
|
|
||||||
dax += sintable[(sprite[curspr].ang+2560)&2047]>>17;
|
|
||||||
day += sintable[(sprite[curspr].ang+2048)&2047]>>17;
|
|
||||||
|
|
||||||
updatesector(dax,day,§);
|
updatesector(dax,day,§);
|
||||||
if (numsprites < MAXSPRITES && sect >= 0)
|
if (numsprites < MAXSPRITES && sect >= 0)
|
||||||
{
|
{
|
||||||
i = insertsprite(sprite[curspr].sectnum,0);
|
i = insertsprite(sect,0);
|
||||||
sprite[i].x = dax, sprite[i].y = day;
|
sprite[i].x = dax, sprite[i].y = day;
|
||||||
sprite[i].z = sprite[curspr].z;
|
sprite[i].z = sprite[curspr].z;
|
||||||
sprite[i].cstat = (sprite[curspr].cstat | 16) & ~(32|128);
|
sprite[i].cstat = (sprite[curspr].cstat | 16) & ~(32|128);
|
||||||
|
@ -3428,68 +3436,59 @@ void rendertext(short startspr)
|
||||||
localartfreq[sprite[k].picnum]++;
|
localartfreq[sprite[k].picnum]++;
|
||||||
|
|
||||||
curspr = i;
|
curspr = i;
|
||||||
|
doingspace = 0;
|
||||||
|
|
||||||
updatenumsprites();
|
updatenumsprites();
|
||||||
asksave = 1;
|
asksave = 1;
|
||||||
|
|
||||||
|
if (numletters >= stackallocsize)
|
||||||
|
{
|
||||||
|
stackallocsize *= 2;
|
||||||
|
spritenums = Brealloc(spritenums, stackallocsize*sizeof(short));
|
||||||
|
if (!spritenums) goto ERROR1;
|
||||||
|
}
|
||||||
|
spritenums[numletters++] = i;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
else if (ch == 32)
|
else if (ch == 32)
|
||||||
{
|
{
|
||||||
dax += ((sp->xrepeat*spcgap[alphidx]*sintable[daang])>>17);
|
dax += ((sp->xrepeat*spcgap[alphidx]*sintable[daang])>>17);
|
||||||
day -= ((sp->xrepeat*spcgap[alphidx]*sintable[(daang+512)&2047])>>17);
|
day -= ((sp->xrepeat*spcgap[alphidx]*sintable[(daang+512)&2047])>>17);
|
||||||
|
doingspace = 1;
|
||||||
}
|
}
|
||||||
else if (ch == 8 || ch == 127) // backspace
|
else if (ch == 8 || ch == 127) // backspace
|
||||||
{
|
{
|
||||||
int64 damindist=0x7fffffffffffffffULL, tdist;
|
if (numletters > 0)
|
||||||
short daspr = -1;
|
|
||||||
spritetype *ls, *ks;
|
|
||||||
|
|
||||||
for (k=headspritesect[sp->sectnum]; k>=0; k=nextspritesect[k])
|
|
||||||
{
|
{
|
||||||
if (k!=curspr && sprite[k].ang==daang && sprite[k].z==sp->z)
|
numletters--;
|
||||||
{
|
// message ("Deleted sprite %d.", spritenums[numletters]);
|
||||||
ls = &sprite[linebegspr];
|
deletesprite(spritenums[numletters]);
|
||||||
ks = &sprite[k];
|
|
||||||
|
|
||||||
// true if k is inside the rectangular region defined by linebegspr,
|
if (numletters > 0)
|
||||||
// curspr and the coordinate system on the XY plane (good enough?)
|
curspr = spritenums[numletters-1];
|
||||||
if ((ks->x - ls->x)*(ks->x - sp->x) <= 0 &&
|
else
|
||||||
(ks->y - ls->y)*(ks->y - sp->y) <= 0)
|
curspr = linebegspr;
|
||||||
if ((tdist=ldistsqr(sp, &sprite[k])) < damindist)
|
doingspace = 0;
|
||||||
{
|
|
||||||
damindist = tdist;
|
|
||||||
daspr = k;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
if (daspr >= 0)
|
sprite[linebegspr].z = sprite[curspr].z;
|
||||||
{
|
updatenumsprites();
|
||||||
if (curspr != linebegspr)
|
asksave = 1;
|
||||||
{
|
|
||||||
// message ("Deleted sprite %d.", curspr);
|
|
||||||
deletesprite(curspr);
|
|
||||||
curspr = daspr;
|
|
||||||
dax = sprite[curspr].x;
|
|
||||||
day = sprite[curspr].y;
|
|
||||||
updatenumsprites();
|
|
||||||
asksave=1;
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
else if (ch == 13) // enter
|
else if (ch == 13) // enter
|
||||||
{
|
{
|
||||||
sprite[linebegspr].z += ((sprite[linebegspr].yrepeat*(vgap+tilesizy[basetile]))<<2);
|
sprite[linebegspr].z += ((sprite[linebegspr].yrepeat*(vgap+tilesizy[basetile]))<<2);
|
||||||
sprite[linebegspr].cstat = sprite[curspr].cstat;
|
// sprite[linebegspr].cstat = sprite[curspr].cstat;
|
||||||
sprite[linebegspr].shade = sprite[curspr].shade;
|
|
||||||
sprite[linebegspr].pal = sprite[curspr].pal;
|
|
||||||
curspr = linebegspr;
|
curspr = linebegspr;
|
||||||
dax = sprite[curspr].x;
|
doingspace = 0;
|
||||||
day = sprite[curspr].y;
|
|
||||||
asksave = 1;
|
asksave = 1;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
// ---
|
// ---
|
||||||
|
ERROR1:
|
||||||
|
if (spritenums) Bfree(spritenums);
|
||||||
|
else message("Out of memory!");
|
||||||
|
|
||||||
clearkeys();
|
clearkeys();
|
||||||
|
|
||||||
lockclock = totalclock; //Reset timing
|
lockclock = totalclock; //Reset timing
|
||||||
|
@ -8839,41 +8838,51 @@ static void Keys2d3d(void)
|
||||||
#ifdef _WIN32
|
#ifdef _WIN32
|
||||||
if (keystatus[KEYSC_P]) // Ctrl-P: Map playtesting
|
if (keystatus[KEYSC_P]) // Ctrl-P: Map playtesting
|
||||||
{
|
{
|
||||||
|
static int tp_lastkeypresstime=0;
|
||||||
|
|
||||||
keystatus[KEYSC_P] = 0;
|
keystatus[KEYSC_P] = 0;
|
||||||
|
|
||||||
updatesector(posx, posy, &cursectnum);
|
updatesector(posx, posy, &cursectnum);
|
||||||
if (cursectnum >= 0)
|
if (cursectnum >= 0)
|
||||||
{
|
{
|
||||||
SHELLEXECUTEINFOA sinfo;
|
if (tp_lastkeypresstime+120*4 >= totalclock)
|
||||||
char *prog = "eduke32";
|
message("Please wait while starting Eduke32...");
|
||||||
char *param = " -map autosave.map";
|
|
||||||
char *fullparam;
|
|
||||||
int slen = testplay_addparam ? Bstrlen(testplay_addparam) : 0;
|
|
||||||
|
|
||||||
fullparam = Bmalloc(Bstrlen(param)+slen+1);
|
|
||||||
if (testplay_addparam)
|
|
||||||
Bstrcpy(fullparam, testplay_addparam);
|
|
||||||
else
|
else
|
||||||
fullparam[0]=0;
|
{
|
||||||
Bstrcat(fullparam, param);
|
SHELLEXECUTEINFOA sinfo;
|
||||||
|
char *prog = "eduke32";
|
||||||
|
char *param = " -map autosave.map";
|
||||||
|
char *fullparam;
|
||||||
|
int slen;
|
||||||
|
|
||||||
fixspritesectors(); //Do this before saving!
|
tp_lastkeypresstime = totalclock;
|
||||||
ExtPreSaveMap();
|
|
||||||
saveboard("autosave.map",&posx,&posy,&posz,&ang,&cursectnum);
|
|
||||||
message("Board saved to AUTOSAVE.MAP for test playing");
|
|
||||||
|
|
||||||
Bmemset(&sinfo, 0, sizeof(sinfo));
|
slen = testplay_addparam ? Bstrlen(testplay_addparam) : 0;
|
||||||
sinfo.cbSize = sizeof(sinfo);
|
fullparam = Bmalloc(Bstrlen(param)+slen+1);
|
||||||
sinfo.fMask = SEE_MASK_FLAG_NO_UI;
|
if (testplay_addparam)
|
||||||
sinfo.lpVerb = "open";
|
Bstrcpy(fullparam, testplay_addparam);
|
||||||
sinfo.lpFile = prog;
|
else
|
||||||
sinfo.lpParameters = fullparam;
|
fullparam[0]=0;
|
||||||
sinfo.nShow = SW_SHOWNORMAL;
|
Bstrcat(fullparam, param);
|
||||||
|
|
||||||
if (!ShellExecuteExA(&sinfo))
|
fixspritesectors(); //Do this before saving!
|
||||||
message("Error launching eduke32!");
|
ExtPreSaveMap();
|
||||||
|
saveboard("autosave.map",&posx,&posy,&posz,&ang,&cursectnum);
|
||||||
|
message("Board saved to AUTOSAVE.MAP. Starting Eduke32...");
|
||||||
|
|
||||||
Bfree(fullparam);
|
Bmemset(&sinfo, 0, sizeof(sinfo));
|
||||||
|
sinfo.cbSize = sizeof(sinfo);
|
||||||
|
sinfo.fMask = SEE_MASK_FLAG_NO_UI;
|
||||||
|
sinfo.lpVerb = "open";
|
||||||
|
sinfo.lpFile = prog;
|
||||||
|
sinfo.lpParameters = fullparam;
|
||||||
|
sinfo.nShow = SW_SHOWNORMAL;
|
||||||
|
|
||||||
|
if (!ShellExecuteExA(&sinfo))
|
||||||
|
message("Error launching eduke32!");
|
||||||
|
|
||||||
|
Bfree(fullparam);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
message("Must be in valid player space for test playing.");
|
message("Must be in valid player space for test playing.");
|
||||||
|
|
Loading…
Reference in a new issue