mirror of
https://github.com/DrBeef/Raze.git
synced 2025-01-18 23:21:43 +00:00
Batch-insertion of many points at once using line drawing and ENTER.
When having drawn N new points (and having one 'free') and pressing ENTER, the N line segments between the new points are checked one by one for intersection with every non-grayed-out wall and a wall vertex is inserted at every intersecting point. This may be viewed as a prerequisite for a 'cutter' style tool. git-svn-id: https://svn.eduke32.com/eduke32@2125 1a8010ca-5511-0410-912e-c29ae57300e0
This commit is contained in:
parent
24edef5c63
commit
45bcc11f46
2 changed files with 100 additions and 13 deletions
|
@ -184,7 +184,7 @@ typedef struct
|
||||||
// bit 8: 1 = y-flipped, 0 = normal "F"
|
// bit 8: 1 = y-flipped, 0 = normal "F"
|
||||||
// bit 9: 1 = Transluscence reversing, 0 = normal "T"
|
// bit 9: 1 = Transluscence reversing, 0 = normal "T"
|
||||||
// bits 10 and 11: reserved (in use by YAX)
|
// bits 10 and 11: reserved (in use by YAX)
|
||||||
// bits 12-15: reserved
|
// bits 12-15: reserved (14: temp use by editor)
|
||||||
|
|
||||||
//32 bytes
|
//32 bytes
|
||||||
typedef struct
|
typedef struct
|
||||||
|
|
|
@ -123,7 +123,7 @@ static int32_t currentlist=0;
|
||||||
//static int32_t repeatcountx, repeatcounty;
|
//static int32_t repeatcountx, repeatcounty;
|
||||||
|
|
||||||
static int32_t fillist[640];
|
static int32_t fillist[640];
|
||||||
// used for fillsector and point selection in side-view mode:
|
// used for fillsector and batch point insertion
|
||||||
static int32_t tempxyar[MAXWALLS][2];
|
static int32_t tempxyar[MAXWALLS][2];
|
||||||
|
|
||||||
static int32_t mousx, mousy;
|
static int32_t mousx, mousy;
|
||||||
|
@ -195,7 +195,7 @@ static int32_t checkautoinsert(int32_t dax, int32_t day, int16_t danumwalls);
|
||||||
void keytimerstuff(void);
|
void keytimerstuff(void);
|
||||||
static int32_t clockdir(int16_t wallstart);
|
static int32_t clockdir(int16_t wallstart);
|
||||||
static void flipwalls(int16_t numwalls, int16_t newnumwalls);
|
static void flipwalls(int16_t numwalls, int16_t newnumwalls);
|
||||||
static int32_t insertpoint(int16_t linehighlight, int32_t dax, int32_t day);
|
static int32_t insertpoint(int16_t linehighlight, int32_t dax, int32_t day, int32_t *mapwallnum);
|
||||||
static const char *deletepoint(int16_t point, int32_t runi);
|
static const char *deletepoint(int16_t point, int32_t runi);
|
||||||
static int32_t deletesector(int16_t sucksect);
|
static int32_t deletesector(int16_t sucksect);
|
||||||
void fixrepeats(int16_t i);
|
void fixrepeats(int16_t i);
|
||||||
|
@ -2552,7 +2552,8 @@ static int32_t bakframe_fillandfade(char **origframeptr, int32_t sectnum, const
|
||||||
|
|
||||||
// high-level insert point, handles TROR constrained walls too
|
// high-level insert point, handles TROR constrained walls too
|
||||||
// onewnumwalls: old numwalls + drawn walls
|
// onewnumwalls: old numwalls + drawn walls
|
||||||
static int32_t M32_InsertPoint(int32_t thewall, int32_t dax, int32_t day, int32_t onewnumwalls)
|
// mapwallnum: see insertpoint()
|
||||||
|
static int32_t M32_InsertPoint(int32_t thewall, int32_t dax, int32_t day, int32_t onewnumwalls, int32_t *mapwallnum)
|
||||||
{
|
{
|
||||||
#ifdef YAX_ENABLE
|
#ifdef YAX_ENABLE
|
||||||
int32_t nextw = wall[thewall].nextwall;
|
int32_t nextw = wall[thewall].nextwall;
|
||||||
|
@ -2586,13 +2587,15 @@ static int32_t M32_InsertPoint(int32_t thewall, int32_t dax, int32_t day, int32_
|
||||||
{
|
{
|
||||||
return 0; // no points inserted, would exceed limits
|
return 0; // no points inserted, would exceed limits
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// the actual insertion!
|
||||||
m = 0;
|
m = 0;
|
||||||
for (i=0; i<numwalls; i++)
|
for (i=0; i<numwalls /* rises with ins. */; i++)
|
||||||
{
|
{
|
||||||
if (wall[i].cstat&(1<<14))
|
if (wall[i].cstat&(1<<14))
|
||||||
if (wall[i].nextwall<0 || i<wall[i].nextwall) // || !(NEXTWALL(i).cstat&(1<<14)) ??
|
if (wall[i].nextwall<0 || i<wall[i].nextwall) // || !(NEXTWALL(i).cstat&(1<<14)) ??
|
||||||
{
|
{
|
||||||
m += insertpoint(i, dax,day);
|
m += insertpoint(i, dax,day, mapwallnum);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -2618,12 +2621,27 @@ static int32_t M32_InsertPoint(int32_t thewall, int32_t dax, int32_t day, int32_
|
||||||
else
|
else
|
||||||
#endif
|
#endif
|
||||||
{
|
{
|
||||||
insertpoint(thewall, dax,day);
|
insertpoint(thewall, dax,day, mapwallnum);
|
||||||
return 1;
|
return 1;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
static int32_t lineintersect2v(const vec2_t *p1, const vec2_t *p2, // line segment 1
|
||||||
|
const vec2_t *q1, const vec2_t *q2, // line segment 2
|
||||||
|
vec2_t *pint)
|
||||||
|
{
|
||||||
|
int32_t intz;
|
||||||
|
return lineintersect(p1->x, p1->y, 0, p2->x, p2->y, 0,
|
||||||
|
q1->x, q1->y, q2->x, q2->y,
|
||||||
|
&pint->x, &pint->y, &intz);
|
||||||
|
}
|
||||||
|
|
||||||
|
static int32_t vec2eq(const vec2_t *v1, const vec2_t *v2)
|
||||||
|
{
|
||||||
|
return (v1->x==v2->x && v1->y==v2->y);
|
||||||
|
}
|
||||||
|
|
||||||
void overheadeditor(void)
|
void overheadeditor(void)
|
||||||
{
|
{
|
||||||
char buffer[80];
|
char buffer[80];
|
||||||
|
@ -4813,7 +4831,6 @@ end_point_dragging:
|
||||||
int32_t askres, joinstat, needsdisp, moveonwp;
|
int32_t askres, joinstat, needsdisp, moveonwp;
|
||||||
int32_t movestat, dx=0,dy=0,dz, delayerr=0;
|
int32_t movestat, dx=0,dy=0,dz, delayerr=0;
|
||||||
|
|
||||||
// tempxyar: int32_t [MAXWALLS][2]
|
|
||||||
int32_t numouterwalls[2] = {0,0}, numowals;
|
int32_t numouterwalls[2] = {0,0}, numowals;
|
||||||
static int16_t outerwall[2][MAXWALLS];
|
static int16_t outerwall[2][MAXWALLS];
|
||||||
const walltype *wal0, *wal1, *wal0p2, *wal1p2;
|
const walltype *wal0, *wal1, *wal0p2, *wal1p2;
|
||||||
|
@ -5696,7 +5713,7 @@ end_join_sectors:
|
||||||
|
|
||||||
if (bad > 0 && goodtogo)
|
if (bad > 0 && goodtogo)
|
||||||
{
|
{
|
||||||
insertpoint(circlewall,dax,day);
|
insertpoint(circlewall,dax,day,NULL);
|
||||||
if (wall[circlewall].nextwall >= 0 && wall[circlewall].nextwall < circlewall)
|
if (wall[circlewall].nextwall >= 0 && wall[circlewall].nextwall < circlewall)
|
||||||
circlewall++;
|
circlewall++;
|
||||||
}
|
}
|
||||||
|
@ -6353,7 +6370,70 @@ end_space_handling:
|
||||||
}
|
}
|
||||||
else // NOT (LCtrl + LShift)
|
else // NOT (LCtrl + LShift)
|
||||||
{
|
{
|
||||||
if (linehighlight >= 0)
|
if (newnumwalls > numwalls) // batch insert points
|
||||||
|
{
|
||||||
|
int32_t numdrawnwalls = newnumwalls-numwalls;
|
||||||
|
vec2_t *point = (vec2_t *)tempxyar; // [MAXWALLS][2]
|
||||||
|
int32_t insdpoints = 0;
|
||||||
|
|
||||||
|
// back up the points of the line strip
|
||||||
|
for (i=0; i<numdrawnwalls+1; i++)
|
||||||
|
{
|
||||||
|
point[i].x = wall[numwalls+i].x;
|
||||||
|
point[i].y = wall[numwalls+i].y;
|
||||||
|
}
|
||||||
|
|
||||||
|
newnumwalls = -1;
|
||||||
|
|
||||||
|
for (i=0; i<numdrawnwalls; i++)
|
||||||
|
{
|
||||||
|
for (j=numwalls-1; j>=0; j--) /* j may be modified in loop */
|
||||||
|
{
|
||||||
|
vec2_t pint;
|
||||||
|
int32_t inspts;
|
||||||
|
|
||||||
|
YAX_SKIPWALL(j);
|
||||||
|
|
||||||
|
if (!lineintersect2v((vec2_t *)&wall[j], (vec2_t *)&POINT2(j),
|
||||||
|
&point[i], &point[i+1], &pint))
|
||||||
|
continue;
|
||||||
|
|
||||||
|
if (vec2eq(&pint, (vec2_t *)&wall[j]) || vec2eq(&pint, (vec2_t *)&POINT2(j)))
|
||||||
|
continue;
|
||||||
|
|
||||||
|
inspts = M32_InsertPoint(j, pint.x, pint.y, -1, &j); /* maybe modify j */
|
||||||
|
|
||||||
|
if (inspts==0)
|
||||||
|
{
|
||||||
|
printmessage16("Wall limit exceeded while inserting points.");
|
||||||
|
goto end_batch_insert_points;
|
||||||
|
}
|
||||||
|
else if (inspts > 0 && inspts < 65536)
|
||||||
|
{
|
||||||
|
insdpoints += inspts;
|
||||||
|
}
|
||||||
|
else // inspts >= 65536
|
||||||
|
{
|
||||||
|
message("ERR: Inserted %d points for constr. wall (exp. %d; %d already ins'd)",
|
||||||
|
inspts&65535, inspts>>16, insdpoints);
|
||||||
|
goto end_batch_insert_points;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
message("Batch-inserted %d points in total", insdpoints);
|
||||||
|
end_batch_insert_points:
|
||||||
|
|
||||||
|
if (insdpoints != 0)
|
||||||
|
{
|
||||||
|
#ifdef YAX_ENABLE
|
||||||
|
yax_updategrays(pos.z);
|
||||||
|
#endif
|
||||||
|
mkonwinvalid();
|
||||||
|
asksave = 1;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else if (linehighlight >= 0)
|
||||||
{
|
{
|
||||||
checksectorpointer(linehighlight,sectorofwall(linehighlight));
|
checksectorpointer(linehighlight,sectorofwall(linehighlight));
|
||||||
printmessage16("Checked pointers of highlighted line.");
|
printmessage16("Checked pointers of highlighted line.");
|
||||||
|
@ -6556,7 +6636,7 @@ point_not_inserted:
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
int32_t insdpoints = M32_InsertPoint(linehighlight, dax, day, onewnumwalls);
|
int32_t insdpoints = M32_InsertPoint(linehighlight, dax, day, onewnumwalls, NULL);
|
||||||
|
|
||||||
if (insdpoints == 0)
|
if (insdpoints == 0)
|
||||||
{
|
{
|
||||||
|
@ -7426,7 +7506,7 @@ static int32_t checkautoinsert(int32_t dax, int32_t day, int16_t danumwalls)
|
||||||
if ((x1 <= dax && dax <= x2) || (x2 <= dax && dax <= x1))
|
if ((x1 <= dax && dax <= x2) || (x2 <= dax && dax <= x1))
|
||||||
if ((y1 <= day && day <= y2) || (y2 <= day && day <= y1))
|
if ((y1 <= day && day <= y2) || (y2 <= day && day <= y1))
|
||||||
if ((dax-x1)*(y2-y1) == (day-y1)*(x2-x1))
|
if ((dax-x1)*(y2-y1) == (day-y1)*(x2-x1))
|
||||||
return(1); //insertpoint((short)i,dax,day);
|
return(1); //insertpoint((short)i,dax,day,NULL);
|
||||||
}
|
}
|
||||||
|
|
||||||
return(0);
|
return(0);
|
||||||
|
@ -7485,7 +7565,10 @@ static void flipwalls(int16_t numwalls, int16_t newnumwalls)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
static int32_t insertpoint(int16_t linehighlight, int32_t dax, int32_t day)
|
// returns number of points inserted (1; or 2 if wall had a nextwall)
|
||||||
|
// *mapwallnum contains the new wallnum of the former (pre-insertpoint) *mapwallnum
|
||||||
|
// (the new one can only be >= than the old one; ptr may be NULL if we don't care)
|
||||||
|
static int32_t insertpoint(int16_t linehighlight, int32_t dax, int32_t day, int32_t *mapwallnum)
|
||||||
{
|
{
|
||||||
int16_t sucksect;
|
int16_t sucksect;
|
||||||
int32_t i, j, k;
|
int32_t i, j, k;
|
||||||
|
@ -7499,6 +7582,8 @@ static int32_t insertpoint(int16_t linehighlight, int32_t dax, int32_t day)
|
||||||
for (i=sucksect+1; i<numsectors; i++)
|
for (i=sucksect+1; i<numsectors; i++)
|
||||||
sector[i].wallptr++;
|
sector[i].wallptr++;
|
||||||
|
|
||||||
|
if (mapwallnum && *mapwallnum >= j+1)
|
||||||
|
(*mapwallnum)++;
|
||||||
movewalls(j+1, +1);
|
movewalls(j+1, +1);
|
||||||
Bmemcpy(&wall[j+1], &wall[j], sizeof(walltype));
|
Bmemcpy(&wall[j+1], &wall[j], sizeof(walltype));
|
||||||
#ifdef YAX_ENABLE
|
#ifdef YAX_ENABLE
|
||||||
|
@ -7522,6 +7607,8 @@ static int32_t insertpoint(int16_t linehighlight, int32_t dax, int32_t day)
|
||||||
for (i=sucksect+1; i<numsectors; i++)
|
for (i=sucksect+1; i<numsectors; i++)
|
||||||
sector[i].wallptr++;
|
sector[i].wallptr++;
|
||||||
|
|
||||||
|
if (mapwallnum && *mapwallnum >= k+1)
|
||||||
|
(*mapwallnum)++;
|
||||||
movewalls(k+1, +1);
|
movewalls(k+1, +1);
|
||||||
Bmemcpy(&wall[k+1], &wall[k], sizeof(walltype));
|
Bmemcpy(&wall[k+1], &wall[k], sizeof(walltype));
|
||||||
#ifdef YAX_ENABLE
|
#ifdef YAX_ENABLE
|
||||||
|
|
Loading…
Reference in a new issue