mirror of
https://github.com/ZDoom/raze-gles.git
synced 2025-01-26 00:40:56 +00:00
Replace dragpoint()'s "dragpoint_noreset" global with a "flags" argument.
Also, add another flag, signifying that from the editor, also the "lastwall"s (i.e. the CCW-linked points) should get collected. This is to signal the editor that their wall lengths should be displayed, too. git-svn-id: https://svn.eduke32.com/eduke32@3394 1a8010ca-5511-0410-912e-c29ae57300e0
This commit is contained in:
parent
898462152c
commit
8fb886b14a
8 changed files with 21 additions and 16 deletions
|
@ -802,7 +802,7 @@ void updatesectorexclude(int32_t x, int32_t y, int16_t *sectnum,
|
||||||
const uint8_t *excludesectbitmap) ATTRIBUTE((nonnull(3,4)));
|
const uint8_t *excludesectbitmap) ATTRIBUTE((nonnull(3,4)));
|
||||||
void updatesectorz(int32_t x, int32_t y, int32_t z, int16_t *sectnum) ATTRIBUTE((nonnull(4)));
|
void updatesectorz(int32_t x, int32_t y, int32_t z, int16_t *sectnum) ATTRIBUTE((nonnull(4)));
|
||||||
int32_t inside(int32_t x, int32_t y, int16_t sectnum);
|
int32_t inside(int32_t x, int32_t y, int16_t sectnum);
|
||||||
void dragpoint(int16_t pointhighlight, int32_t dax, int32_t day);
|
void dragpoint(int16_t pointhighlight, int32_t dax, int32_t day, uint8_t flags);
|
||||||
void setfirstwall(int16_t sectnum, int16_t newfirstwall);
|
void setfirstwall(int16_t sectnum, int16_t newfirstwall);
|
||||||
|
|
||||||
extern const int16_t *chsecptr_onextwall;
|
extern const int16_t *chsecptr_onextwall;
|
||||||
|
|
|
@ -103,8 +103,6 @@ extern int32_t m32_osd_tryscript;
|
||||||
extern int32_t showheightindicators;
|
extern int32_t showheightindicators;
|
||||||
extern int32_t showambiencesounds;
|
extern int32_t showambiencesounds;
|
||||||
|
|
||||||
extern int32_t dragpoint_noreset;
|
|
||||||
|
|
||||||
extern int32_t numgraysects;
|
extern int32_t numgraysects;
|
||||||
extern uint8_t graysectbitmap[MAXSECTORS>>3];
|
extern uint8_t graysectbitmap[MAXSECTORS>>3];
|
||||||
extern uint8_t graywallbitmap[MAXWALLS>>3];
|
extern uint8_t graywallbitmap[MAXWALLS>>3];
|
||||||
|
|
|
@ -4700,6 +4700,7 @@ end_yax: ;
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
int32_t tx, ty, onlySprites=eitherCTRL;
|
int32_t tx, ty, onlySprites=eitherCTRL;
|
||||||
|
int32_t accum_dragged_verts = 0;
|
||||||
|
|
||||||
if (!setop)
|
if (!setop)
|
||||||
{
|
{
|
||||||
|
@ -4739,8 +4740,9 @@ end_yax: ;
|
||||||
{
|
{
|
||||||
if (numgraysects > 0 || m32_sideview)
|
if (numgraysects > 0 || m32_sideview)
|
||||||
{
|
{
|
||||||
dragpoint(i, wall[i].x, wall[i].y);
|
// Only called to find out which walls would get dragged:
|
||||||
dragpoint_noreset = 1; // vvv
|
dragpoint(i, wall[i].x, wall[i].y, accum_dragged_verts);
|
||||||
|
accum_dragged_verts = 1;
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
show2dwall[i>>3] |= (1<<(i&7));
|
show2dwall[i>>3] |= (1<<(i&7));
|
||||||
|
@ -4749,7 +4751,6 @@ end_yax: ;
|
||||||
show2dwall[i>>3] &= ~(1<<(i&7));
|
show2dwall[i>>3] &= ~(1<<(i&7));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
dragpoint_noreset = 0; // ^^^
|
|
||||||
|
|
||||||
if (!sub && (numgraysects > 0 || m32_sideview))
|
if (!sub && (numgraysects > 0 || m32_sideview))
|
||||||
{
|
{
|
||||||
|
@ -5458,7 +5459,7 @@ end_after_dragging:
|
||||||
goto end_point_dragging;
|
goto end_point_dragging;
|
||||||
}
|
}
|
||||||
|
|
||||||
dragpoint(pointhighlight,dax,day);
|
dragpoint(pointhighlight,dax,day,2);
|
||||||
if ((unsigned)linehighlight < MAXWALLS)
|
if ((unsigned)linehighlight < MAXWALLS)
|
||||||
wall[linehighlight].cstat |= (1<<14);
|
wall[linehighlight].cstat |= (1<<14);
|
||||||
wall[lastwall(pointhighlight)].cstat |= (1<<14);
|
wall[lastwall(pointhighlight)].cstat |= (1<<14);
|
||||||
|
|
|
@ -11889,8 +11889,10 @@ void neartag(int32_t xs, int32_t ys, int32_t zs, int16_t sectnum, int16_t ange,
|
||||||
//
|
//
|
||||||
// dragpoint
|
// dragpoint
|
||||||
//
|
//
|
||||||
int32_t dragpoint_noreset = 0;
|
// flags:
|
||||||
void dragpoint(int16_t pointhighlight, int32_t dax, int32_t day)
|
// 1: don't reset walbitmap[] (the bitmap of already dragged vertices)
|
||||||
|
// 2: In the editor, do wall[].cstat |= (1<<14) also for the lastwall().
|
||||||
|
void dragpoint(int16_t pointhighlight, int32_t dax, int32_t day, uint8_t flags)
|
||||||
#ifdef YAX_ENABLE
|
#ifdef YAX_ENABLE
|
||||||
{
|
{
|
||||||
int32_t i, numyaxwalls=0;
|
int32_t i, numyaxwalls=0;
|
||||||
|
@ -11898,7 +11900,7 @@ void dragpoint(int16_t pointhighlight, int32_t dax, int32_t day)
|
||||||
|
|
||||||
uint8_t *const walbitmap = (uint8_t *)tempbuf;
|
uint8_t *const walbitmap = (uint8_t *)tempbuf;
|
||||||
|
|
||||||
if (!dragpoint_noreset)
|
if ((flags&1)==0)
|
||||||
Bmemset(walbitmap, 0, (numwalls+7)>>3);
|
Bmemset(walbitmap, 0, (numwalls+7)>>3);
|
||||||
yaxwalls[numyaxwalls++] = pointhighlight;
|
yaxwalls[numyaxwalls++] = pointhighlight;
|
||||||
|
|
||||||
|
@ -11973,7 +11975,11 @@ void dragpoint(int16_t pointhighlight, int32_t dax, int32_t day)
|
||||||
// TODO: extern a separate bitmap instead?
|
// TODO: extern a separate bitmap instead?
|
||||||
for (w=0; w<numwalls; w++)
|
for (w=0; w<numwalls; w++)
|
||||||
if (walbitmap[w>>3] & (1<<(w&7)))
|
if (walbitmap[w>>3] & (1<<(w&7)))
|
||||||
|
{
|
||||||
wall[w].cstat |= (1<<14);
|
wall[w].cstat |= (1<<14);
|
||||||
|
if (flags&2)
|
||||||
|
wall[lastwall(w)].cstat |= (1<<14);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
#else
|
#else
|
||||||
|
|
|
@ -667,7 +667,7 @@ static void A_MoveSector(int32_t i)
|
||||||
for (; x<endwall; x++)
|
for (; x<endwall; x++)
|
||||||
{
|
{
|
||||||
rotatepoint(0,0,msx[j],msy[j],k&2047,&tx,&ty);
|
rotatepoint(0,0,msx[j],msy[j],k&2047,&tx,&ty);
|
||||||
dragpoint(x,s->x+tx,s->y+ty);
|
dragpoint(x,s->x+tx,s->y+ty,0);
|
||||||
|
|
||||||
j++;
|
j++;
|
||||||
}
|
}
|
||||||
|
@ -7082,8 +7082,8 @@ ACTOR_STATIC void G_MoveEffectors(void) //STATNUM 3
|
||||||
j = nextj;
|
j = nextj;
|
||||||
}
|
}
|
||||||
|
|
||||||
dragpoint((int16_t)t[1],wall[t[1]].x+x,wall[t[1]].y+l);
|
dragpoint((int16_t)t[1],wall[t[1]].x+x,wall[t[1]].y+l,0);
|
||||||
dragpoint((int16_t)t[2],wall[t[2]].x+x,wall[t[2]].y+l);
|
dragpoint((int16_t)t[2],wall[t[2]].x+x,wall[t[2]].y+l,0);
|
||||||
|
|
||||||
for (TRAVERSE_CONNECT(p))
|
for (TRAVERSE_CONNECT(p))
|
||||||
{
|
{
|
||||||
|
|
|
@ -8246,7 +8246,7 @@ static void Keys2d(void)
|
||||||
j = getnumber16(tempbuf, j, editorgridextent, 1);
|
j = getnumber16(tempbuf, j, editorgridextent, 1);
|
||||||
Bsprintf(tempbuf, "Wall %d y: ", i);
|
Bsprintf(tempbuf, "Wall %d y: ", i);
|
||||||
k = getnumber16(tempbuf, k, editorgridextent, 1);
|
k = getnumber16(tempbuf, k, editorgridextent, 1);
|
||||||
dragpoint(i, j, k);
|
dragpoint(i, j, k, 0);
|
||||||
printmessage16("Wall %d updated", i);
|
printmessage16("Wall %d updated", i);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -2183,7 +2183,7 @@ nullquote:
|
||||||
CON_ERRPRINTF("Invalid wall %d\n", wallnum);
|
CON_ERRPRINTF("Invalid wall %d\n", wallnum);
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
dragpoint(wallnum,newx,newy);
|
dragpoint(wallnum,newx,newy,0);
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -2115,7 +2115,7 @@ badindex:
|
||||||
M32_ERROR("Invalid wall %d", wallnum);
|
M32_ERROR("Invalid wall %d", wallnum);
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
dragpoint(wallnum,newx,newy);
|
dragpoint(wallnum,newx,newy,0);
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue