mirror of
https://github.com/ZDoom/raze-gles.git
synced 2025-01-26 00:40:56 +00:00
Rewrite sector duplication (Insert or C) in terms of backup_highlighted_sector
and restore_highlighted_sector functions. What this means is that TROR bunches are now correctly duplicated too (only if all sectors of a given bunch are highlighted). git-svn-id: https://svn.eduke32.com/eduke32@2138 1a8010ca-5511-0410-912e-c29ae57300e0
This commit is contained in:
parent
54c109168d
commit
2ce07bdcd2
1 changed files with 108 additions and 5 deletions
|
@ -148,7 +148,7 @@ typedef struct
|
||||||
} mapinfofull_t;
|
} mapinfofull_t;
|
||||||
|
|
||||||
static int32_t backup_highlighted_map(mapinfofull_t *mapinfo);
|
static int32_t backup_highlighted_map(mapinfofull_t *mapinfo);
|
||||||
static int32_t restore_highlighted_map(mapinfofull_t *mapinfo);
|
static int32_t restore_highlighted_map(mapinfofull_t *mapinfo, int32_t forreal);
|
||||||
static void SaveBoardAndPrintMessage(const char *fn);
|
static void SaveBoardAndPrintMessage(const char *fn);
|
||||||
static const char *GetSaveBoardFilename(void);
|
static const char *GetSaveBoardFilename(void);
|
||||||
|
|
||||||
|
@ -212,7 +212,7 @@ static int16_t loopinside(int32_t x, int32_t y, int16_t startwall);
|
||||||
int32_t fillsector(int16_t sectnum, int32_t fillcolor); // fillcolor == -1: default (pulsating)
|
int32_t fillsector(int16_t sectnum, int32_t fillcolor); // fillcolor == -1: default (pulsating)
|
||||||
static int16_t whitelinescan(int16_t sucksect, int16_t dalinehighlight);
|
static int16_t whitelinescan(int16_t sucksect, int16_t dalinehighlight);
|
||||||
void printcoords16(int32_t posxe, int32_t posye, int16_t ange);
|
void printcoords16(int32_t posxe, int32_t posye, int16_t ange);
|
||||||
static void copysector(int16_t soursector, int16_t destsector, int16_t deststartwall, char copystat, const int16_t *oldtonewsect);
|
//static void copysector(int16_t soursector, int16_t destsector, int16_t deststartwall, char copystat, const int16_t *oldtonewsect);
|
||||||
int32_t drawtilescreen(int32_t pictopleft, int32_t picbox);
|
int32_t drawtilescreen(int32_t pictopleft, int32_t picbox);
|
||||||
void overheadeditor(void);
|
void overheadeditor(void);
|
||||||
static int32_t getlinehighlight(int32_t xplc, int32_t yplc, int32_t line);
|
static int32_t getlinehighlight(int32_t xplc, int32_t yplc, int32_t line);
|
||||||
|
@ -1656,7 +1656,8 @@ static void mapinfofull_free(mapinfofull_t *mapinfo)
|
||||||
// return values:
|
// return values:
|
||||||
// -1: limits exceeded
|
// -1: limits exceeded
|
||||||
// 0: ok
|
// 0: ok
|
||||||
static int32_t restore_highlighted_map(mapinfofull_t *mapinfo)
|
// forreal: if 0, only test if we have enough space (same return values)
|
||||||
|
static int32_t restore_highlighted_map(mapinfofull_t *mapinfo, int32_t forreal)
|
||||||
{
|
{
|
||||||
int32_t i, j, sect, onumsectors=numsectors, newnumsectors, newnumwalls;
|
int32_t i, j, sect, onumsectors=numsectors, newnumsectors, newnumwalls;
|
||||||
|
|
||||||
|
@ -1671,6 +1672,9 @@ static int32_t restore_highlighted_map(mapinfofull_t *mapinfo)
|
||||||
return -1;
|
return -1;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (!forreal)
|
||||||
|
return 0;
|
||||||
|
|
||||||
newnumsectors = numsectors + mapinfo->numsectors;
|
newnumsectors = numsectors + mapinfo->numsectors;
|
||||||
newnumwalls = numwalls + mapinfo->numwalls;
|
newnumwalls = numwalls + mapinfo->numwalls;
|
||||||
|
|
||||||
|
@ -1804,6 +1808,102 @@ void ovh_whiteoutgrab(int32_t restoreredwalls)
|
||||||
mkonwinvalid();
|
mkonwinvalid();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static void duplicate_selected_sectors(void)
|
||||||
|
{
|
||||||
|
mapinfofull_t mapinfo;
|
||||||
|
int32_t i, j, onumsectors;
|
||||||
|
#ifdef YAX_ENABLE
|
||||||
|
int32_t onumyaxbunches;
|
||||||
|
#endif
|
||||||
|
int32_t minx=INT32_MAX, maxx=INT32_MIN, miny=INT32_MAX, maxy=INT32_MIN, dx, dy;
|
||||||
|
|
||||||
|
i = backup_highlighted_map(&mapinfo);
|
||||||
|
|
||||||
|
if (i < 0)
|
||||||
|
{
|
||||||
|
message("Out of memory!");
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
i = restore_highlighted_map(&mapinfo, 0);
|
||||||
|
if (i < 0)
|
||||||
|
{
|
||||||
|
// XXX: no, might be another limit too. Better message needed.
|
||||||
|
printmessage16("Copying sectors would exceed sector or wall limit.");
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
// restoring would succeed, tweak things...
|
||||||
|
Bmemset(hlsectorbitmap, 0, sizeof(hlsectorbitmap));
|
||||||
|
for (i=0; i<highlightsectorcnt; i++)
|
||||||
|
{
|
||||||
|
int32_t startwall, endwall;
|
||||||
|
|
||||||
|
// first, make red lines of old selected sectors, effectively
|
||||||
|
// restoring the original state
|
||||||
|
for (WALLS_OF_SECTOR(highlightsector[i], j))
|
||||||
|
{
|
||||||
|
if (wall[j].nextwall >= 0)
|
||||||
|
checksectorpointer(wall[j].nextwall,wall[j].nextsector);
|
||||||
|
checksectorpointer(j, highlightsector[i]);
|
||||||
|
|
||||||
|
minx = min(minx, wall[j].x);
|
||||||
|
maxx = max(maxx, wall[j].x);
|
||||||
|
miny = min(miny, wall[j].y);
|
||||||
|
maxy = max(maxy, wall[j].y);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
// displace walls & sprites of new sectors by a small amount:
|
||||||
|
// calculate displacement
|
||||||
|
if (grid>0 && grid<9)
|
||||||
|
dx = max(2048>>grid, 128);
|
||||||
|
else
|
||||||
|
dx = 512;
|
||||||
|
dy = -dx;
|
||||||
|
if (maxx+dx >= editorgridextent) dx*=-1;
|
||||||
|
if (minx+dx <= -editorgridextent) dx*=-1;
|
||||||
|
if (maxy+dy >= editorgridextent) dy*=-1;
|
||||||
|
if (miny+dy <= -editorgridextent) dy*=-1;
|
||||||
|
|
||||||
|
onumsectors = numsectors;
|
||||||
|
onumyaxbunches = numyaxbunches;
|
||||||
|
|
||||||
|
// restore! this will not fail.
|
||||||
|
restore_highlighted_map(&mapinfo, 1);
|
||||||
|
|
||||||
|
// displace
|
||||||
|
for (i=onumsectors; i<numsectors; i++)
|
||||||
|
{
|
||||||
|
for (j=sector[i].wallptr; j<sector[i].wallptr+sector[i].wallnum; j++)
|
||||||
|
{
|
||||||
|
wall[j].x += dx;
|
||||||
|
wall[j].y += dy;
|
||||||
|
}
|
||||||
|
|
||||||
|
for (j=headspritesect[i]; j>=0; j=nextspritesect[j])
|
||||||
|
{
|
||||||
|
sprite[j].x += dx;
|
||||||
|
sprite[j].y += dy;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
#ifdef YAX_ENABLE
|
||||||
|
if (numyaxbunches > onumyaxbunches)
|
||||||
|
printmessage16("Sectors duplicated, creating %d new bunches.", numyaxbunches-onumyaxbunches);
|
||||||
|
else
|
||||||
|
#endif
|
||||||
|
printmessage16("Sectors duplicated and stamped.");
|
||||||
|
asksave = 1;
|
||||||
|
|
||||||
|
#ifdef YAX_ENABLE
|
||||||
|
if (numyaxbunches > onumyaxbunches)
|
||||||
|
yax_update(0);
|
||||||
|
#endif
|
||||||
|
yax_updategrays(pos.z);
|
||||||
|
}
|
||||||
|
|
||||||
|
#if 0
|
||||||
static void duplicate_selected_sectors(void)
|
static void duplicate_selected_sectors(void)
|
||||||
{
|
{
|
||||||
int32_t i, j, startwall, endwall, newnumsectors, newwalls = 0;
|
int32_t i, j, startwall, endwall, newnumsectors, newwalls = 0;
|
||||||
|
@ -1930,6 +2030,7 @@ static void duplicate_selected_sectors(void)
|
||||||
printmessage16("Copying sectors would exceed sector or wall limit.");
|
printmessage16("Copying sectors would exceed sector or wall limit.");
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
static void duplicate_selected_sprites(void)
|
static void duplicate_selected_sprites(void)
|
||||||
{
|
{
|
||||||
|
@ -7278,7 +7379,7 @@ CANCEL:
|
||||||
#endif
|
#endif
|
||||||
if (bakstat==0)
|
if (bakstat==0)
|
||||||
{
|
{
|
||||||
bakstat = restore_highlighted_map(&bakmap);
|
bakstat = restore_highlighted_map(&bakmap, 1);
|
||||||
if (bakstat == -1)
|
if (bakstat == -1)
|
||||||
message("Can't copy highlighted portion of old map: limits exceeded.");
|
message("Can't copy highlighted portion of old map: limits exceeded.");
|
||||||
}
|
}
|
||||||
|
@ -7321,7 +7422,7 @@ CANCEL:
|
||||||
|
|
||||||
if (bakstat==0)
|
if (bakstat==0)
|
||||||
{
|
{
|
||||||
bakstat = restore_highlighted_map(&bakmap);
|
bakstat = restore_highlighted_map(&bakmap, 1);
|
||||||
if (bakstat == -1)
|
if (bakstat == -1)
|
||||||
message("Can't copy highlighted portion of old map: limits exceeded.");
|
message("Can't copy highlighted portion of old map: limits exceeded.");
|
||||||
}
|
}
|
||||||
|
@ -9730,6 +9831,7 @@ void updatenumsprites(void)
|
||||||
numsprites += (sprite[i].statnum != MAXSTATUS);
|
numsprites += (sprite[i].statnum != MAXSTATUS);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#if 0
|
||||||
static void copysector(int16_t soursector, int16_t destsector, int16_t deststartwall, char copystat,
|
static void copysector(int16_t soursector, int16_t destsector, int16_t deststartwall, char copystat,
|
||||||
const int16_t *oldtonewsect)
|
const int16_t *oldtonewsect)
|
||||||
{
|
{
|
||||||
|
@ -9825,6 +9927,7 @@ nonextsector:
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
#define DOPRINT(Yofs, fmt, ...) \
|
#define DOPRINT(Yofs, fmt, ...) \
|
||||||
Bsprintf(snotbuf, fmt, ## __VA_ARGS__); \
|
Bsprintf(snotbuf, fmt, ## __VA_ARGS__); \
|
||||||
|
|
Loading…
Reference in a new issue