New sector selection mode in 2d mode: if RCtrl is pressed when releasing RAlt, then instead of the sector having to be contained in the rectangle, the mouse pointer must be inside a sector to be selected. This way it's easy to select sectors with arbitrary shapes. Set ops work independently of it, too. Also some annoyance fixes with sprite movement.

git-svn-id: https://svn.eduke32.com/eduke32@1816 1a8010ca-5511-0410-912e-c29ae57300e0
This commit is contained in:
helixhorned 2011-03-02 21:21:47 +00:00
parent 0c9618bc44
commit 0fbd035e54
4 changed files with 360 additions and 164 deletions

View file

@ -61,6 +61,17 @@ extern "C" {
#define PR_LIGHT_PRIO_LOW 4 #define PR_LIGHT_PRIO_LOW 4
#define PR_LIGHT_PRIO_LOW_GAME 5 #define PR_LIGHT_PRIO_LOW_GAME 5
////////// yax defs //////////
#define YAX_BIT 1024
#define YAX_CEILING 0
#define YAX_FLOOR 1
#define YAX_SECTORFLD(Sect,Fld, Cf) (*((uint8_t *)&sector[Sect].ceiling##Fld + (Cf)*((char*)&sector[0].floor##Fld - (char*)&sector[0].ceiling##Fld)))
int16_t yax_getbunch(int16_t i, int16_t cf);
void yax_setbunch(int16_t i, int16_t cf, int16_t bunchnum);
#define CLIPMASK0 (((1L)<<16)+1L) #define CLIPMASK0 (((1L)<<16)+1L)
#define CLIPMASK1 (((256L)<<16)+64L) #define CLIPMASK1 (((256L)<<16)+64L)
@ -577,6 +588,8 @@ int32_t changespritesect(int16_t spritenum, int16_t newsectnum);
int32_t changespritestat(int16_t spritenum, int16_t newstatnum); int32_t changespritestat(int16_t spritenum, int16_t newstatnum);
int32_t setsprite(int16_t spritenum, const vec3_t *new) ATTRIBUTE((nonnull(2))); int32_t setsprite(int16_t spritenum, const vec3_t *new) ATTRIBUTE((nonnull(2)));
int32_t spriteheight(int16_t i, int32_t *basez);
int32_t screencapture(const char *filename, char inverseit) ATTRIBUTE((nonnull(1))); int32_t screencapture(const char *filename, char inverseit) ATTRIBUTE((nonnull(1)));
int32_t getclosestcol(int32_t r, int32_t g, int32_t b); int32_t getclosestcol(int32_t r, int32_t g, int32_t b);

View file

@ -1110,13 +1110,15 @@ void editinput(void)
cz = getceilzofslope(hitinfo.hitsect, hitinfo.pos.x, hitinfo.pos.y); cz = getceilzofslope(hitinfo.hitsect, hitinfo.pos.x, hitinfo.pos.y);
fz = getflorzofslope(hitinfo.hitsect, hitinfo.pos.x, hitinfo.pos.y); fz = getflorzofslope(hitinfo.hitsect, hitinfo.pos.x, hitinfo.pos.y);
j = (tilesizy[sprite[i].picnum]*sprite[i].yrepeat)<<1; j = spriteheight(i, NULL)>>1;
sprite[i].z = hitinfo.pos.z; sprite[i].z = hitinfo.pos.z;
if ((sprite[i].cstat&48)!=32)
{
if ((sprite[i].cstat&128) == 0) if ((sprite[i].cstat&128) == 0)
bclamp(&sprite[i].z, cz+(j<<1), fz); bclamp(&sprite[i].z, cz+(j<<1), fz);
else else
bclamp(&sprite[i].z, cz+j, fz-j); bclamp(&sprite[i].z, cz+j, fz-j);
}
if (searchstat == 0 || searchstat == 4) if (searchstat == 0 || searchstat == 4)
{ {
@ -1796,21 +1798,106 @@ static int32_t copyloop1(int16_t *danumwalls, int32_t *m)
return 0; return 0;
} }
static void updatesprite1(int16_t j) static void updatesprite1(int16_t i)
{ {
int32_t tempint; setsprite(i, (vec3_t *)&sprite[i]);
setsprite(j, (vec3_t *)&sprite[j]); if ((sprite[i].cstat&48)!=32 && sprite[i].sectnum>=0)
tempint = (tilesizy[sprite[j].picnum]*sprite[j].yrepeat)<<2;
if (sprite[j].sectnum>=0)
{ {
sprite[j].z = max(sprite[j].z, getceilzofslope(sprite[j].sectnum,sprite[j].x,sprite[j].y)+tempint); int32_t tempint, cz, fz;
sprite[j].z = min(sprite[j].z, getflorzofslope(sprite[j].sectnum,sprite[j].x,sprite[j].y)); tempint = spriteheight(i, NULL);
if (sprite[i].cstat&128)
tempint >>= 1;
cz = getceilzofslope(sprite[i].sectnum, sprite[i].x,sprite[i].y);
fz = getflorzofslope(sprite[i].sectnum, sprite[i].x,sprite[i].y);
sprite[i].z = max(sprite[i].z, cz+tempint);
sprite[i].z = min(sprite[i].z, fz);
} }
} }
static int32_t ask_if_sure(const char *query, uint32_t flags); static int32_t ask_if_sure(const char *query, uint32_t flags);
static int32_t ask_above_or_below();
// returns:
// 0: continue
// >0: newnumwalls
// <0: error
static int32_t trace_loop(int32_t j, uint8_t *visitedwall, int16_t *ignore_ret, int16_t *refsect_ret)
{
int16_t refsect, ignore;
int32_t k, n, refwall;
if (wall[j].nextwall>=0 || (visitedwall[j>>3]&(1<<(j&7))))
return 0;
n=2*MAXWALLS; // simple inf loop check
refwall = j;
k = numwalls;
ignore = 0;
if (ignore_ret)
{
refsect = -1;
updatesectorexclude(wall[j].x, wall[j].y, &refsect, hlsectorbitmap);
if (refsect<0)
return -1;
}
do
{
if (j!=refwall && visitedwall[j>>3]&(1<<(j&7)))
ignore = 1;
visitedwall[j>>3] |= (1<<(j&7));
if (ignore_ret)
{
if (inside(wall[j].x, wall[j].y, refsect) != 1)
ignore = 1;
}
if (!ignore)
{
if (k>=MAXWALLS)
{
message("Wall limits exceeded while tracing outer loop.");
return -2;
}
Bmemcpy(&wall[k], &wall[j], sizeof(walltype));
wall[k].point2 = k+1;
wall[k].nextsector = wall[k].nextwall = wall[k].extra = -1;
k++;
}
j = wall[j].point2;
n--;
while (wall[j].nextwall>=0 && n>0)
{
j = wall[wall[j].nextwall].point2;
// if (j!=refwall && (visitedwall[j>>3]&(1<<(j&7))))
// ignore = 1;
// visitedwall[j>>3] |= (1<<(j&7));
n--;
}
}
while (j!=refwall && n>0);
if (j!=refwall)
{
message("internal error while tracing outer loop: didn't reach refwall");
return -3;
}
if (ignore_ret)
*ignore_ret = ignore;
if (refsect_ret)
*refsect_ret = refsect;
return k;
}
void overheadeditor(void) void overheadeditor(void)
{ {
@ -2224,7 +2311,7 @@ void overheadeditor(void)
printext16(8,8, editorcolors[13],editorcolors[0],cbuf,0); printext16(8,8, editorcolors[13],editorcolors[0],cbuf,0);
} }
if ((keystatus[0x36] || keystatus[0xb8]) && !eitherCTRL) // RSHIFT || RALT if (keystatus[0x36] || keystatus[0xb8]) // RSHIFT || RALT
{ {
if (keystatus[0x27] || keystatus[0x28]) // ' and ; if (keystatus[0x27] || keystatus[0x28]) // ' and ;
{ {
@ -2252,10 +2339,8 @@ void overheadeditor(void)
x2 = mulscale14(dax-pos.x,zoom); x2 = mulscale14(dax-pos.x,zoom);
y2 = mulscale14(day-pos.y,zoom); y2 = mulscale14(day-pos.y,zoom);
if (wall[linehighlight].nextsector >= 0) drawline16base(halfxdim16+x2,midydim16+y2, 0,0, 0,0,
drawline16base(halfxdim16+x2,midydim16+y2, 0,0, 0,0, editorcolors[15]); wall[linehighlight].nextsector >= 0 ? editorcolors[15] : editorcolors[5]);
else
drawline16base(halfxdim16+x2,midydim16+y2, 0,0, 0,0, editorcolors[5]);
} }
enddrawing(); //}}} enddrawing(); //}}}
@ -2676,16 +2761,50 @@ void overheadeditor(void)
{ {
keystatus[0x12] = 0; keystatus[0x12] = 0;
if (!eitherCTRL)
{
if (pointhighlight >= 16384) if (pointhighlight >= 16384)
{ {
i = pointhighlight-16384; i = pointhighlight-16384;
Bsprintf(buffer, "Sprite (%d) Status list: ", i); Bsprintf(buffer, "Sprite (%d) Status list: ", i);
changespritestat(i, getnumber16(buffer, sprite[i].statnum, 65535, 0)); changespritestat(i, getnumber16(buffer, sprite[i].statnum, MAXSTATUS-1, 0));
// clearmidstatbar16(); // clearmidstatbar16();
// showspritedata((int16_t)i); // showspritedata((int16_t)i);
}
// printmessage16(""); // printmessage16("");
} }
}
else if (highlightsectorcnt > 0&&0)
{
////////// YAX //////////
static const char *cfs[2] = {"ceiling", "floor"};
int32_t cf, good, thez;
cf = ask_above_or_below();
if (!cf)
goto end_yax;
cf--;
good = (highlightsectorcnt==1 || (YAX_SECTORFLD(highlightsector[0],stat, cf)&2)==0);
thez = YAX_SECTORFLD(highlightsector[0],z, cf);
for (i=1; i<highlightsectorcnt; i++)
{
if (YAX_SECTORFLD(highlightsector[i],z, cf) != thez)
{
message("All sectors must have the same %s height", cfs[cf]);
goto end_yax;
}
if ((YAX_SECTORFLD(highlightsector[i],stat, cf)&2)!=0)
{
message("Sector %ss must not be sloped", cfs[cf]);
goto end_yax;
}
}
end_yax: ;
}
}
if (highlightsectorcnt < 0) if (highlightsectorcnt < 0)
{ {
@ -2724,12 +2843,13 @@ void overheadeditor(void)
if (highlighty1 > highlighty2) if (highlighty1 > highlighty2)
swaplong(&highlighty1, &highlighty2); swaplong(&highlighty1, &highlighty2);
// Ctrl+RShift: select all wall-points of highlighted wall's loop:
if (eitherCTRL) if (eitherCTRL)
{ {
Bmemset(show2dwall, 0, sizeof(show2dwall)); Bmemset(show2dwall, 0, sizeof(show2dwall));
Bmemset(show2dsprite, 0, sizeof(show2dsprite)); Bmemset(show2dsprite, 0, sizeof(show2dsprite));
if ((linehighlight >= 0) && (linehighlight < MAXWALLS)) if (linehighlight >= 0 && linehighlight < MAXWALLS)
{ {
i = linehighlight; i = linehighlight;
do do
@ -2792,6 +2912,8 @@ void overheadeditor(void)
if (keystatus[0xb8]) //Right alt (sector highlighting) if (keystatus[0xb8]) //Right alt (sector highlighting)
{ {
if (highlightsectorcnt == 0) if (highlightsectorcnt == 0)
{
if (!eitherCTRL)
{ {
int32_t xx[] = { highlightx1, highlightx1, searchx, searchx, highlightx1 }; int32_t xx[] = { highlightx1, highlightx1, searchx, searchx, highlightx1 };
int32_t yy[] = { highlighty1, searchy, searchy, highlighty1, highlighty1 }; int32_t yy[] = { highlighty1, searchy, searchy, highlighty1, highlighty1 };
@ -2802,6 +2924,7 @@ void overheadeditor(void)
plotlines2d(xx, yy, 5, editorcolors[10]); plotlines2d(xx, yy, 5, editorcolors[10]);
} }
}
else else
{ {
int32_t didmakered = (highlightsectorcnt<0), hadouterpoint=0; int32_t didmakered = (highlightsectorcnt<0), hadouterpoint=0;
@ -2833,84 +2956,28 @@ void overheadeditor(void)
clearkeys(); clearkeys();
} }
if (!didmakered && !hadouterpoint && newnumwalls<0)
while (!didmakered && !hadouterpoint && newnumwalls<0) // if
{ {
int32_t tmpnumwalls=0, refwall;
uint8_t *visitedwall = Bcalloc((numwalls+7)>>3,1); uint8_t *visitedwall = Bcalloc((numwalls+7)>>3,1);
int16_t ignore, refsect;
int32_t n;
if (!visitedwall) if (!visitedwall)
{ {
message("out of memory!"); message("out of memory!");
break; goto outtathis;
} }
for (i=0; i<highlightsectorcnt; i++)
tmpnumwalls += sector[highlightsector[i]].wallnum;
for (i=0; i<highlightsectorcnt; i++) for (i=0; i<highlightsectorcnt; i++)
{ {
for (WALLS_OF_SECTOR(highlightsector[i], j)) for (WALLS_OF_SECTOR(highlightsector[i], j))
{ {
int16_t refsect, ignore; k = trace_loop(j, visitedwall, &ignore, &refsect);
int32_t n; if (k == 0)
if (wall[j].nextwall>=0 || (visitedwall[j>>3]&(1<<(j&7))))
continue; continue;
else if (k < 0)
n=2*tmpnumwalls; // simple inf loop check
refwall = j;
k = numwalls;
ignore = 0;
refsect = -1;
updatesectorexclude(wall[j].x, wall[j].y, &refsect, hlsectorbitmap);
if (refsect<0)
goto outtathis; goto outtathis;
do
{
if (j!=refwall && visitedwall[j>>3]&(1<<(j&7)))
ignore = 1;
visitedwall[j>>3] |= (1<<(j&7));
if (inside(wall[j].x, wall[j].y, refsect)!=1)
ignore = 1;
if (!ignore)
{
if (k>=MAXWALLS)
{
message("Wall limits exceeded while tracing outer loop.");
goto outtathis;
}
Bmemcpy(&wall[k], &wall[j], sizeof(walltype));
wall[k].point2 = k+1;
wall[k].nextsector = wall[k].nextwall = wall[k].extra = -1;
k++;
}
j = wall[j].point2;
n--;
while (wall[j].nextwall>=0 && n>0)
{
j = wall[wall[j].nextwall].point2;
// if (j!=refwall && (visitedwall[j>>3]&(1<<(j&7))))
// ignore = 1;
// visitedwall[j>>3] |= (1<<(j&7));
n--;
}
}
while (j!=refwall && n>0);
if (j!=refwall)
{
message("internal error while tracing outer loop: didn't reach refwall");
goto outtathis;
}
if (!ignore) if (!ignore)
{ {
wall[k-1].point2 = numwalls; // close the loop wall[k-1].point2 = numwalls; // close the loop
@ -2967,15 +3034,14 @@ void overheadeditor(void)
} }
outtathis: outtathis:
newnumwalls = -1; newnumwalls = -1;
if (visitedwall)
Bfree(visitedwall); Bfree(visitedwall);
}
break; // --|
} // <---------/
highlightx1 = searchx; highlightx1 = searchx;
highlighty1 = searchy; highlighty1 = searchy;
highlightx2 = searchx; highlightx2 = searchx;
highlighty2 = searchx; highlighty2 = searchy;
highlightsectorcnt = 0; highlightsectorcnt = 0;
} }
} }
@ -2984,19 +3050,29 @@ outtathis:
if (highlightsectorcnt == 0) if (highlightsectorcnt == 0)
{ {
int32_t add=keystatus[0x28], sub=(!add && keystatus[0x27]), setop=(add||sub); int32_t add=keystatus[0x28], sub=(!add && keystatus[0x27]), setop=(add||sub);
int32_t pointsel = eitherCTRL;
getpoint(highlightx1,highlighty1, &highlightx1,&highlighty1); getpoint(highlightx1,highlighty1, &highlightx1,&highlighty1);
getpoint(highlightx2,highlighty2, &highlightx2,&highlighty2); getpoint(highlightx2,highlighty2, &highlightx2,&highlighty2);
if (!pointsel)
{
if (highlightx1 > highlightx2) if (highlightx1 > highlightx2)
swaplong(&highlightx1, &highlightx2); swaplong(&highlightx1, &highlightx2);
if (highlighty1 > highlighty2) if (highlighty1 > highlighty2)
swaplong(&highlighty1, &highlighty2); swaplong(&highlighty1, &highlighty2);
}
if (!setop) if (!setop)
Bmemset(hlsectorbitmap, 0, sizeof(hlsectorbitmap)); Bmemset(hlsectorbitmap, 0, sizeof(hlsectorbitmap));
for (i=0; i<numsectors; i++) for (i=0; i<numsectors; i++)
{
if (pointsel)
{
bad = (inside(highlightx2, highlighty2, i)!=1);
}
else
{ {
bad = 0; bad = 0;
for (WALLS_OF_SECTOR(i, j)) for (WALLS_OF_SECTOR(i, j))
@ -3007,6 +3083,8 @@ outtathis:
if (wall[j].y > highlighty2) bad = 1; if (wall[j].y > highlighty2) bad = 1;
if (bad == 1) break; if (bad == 1) break;
} }
}
if (bad == 0) if (bad == 0)
{ {
if (sub) if (sub)
@ -3026,6 +3104,9 @@ outtathis:
update_highlightsector(); update_highlightsector();
ovh_whiteoutgrab(); ovh_whiteoutgrab();
if (highlightsectorcnt>0)
printmessage16("Total selected sectors: %d", highlightsectorcnt);
} }
} }
} }
@ -3145,7 +3226,7 @@ end_after_dragging:
break; break;
} }
if ((cursectorhighlight >= 0) && (cursectorhighlight < numsectors)) if (cursectorhighlight >= 0 && cursectorhighlight < numsectors)
{ {
// for (i=0; i<highlightsectorcnt; i++) // for (i=0; i<highlightsectorcnt; i++)
// if (cursectorhighlight == highlightsector[i]) // if (cursectorhighlight == highlightsector[i])
@ -3200,7 +3281,7 @@ end_after_dragging:
} }
} }
else else //if (highlightsectorcnt <= 0)
{ {
if ((bstatus&1) > (oldmousebstatus&1)) if ((bstatus&1) > (oldmousebstatus&1))
pointhighlight = getpointhighlight(mousxplc, mousyplc, pointhighlight); pointhighlight = getpointhighlight(mousxplc, mousyplc, pointhighlight);
@ -3286,7 +3367,7 @@ end_after_dragging:
if (setsprite(daspr, &vec) == -1 && osec>=0) if (setsprite(daspr, &vec) == -1 && osec>=0)
Bmemcpy(&sprite[daspr], &ovec, sizeof(vec3_t)); Bmemcpy(&sprite[daspr], &ovec, sizeof(vec3_t));
#if 0 #if 0
daz = ((tilesizy[sprite[daspr].picnum]*sprite[daspr].yrepeat)<<2); daz = spriteheight(daspr, NULL);
for (i=0; i<numsectors; i++) for (i=0; i<numsectors; i++)
if (inside(dax,day,i) == 1) if (inside(dax,day,i) == 1)
@ -3414,7 +3495,7 @@ end_point_dragging:
else else
{ {
m32_sideview = !m32_sideview; m32_sideview = !m32_sideview;
message("Side view %s", m32_sideview?"enabled":"disabled"); printmessage16("Side view %s", m32_sideview?"enabled":"disabled");
m32_setkeyfilter(1); m32_setkeyfilter(1);
} }
@ -3673,6 +3754,7 @@ end_point_dragging:
deletesector(joinsector[1]); deletesector(joinsector[1]);
printmessage16("Sectors joined."); printmessage16("Sectors joined.");
asksave = 1;
} }
joinsector[0] = -1; joinsector[0] = -1;
@ -3747,8 +3829,9 @@ end_join_sectors:
else else
{ {
sprite[i].z = getflorzofslope(sucksect,dax,day); sprite[i].z = getflorzofslope(sucksect,dax,day);
if ((sprite[i].cstat&128) != 0) // if (sprite[i].cstat&128)
sprite[i].z -= ((tilesizy[sprite[i].picnum]*sprite[i].yrepeat)<<1); // sprite[i].z -= spriteheight(i, NULL)>>1;
// PK // PK
if (prefixarg) if (prefixarg)
{ {
@ -5044,6 +5127,35 @@ static int32_t ask_if_sure(const char *query, uint32_t flags)
return 0; return 0;
} }
static int32_t ask_above_or_below()
{
char ch;
int32_t ret=0;
_printmessage16("Extend above (a) or below (z)?");
showframe(1);
bflushchars();
while ((keystatus[1]|keystatus[0x2e]) == 0 && ret==0)
{
if (handleevents())
quitevent = 0;
idle();
ch = bgetchar();
if (ch == 'a' || ch == 'A')
ret = 1;
else if (ch == 'z' || ch == 'Z')
ret = 2;
}
clearkeys();
return ret;
}
// flags: 1:no ExSaveMap (backup.map) // flags: 1:no ExSaveMap (backup.map)
const char *SaveBoard(const char *fn, uint32_t flags) const char *SaveBoard(const char *fn, uint32_t flags)
{ {
@ -5527,7 +5639,7 @@ void fixspritesectors(void)
if (inside(dax,day,sprite[i].sectnum) != 1) if (inside(dax,day,sprite[i].sectnum) != 1)
{ {
daz = (tilesizy[sprite[i].picnum]*sprite[i].yrepeat)<<2; daz = spriteheight(i, NULL);
for (j=0; j<numsectors; j++) for (j=0; j<numsectors; j++)
if (inside(dax,day, j) == 1 if (inside(dax,day, j) == 1
@ -6326,12 +6438,11 @@ int32_t fillsector(int16_t sectnum, char fillcolor)
endwall = startwall + sector[sectnum].wallnum - 1; endwall = startwall + sector[sectnum].wallnum - 1;
for (z=startwall; z<=endwall; z++) for (z=startwall; z<=endwall; z++)
{ {
y1 = (((wall[z].y-pos.y)*zoom)>>14)+midydim16; y1 = midydim16 + (((wall[z].y-pos.y)*zoom)>>14);
y2 = (((POINT2(z).y-pos.y)*zoom)>>14)+midydim16; y2 = midydim16 + (((POINT2(z).y-pos.y)*zoom)>>14);
if (y1 < miny) miny = y1;
if (y2 < miny) miny = y2; miny = min(miny, min(y1, y2));
if (y1 > maxy) maxy = y1; maxy = max(maxy, max(y1, y2));
if (y2 > maxy) maxy = y2;
} }
if (miny < uborder) miny = uborder; if (miny < uborder) miny = uborder;
@ -6340,7 +6451,7 @@ int32_t fillsector(int16_t sectnum, char fillcolor)
//+((totalclock>>2)&3) //+((totalclock>>2)&3)
for (sy=miny; sy<=maxy; sy+=3) // JBF 20040116: numframes%3 -> (totalclock>>2)&3 for (sy=miny; sy<=maxy; sy+=3) // JBF 20040116: numframes%3 -> (totalclock>>2)&3
{ {
y = pos.y+(((sy-midydim16)<<14)/zoom); y = pos.y + ((sy-midydim16)<<14)/zoom;
fillist[0] = lborder; fillcnt = 1; fillist[0] = lborder; fillcnt = 1;
for (z=startwall; z<=endwall; z++) for (z=startwall; z<=endwall; z++)
@ -6349,28 +6460,29 @@ int32_t fillsector(int16_t sectnum, char fillcolor)
y1 = wall[z].y; y2 = POINT2(z).y; y1 = wall[z].y; y2 = POINT2(z).y;
if (y1 > y2) if (y1 > y2)
{ {
tempint = x1; x1 = x2; x2 = tempint; swaplong(&x1, &x2);
tempint = y1; y1 = y2; y2 = tempint; swaplong(&y1, &y2);
} }
if ((y1 <= y) && (y2 > y))
if (y1 <= y && y < y2)
//if (x1*(y-y2) + x2*(y1-y) <= 0) //if (x1*(y-y2) + x2*(y1-y) <= 0)
{ {
if (fillcnt == sizeof(fillist)/sizeof(fillist[0]))
break;
dax = x1 + scale(y-y1, x2-x1, y2-y1); dax = x1 + scale(y-y1, x2-x1, y2-y1);
dax = (((dax-pos.x)*zoom)>>14)+halfxdim16; dax = halfxdim16 + (((dax-pos.x)*zoom)>>14);
if (dax >= lborder) if (dax >= lborder)
fillist[fillcnt++] = dax; fillist[fillcnt++] = dax;
} }
} }
if (fillcnt > 0) if (fillcnt > 0)
{ {
for (z=1; z<fillcnt; z++) for (z=1; z<fillcnt; z++)
for (zz=0; zz<z; zz++) for (zz=0; zz<z; zz++)
if (fillist[z] < fillist[zz]) if (fillist[z] < fillist[zz])
{ swaplong(&fillist[z], &fillist[zz]);
tempint = fillist[z];
fillist[z] = fillist[zz];
fillist[zz] = tempint;
}
for (z=(fillcnt&1); z<fillcnt-1; z+=2) for (z=(fillcnt&1); z<fillcnt-1; z+=2)
{ {
@ -6378,11 +6490,13 @@ int32_t fillsector(int16_t sectnum, char fillcolor)
break; break;
if (fillist[z+1] > rborder) if (fillist[z+1] > rborder)
fillist[z+1] = rborder; fillist[z+1] = rborder;
drawline16(fillist[z],sy, fillist[z+1],sy, 159 //editorcolors[fillcolor] drawline16(fillist[z],sy, fillist[z+1],sy, 159 //editorcolors[fillcolor]
-klabs(sintable[((totalclock<<3)&2047)]>>11)); -klabs(sintable[((totalclock<<3)&2047)]>>11));
} }
} }
} }
return(0); return(0);
} }
@ -6690,11 +6804,15 @@ nonextsector:
while (j >= 0) while (j >= 0)
{ {
m = insertsprite(destsector,sprite[j].statnum); m = insertsprite(destsector,sprite[j].statnum);
if (m>=0) if (m<0)
{ {
message("Some sprites not duplicated because limit was reached.");
break;
}
Bmemcpy(&sprite[m],&sprite[j],sizeof(spritetype)); Bmemcpy(&sprite[m],&sprite[j],sizeof(spritetype));
sprite[m].sectnum = destsector; //Don't let memcpy overwrite sector! sprite[m].sectnum = destsector; //Don't let memcpy overwrite sector!
}
j = nextspritesect[j]; j = nextspritesect[j];
} }
} }

View file

@ -173,6 +173,32 @@ static int16_t maphacklightcnt=0;
static int16_t maphacklight[PR_MAXLIGHTS]; static int16_t maphacklight[PR_MAXLIGHTS];
#endif #endif
////////// YAX //////////
#define YAX_BUNCHNUM(Sect, Cf) (*(int16_t *)(&sector[Sect].ceilingxpanning + 6*Cf))
int16_t yax_getbunch(int16_t i, int16_t cf)
{
if (((*(&sector[i].ceilingstat + cf))&YAX_BIT)==0)
return -1;
return YAX_BUNCHNUM(i, cf);
}
void yax_setbunch(int16_t i, int16_t cf, int16_t bunchnum)
{
if (i<0)
{
*(&sector[i].ceilingstat + cf) &= ~YAX_BIT;
YAX_BUNCHNUM(i, cf) = 0;
return;
}
*(&sector[i].ceilingstat + cf) |= YAX_BIT;
YAX_BUNCHNUM(i, cf) = bunchnum;
}
////////// editor side view ////////// ////////// editor side view //////////
int32_t m32_sideview = 0; int32_t m32_sideview = 0;
int32_t m32_sideelev = 256; // elevation in BUILD degrees, 0..512 int32_t m32_sideelev = 256; // elevation in BUILD degrees, 0..512
@ -6053,6 +6079,7 @@ static inline void keepaway(int32_t *x, int32_t *y, int32_t w)
y1 = clipit[w].y1; dy = clipit[w].y2-y1; y1 = clipit[w].y1; dy = clipit[w].y2-y1;
ox = ksgn(-dy); oy = ksgn(dx); ox = ksgn(-dy); oy = ksgn(dx);
first = (klabs(dx) <= klabs(dy)); first = (klabs(dx) <= klabs(dy));
while (1) while (1)
{ {
if (dx*(*y-y1) > (*x-x1)*dy) return; if (dx*(*y-y1) > (*x-x1)*dy) return;
@ -8929,6 +8956,27 @@ int32_t krecip(int32_t num)
return(krecipasm(num)); return(krecipasm(num));
} }
int32_t spriteheight(int16_t i, int32_t *basez)
{
int32_t hei, flooraligned=((sprite[i].cstat&48)==32);
if (flooraligned)
{
if (basez)
*basez = sprite[i].z;
return 0;
}
hei = (tilesizy[sprite[i].picnum]*sprite[i].yrepeat)<<2;
if (basez)
{
*basez = sprite[i].z;
if (sprite[i].cstat&128)
*basez -= (hei>>1);
}
return hei;
}
// //
// setsprite // setsprite
// //

View file

@ -3692,11 +3692,12 @@ static int32_t spriteonceilingz(int32_t searchwall)
// int32_t z=sprite[searchwall].z; // int32_t z=sprite[searchwall].z;
int32_t z = getceilzofslope(searchsector,sprite[searchwall].x,sprite[searchwall].y); int32_t z = getceilzofslope(searchsector,sprite[searchwall].x,sprite[searchwall].y);
int32_t tmphei = spriteheight(searchwall, NULL);
if (sprite[searchwall].cstat&128) if (sprite[searchwall].cstat&128)
z -= ((tilesizy[sprite[searchwall].picnum]*sprite[searchwall].yrepeat)<<1); z -= tmphei>>1;
if ((sprite[searchwall].cstat&48) != 32) if ((sprite[searchwall].cstat&48) != 32)
z += ((tilesizy[sprite[searchwall].picnum]*sprite[searchwall].yrepeat)<<2); z += tmphei;
return z; return z;
} }
@ -3707,7 +3708,7 @@ static int32_t spriteongroundz(int32_t searchwall)
int32_t z = getflorzofslope(searchsector,sprite[searchwall].x,sprite[searchwall].y); int32_t z = getflorzofslope(searchsector,sprite[searchwall].x,sprite[searchwall].y);
if (sprite[searchwall].cstat&128) if (sprite[searchwall].cstat&128)
z -= ((tilesizy[sprite[searchwall].picnum]*sprite[searchwall].yrepeat)<<1); z -= spriteheight(searchwall, NULL)>>1;
return z; return z;
} }
@ -4271,6 +4272,7 @@ static void mouseaction_movesprites(int32_t *sumxvect, int32_t *sumyvect, int32_
xvect = daxvect; xvect = daxvect;
yvect = dayvect; yvect = dayvect;
// test run
for (ii=0; ii<highlightcnt; ii++) for (ii=0; ii<highlightcnt; ii++)
if (highlight[ii]&16384) if (highlight[ii]&16384)
{ {
@ -4282,6 +4284,7 @@ static void mouseaction_movesprites(int32_t *sumxvect, int32_t *sumyvect, int32_
xvect = (tvec.x - sprite[spi].x)<<14; xvect = (tvec.x - sprite[spi].x)<<14;
yvect = (tvec.y - sprite[spi].y)<<14; yvect = (tvec.y - sprite[spi].y)<<14;
} }
// the real thing
for (ii=0; ii<highlightcnt; ii++) for (ii=0; ii<highlightcnt; ii++)
if (highlight[ii]&16384) if (highlight[ii]&16384)
{ {
@ -4653,7 +4656,7 @@ static void Keys3d(void)
if (AIMING_AT_WALL_OR_MASK && PRESSED_KEYSC(PERIOD)) if (AIMING_AT_WALL_OR_MASK && PRESSED_KEYSC(PERIOD))
{ {
AutoAlignWalls((int32_t)searchwall, 0); AutoAlignWalls(searchwall, 0);
message("Wall %d autoalign", searchwall); message("Wall %d autoalign", searchwall);
} }
@ -4688,7 +4691,7 @@ static void Keys3d(void)
sector[searchsector].ceilingheinum = 0; sector[searchsector].ceilingheinum = 0;
} }
getnumberptr256("Sector ceiling slope: ", &sector[searchsector].ceilingheinum, getnumberptr256("Sector ceiling slope: ", &sector[searchsector].ceilingheinum,
sizeof(sector[0].ceilingheinum), 65536, 1, NULL); sizeof(sector[0].ceilingheinum), 32767, 1, NULL);
break; break;
case SEARCH_FLOOR: case SEARCH_FLOOR:
getnumberptr256("Sector floorz: ", &sector[searchsector].floorz, getnumberptr256("Sector floorz: ", &sector[searchsector].floorz,
@ -4699,7 +4702,7 @@ static void Keys3d(void)
sector[searchsector].floorstat |= 2; sector[searchsector].floorstat |= 2;
} }
getnumberptr256("Sector floor slope: ", &sector[searchsector].floorheinum, getnumberptr256("Sector floor slope: ", &sector[searchsector].floorheinum,
sizeof(sector[0].floorheinum), 65536, 1, NULL); sizeof(sector[0].floorheinum), 32767, 1, NULL);
break; break;
case SEARCH_SPRITE: case SEARCH_SPRITE:
@ -5175,16 +5178,19 @@ static void Keys3d(void)
int16_t sect = k ? highlightsector[0] : int16_t sect = k ? highlightsector[0] :
((AIMING_AT_WALL && wall[searchwall].nextsector>=0 && (eitherALT && !(bstatus&1))) ? ((AIMING_AT_WALL && wall[searchwall].nextsector>=0 && (eitherALT && !(bstatus&1))) ?
wall[searchwall].nextsector : searchsector); wall[searchwall].nextsector : searchsector);
int32_t tmphei;
for (j=0; j<(k?k:1); j++, sect=highlightsector[j]) for (j=0; j<(k?k:1); j++, sect=highlightsector[j])
{ {
for (i=headspritesect[sect]; i!=-1; i=nextspritesect[i]) for (i=headspritesect[sect]; i!=-1; i=nextspritesect[i])
{ {
tmphei = spriteheight(i, NULL);
tempint = getceilzofslope(sect, sprite[i].x, sprite[i].y); tempint = getceilzofslope(sect, sprite[i].x, sprite[i].y);
tempint += (tilesizy[sprite[i].picnum]*sprite[i].yrepeat)<<2; tempint += tmphei;
if (sprite[i].cstat&128) if (sprite[i].cstat&128)
tempint += (tilesizy[sprite[i].picnum]*sprite[i].yrepeat)<<1; tempint += tmphei>>1;
if (sprite[i].z == tempint) if (sprite[i].z == tempint)
sprite[i].z += tsign * (updownunits << (eitherCTRL<<1)); // JBF 20031128 sprite[i].z += tsign * (updownunits << (eitherCTRL<<1)); // JBF 20031128
@ -5205,7 +5211,7 @@ static void Keys3d(void)
tempint = getflorzofslope(sect,sprite[i].x,sprite[i].y); tempint = getflorzofslope(sect,sprite[i].x,sprite[i].y);
if (sprite[i].cstat&128) if (sprite[i].cstat&128)
tempint += ((tilesizy[sprite[i].picnum]*sprite[i].yrepeat)<<1); tempint += spriteheight(i, NULL)>>1;
if (sprite[i].z == tempint) if (sprite[i].z == tempint)
sprite[i].z += tsign * (updownunits << (eitherCTRL<<1)); // JBF 20031128 sprite[i].z += tsign * (updownunits << (eitherCTRL<<1)); // JBF 20031128
@ -6866,7 +6872,7 @@ static void Keys2d(void)
} }
} }
if (PRESSED_KEYSC(E)) // E (expand) if (!eitherCTRL && PRESSED_KEYSC(E)) // E (expand)
{ {
for (i=0; i<numsectors; i++) for (i=0; i<numsectors; i++)
if (inside(mousxplc,mousyplc,i) == 1) if (inside(mousxplc,mousyplc,i) == 1)
@ -7131,8 +7137,7 @@ static void Keys2d(void)
sprite[i].ang &= 2047; sprite[i].ang &= 2047;
printmessage16("Sprite %d updated", i); printmessage16("Sprite %d updated", i);
} }
else if (pointhighlight >= 0)
else if (pointhighlight >= 0 /*<= 16383*/)
{ {
i = linehighlight; i = linehighlight;
j = wall[i].x; j = wall[i].x;
@ -9996,11 +10001,23 @@ void ExtCheckKeys(void)
if (asksave == 1 && (bstatus + lastbstatus) == 0 && mapstate) if (asksave == 1 && (bstatus + lastbstatus) == 0 && mapstate)
{ {
#if 0
int32_t i;
// check keys so that e.g. bunch deletions won't produce
// as much revisions
for (i=sizeof(keystatus)/sizeof(keystatus[0]) - 1; i>=0; i--)
if (keystatus[i])
break;
// message("Saved undo rev %d",map_revision); // message("Saved undo rev %d",map_revision);
if (i==-1)
#endif
{
create_map_snapshot(); create_map_snapshot();
asksave++; asksave++;
} }
else if (asksave == 2) asksave++; }
else if (asksave == 2)
asksave++;
if (totalclock > autosavetimer && autosave) if (totalclock > autosavetimer && autosave)
{ {
@ -10532,7 +10549,7 @@ static void EditSectorData(int16_t sectnum)
break; break;
case 5: case 5:
handlemed(0, "Ceiling heinum", "Ceiling Heinum", &sector[sectnum].ceilingheinum, handlemed(0, "Ceiling heinum", "Ceiling Heinum", &sector[sectnum].ceilingheinum,
sizeof(sector[sectnum].ceilingheinum), 65536L, 1); sizeof(sector[sectnum].ceilingheinum), 32767, 1);
break; break;
case 6: case 6:
handlemed(0, "Palookup number", "Ceiling Palookup Number", &sector[sectnum].ceilingpal, handlemed(0, "Palookup number", "Ceiling Palookup Number", &sector[sectnum].ceilingpal,
@ -10546,7 +10563,7 @@ static void EditSectorData(int16_t sectnum)
{ {
case 0: case 0:
handlemed(1, "Flags (hex)", "Floor Flags", &sector[sectnum].floorstat, handlemed(1, "Flags (hex)", "Floor Flags", &sector[sectnum].floorstat,
sizeof(sector[sectnum].floorstat), 65536, 0); sizeof(sector[sectnum].floorstat), 65535, 0);
break; break;
case 1: case 1:
@ -10576,7 +10593,7 @@ static void EditSectorData(int16_t sectnum)
break; break;
case 5: case 5:
handlemed(0, "Floor heinum", "Floor Heinum", &sector[sectnum].floorheinum, handlemed(0, "Floor heinum", "Floor Heinum", &sector[sectnum].floorheinum,
sizeof(sector[sectnum].floorheinum), 65536, 1); sizeof(sector[sectnum].floorheinum), 32767, 1);
break; break;
case 6: case 6:
handlemed(0, "Palookup number", "Floor Palookup Number", &sector[sectnum].floorpal, handlemed(0, "Palookup number", "Floor Palookup Number", &sector[sectnum].floorpal,
@ -10624,7 +10641,7 @@ static void EditWallData(int16_t wallnum)
{ {
case 0: case 0:
handlemed(1, "Flags (hex)", "Flags", &wall[wallnum].cstat, handlemed(1, "Flags (hex)", "Flags", &wall[wallnum].cstat,
sizeof(wall[wallnum].cstat), 65536L, 0); sizeof(wall[wallnum].cstat), 65535, 0);
break; break;
case 1: case 1:
handlemed(0, "Shade", "Shade", &wall[wallnum].shade, handlemed(0, "Shade", "Shade", &wall[wallnum].shade,
@ -10871,15 +10888,15 @@ static void EditSpriteData(int16_t spritenum)
break; break;
case 1: case 1:
handlemed(0, "X-Velocity", "X-Velocity", &sprite[spritenum].xvel, handlemed(0, "X-Velocity", "X-Velocity", &sprite[spritenum].xvel,
sizeof(sprite[spritenum].xvel), 65536, 1); sizeof(sprite[spritenum].xvel), 65535, 1);
break; break;
case 2: case 2:
handlemed(0, "Y-Velocity", "Y-Velocity", &sprite[spritenum].yvel, handlemed(0, "Y-Velocity", "Y-Velocity", &sprite[spritenum].yvel,
sizeof(sprite[spritenum].yvel), 65536, 1); sizeof(sprite[spritenum].yvel), 65535, 1);
break; break;
case 3: case 3:
handlemed(0, "Z-Velocity", "Z-Velocity", &sprite[spritenum].zvel, handlemed(0, "Z-Velocity", "Z-Velocity", &sprite[spritenum].zvel,
sizeof(sprite[spritenum].zvel), 65536, 1); sizeof(sprite[spritenum].zvel), 65535, 1);
break; break;
case 4: case 4:
handlemed(0, "Owner", "Owner", &sprite[spritenum].owner, handlemed(0, "Owner", "Owner", &sprite[spritenum].owner,
@ -10936,10 +10953,10 @@ static void GenericSpriteSearch()
static int32_t maxval[7][3] = static int32_t maxval[7][3] =
{ {
{ BXY_MAX , 65536 , 2048 }, { BXY_MAX , 65535 , 2048 },
{ BXY_MAX , 128 , 65536 }, { BXY_MAX , 128 , 65535 },
{ BZ_MAX , MAXPALOOKUPS-1, 65536 }, { BZ_MAX , MAXPALOOKUPS-1, 65535 },
{ MAXSECTORS-1, 128 , 65536 }, { MAXSECTORS-1, 128 , 65535 },
{ MAXSTATUS-1 , 128 , MAXSPRITES-1 }, { MAXSTATUS-1 , 128 , MAXSPRITES-1 },
{ BTAG_MAX , MAXTILES-1 , 256 }, { BTAG_MAX , MAXTILES-1 , 256 },
{ BTAG_MAX , 0 , BTAG_MAX } { BTAG_MAX , 0 , BTAG_MAX }