ref: fe531d051d66611d82c233f8a02b435bece34ab6
parent: 61e1333c1d39b26c41478df92307543f379e6746
author: Samuel Villareal <svkaiser@gmail.com>
date: Mon Sep 13 23:42:09 EDT 2010
+ Sliding door implementation Subversion-branch: /branches/strife-branch Subversion-revision: 2084
--- a/src/strife/p_doors.c
+++ b/src/strife/p_doors.c
@@ -41,20 +41,7 @@
#include "dstrings.h"
#include "sounds.h"
-#if 0
-//
-// Sliding door frame information
-//
-slidename_t slideFrameNames[MAXSLIDEDOORS] =
-{
- {"GDOORF1","GDOORF2","GDOORF3","GDOORF4", // front
- "GDOORB1","GDOORB2","GDOORB3","GDOORB4"}, // back
-
- {"\0","\0","\0","\0"}
-};
-#endif
-
//
// VERTICAL DOORS
//
@@ -574,72 +561,186 @@
}
+// villsa [STRIFE] resurrected sliding doors
+//
-// UNUSED
-// Separate into p_slidoor.c?
+//
+// villsa [STRIFE]
+//
+// Sliding door name information
+//
+static slidename_t slideFrameNames[MAXSLIDEDOORS] =
+{
+ // SIGLDR
+ {
+ { "SIGLDR01" }, // frame1
+ { "SIGLDR02" }, // frame2
+ { "SIGLDR03" }, // frame3
+ { "SIGLDR04" }, // frame4
+ { "SIGLDR05" }, // frame5
+ { "SIGLDR06" }, // frame6
+ { "SIGLDR07" }, // frame7
+ { "SIGLDR08" } // frame8
+ },
+ // DORSTN
+ {
+ { "DORSTN01" }, // frame1
+ { "DORSTN02" }, // frame2
+ { "DORSTN03" }, // frame3
+ { "DORSTN04" }, // frame4
+ { "DORSTN05" }, // frame5
+ { "DORSTN06" }, // frame6
+ { "DORSTN07" }, // frame7
+ { "DORSTN08" } // frame8
+ },
-#if 0 // ABANDONED TO THE MISTS OF TIME!!!
+ // DORQTR
+ {
+ { "DORQTR01" }, // frame1
+ { "DORQTR02" }, // frame2
+ { "DORQTR03" }, // frame3
+ { "DORQTR04" }, // frame4
+ { "DORQTR05" }, // frame5
+ { "DORQTR06" }, // frame6
+ { "DORQTR07" }, // frame7
+ { "DORQTR08" } // frame8
+ },
+
+ // DORCRG
+ {
+ { "DORCRG01" }, // frame1
+ { "DORCRG02" }, // frame2
+ { "DORCRG03" }, // frame3
+ { "DORCRG04" }, // frame4
+ { "DORCRG05" }, // frame5
+ { "DORCRG06" }, // frame6
+ { "DORCRG07" }, // frame7
+ { "DORCRG08" } // frame8
+ },
+
+ // DORCHN
+ {
+ { "DORCHN01" }, // frame1
+ { "DORCHN02" }, // frame2
+ { "DORCHN03" }, // frame3
+ { "DORCHN04" }, // frame4
+ { "DORCHN05" }, // frame5
+ { "DORCHN06" }, // frame6
+ { "DORCHN07" }, // frame7
+ { "DORCHN08" } // frame8
+ },
+
+ // DORIRS
+ {
+ { "DORIRS01" }, // frame1
+ { "DORIRS02" }, // frame2
+ { "DORIRS03" }, // frame3
+ { "DORIRS04" }, // frame4
+ { "DORIRS05" }, // frame5
+ { "DORIRS06" }, // frame6
+ { "DORIRS07" }, // frame7
+ { "DORIRS08" } // frame8
+ },
+
+ // DORALN
+ {
+ { "DORALN01" }, // frame1
+ { "DORALN02" }, // frame2
+ { "DORALN03" }, // frame3
+ { "DORALN04" }, // frame4
+ { "DORALN05" }, // frame5
+ { "DORALN06" }, // frame6
+ { "DORALN07" }, // frame7
+ { "DORALN08" } // frame8
+ },
+
+ {"\0","\0","\0","\0","\0","\0","\0","\0"}
+};
+
//
-// EV_SlidingDoor : slide a door horizontally
-// (animate midtexture, then set noblocking line)
+// villsa [STRIFE]
//
+// Sliding door open sounds
+//
+static sfxenum_t slideOpenSounds[MAXSLIDEDOORS] =
+{
+ sfx_drlmto, sfx_drston, sfx_airlck, sfx_drsmto,
+ sfx_drchno, sfx_airlck, sfx_airlck, sfx_None
+};
+//
+// villsa [STRIFE]
+//
+// Sliding door close sounds
+//
+static sfxenum_t slideCloseSounds[MAXSLIDEDOORS] =
+{
+ sfx_drlmtc, sfx_drston, sfx_airlck, sfx_drsmtc,
+ sfx_drchnc, sfx_airlck, sfx_airlck, sfx_None
+};
slideframe_t slideFrames[MAXSLIDEDOORS];
+//
+// P_InitSlidingDoorFrames
+//
+// villsa [STRIFE] resurrected
+//
void P_InitSlidingDoorFrames(void)
{
- int i;
- int f1;
- int f2;
- int f3;
- int f4;
+ int i;
+ int f1;
+ int f2;
+ int f3;
+ int f4;
+
+ memset(slideFrames, 0, sizeof(slideframe_t) * MAXSLIDEDOORS);
- // DOOM II ONLY...
- if ( gamemode != commercial)
- return;
-
- for (i = 0;i < MAXSLIDEDOORS; i++)
+ for(i = 0; i < MAXSLIDEDOORS; i++)
{
- if (!slideFrameNames[i].frontFrame1[0])
+ if(!slideFrameNames[i].frame1[0])
break;
- f1 = R_TextureNumForName(slideFrameNames[i].frontFrame1);
- f2 = R_TextureNumForName(slideFrameNames[i].frontFrame2);
- f3 = R_TextureNumForName(slideFrameNames[i].frontFrame3);
- f4 = R_TextureNumForName(slideFrameNames[i].frontFrame4);
+ f1 = R_TextureNumForName(DEH_String(slideFrameNames[i].frame1));
+ f2 = R_TextureNumForName(DEH_String(slideFrameNames[i].frame2));
+ f3 = R_TextureNumForName(DEH_String(slideFrameNames[i].frame3));
+ f4 = R_TextureNumForName(DEH_String(slideFrameNames[i].frame4));
- slideFrames[i].frontFrames[0] = f1;
- slideFrames[i].frontFrames[1] = f2;
- slideFrames[i].frontFrames[2] = f3;
- slideFrames[i].frontFrames[3] = f4;
+ slideFrames[i].frames[0] = f1;
+ slideFrames[i].frames[1] = f2;
+ slideFrames[i].frames[2] = f3;
+ slideFrames[i].frames[3] = f4;
- f1 = R_TextureNumForName(slideFrameNames[i].backFrame1);
- f2 = R_TextureNumForName(slideFrameNames[i].backFrame2);
- f3 = R_TextureNumForName(slideFrameNames[i].backFrame3);
- f4 = R_TextureNumForName(slideFrameNames[i].backFrame4);
+ f1 = R_TextureNumForName(DEH_String(slideFrameNames[i].frame5));
+ f2 = R_TextureNumForName(DEH_String(slideFrameNames[i].frame6));
+ f3 = R_TextureNumForName(DEH_String(slideFrameNames[i].frame7));
+ f4 = R_TextureNumForName(DEH_String(slideFrameNames[i].frame8));
- slideFrames[i].backFrames[0] = f1;
- slideFrames[i].backFrames[1] = f2;
- slideFrames[i].backFrames[2] = f3;
- slideFrames[i].backFrames[3] = f4;
+ slideFrames[i].frames[4] = f1;
+ slideFrames[i].frames[5] = f2;
+ slideFrames[i].frames[6] = f3;
+ slideFrames[i].frames[7] = f4;
}
}
//
+// P_FindSlidingDoorType
+//
// Return index into "slideFrames" array
// for which door type to use
//
-int P_FindSlidingDoorType(line_t* line)
+// villsa [STRIFE] resurrected
+//
+int P_FindSlidingDoorType(line_t* line)
{
- int i;
- int val;
+ int i;
+ int val;
- for (i = 0;i < MAXSLIDEDOORS;i++)
+ for(i = 0; i < MAXSLIDEDOORS; i++)
{
- val = sides[line->sidenum[0]].midtexture;
- if (val == slideFrames[i].frontFrames[0])
+ val = sides[line->sidenum[0]].toptexture;
+ if(val == slideFrames[i].frames[0])
return i;
}
@@ -646,143 +747,246 @@
return -1;
}
-void T_SlidingDoor (slidedoor_t* door)
+//
+// T_SlidingDoor
+//
+// villsa [STRIFE] resurrected
+//
+void T_SlidingDoor(slidedoor_t* door)
{
+ sector_t* sec;
+
+ sec = door->frontsector;
+
switch(door->status)
{
- case sd_opening:
- if (!door->timer--)
- {
- if (++door->frame == SNUMFRAMES)
- {
- // IF DOOR IS DONE OPENING...
- sides[door->line->sidenum[0]].midtexture = 0;
- sides[door->line->sidenum[1]].midtexture = 0;
- door->line->flags &= ML_BLOCKING^0xff;
-
- if (door->type == sdt_openOnly)
- {
- door->frontsector->specialdata = NULL;
- P_RemoveThinker (&door->thinker);
- break;
- }
-
- door->timer = SDOORWAIT;
- door->status = sd_waiting;
- }
- else
- {
- // IF DOOR NEEDS TO ANIMATE TO NEXT FRAME...
- door->timer = SWAITTICS;
-
- sides[door->line->sidenum[0]].midtexture =
- slideFrames[door->whichDoorIndex].
- frontFrames[door->frame];
- sides[door->line->sidenum[1]].midtexture =
- slideFrames[door->whichDoorIndex].
- backFrames[door->frame];
- }
- }
- break;
-
- case sd_waiting:
- // IF DOOR IS DONE WAITING...
- if (!door->timer--)
- {
- // CAN DOOR CLOSE?
- if (door->frontsector->thinglist != NULL ||
- door->backsector->thinglist != NULL)
- {
- door->timer = SDOORWAIT;
- break;
- }
+ case sd_opening:
+ if(!door->timer--)
+ {
+ if(++door->frame == SNUMFRAMES)
+ {
+ // IF DOOR IS DONE OPENING...
+ door->line1->flags &= ~ML_BLOCKING;
+ door->line2->flags &= ~ML_BLOCKING;
- //door->frame = SNUMFRAMES-1;
- door->status = sd_closing;
- door->timer = SWAITTICS;
- }
- break;
-
- case sd_closing:
- if (!door->timer--)
- {
- if (--door->frame < 0)
- {
- // IF DOOR IS DONE CLOSING...
- door->line->flags |= ML_BLOCKING;
- door->frontsector->specialdata = NULL;
- P_RemoveThinker (&door->thinker);
- break;
- }
- else
- {
- // IF DOOR NEEDS TO ANIMATE TO NEXT FRAME...
- door->timer = SWAITTICS;
-
- sides[door->line->sidenum[0]].midtexture =
- slideFrames[door->whichDoorIndex].
- frontFrames[door->frame];
- sides[door->line->sidenum[1]].midtexture =
- slideFrames[door->whichDoorIndex].
- backFrames[door->frame];
- }
- }
- break;
+ if(door->type == sdt_openOnly)
+ {
+ door->frontsector->specialdata = NULL;
+ P_RemoveThinker (&door->thinker);
+ return;
+ }
+
+ door->timer = SDOORWAIT;
+ door->status = sd_waiting;
+ }
+ else
+ {
+ // IF DOOR NEEDS TO ANIMATE TO NEXT FRAME...
+ door->timer = SWAITTICS;
+
+ sides[door->line2->sidenum[0]].midtexture =
+ slideFrames[door->whichDoorIndex].frames[door->frame];
+
+ sides[door->line2->sidenum[1]].midtexture =
+ slideFrames[door->whichDoorIndex].frames[door->frame];
+
+ sides[door->line1->sidenum[0]].midtexture =
+ slideFrames[door->whichDoorIndex].frames[door->frame];
+
+ sides[door->line1->sidenum[1]].midtexture =
+ slideFrames[door->whichDoorIndex].frames[door->frame];
+ }
+ }
+
+ return;
+
+ case sd_waiting:
+ // IF DOOR IS DONE WAITING...
+ if(!door->timer--)
+ {
+ fixed_t speed;
+ boolean thinglist;
+
+ sec = door->frontsector;
+ thinglist = (sec->thinglist != NULL);
+
+ // CAN DOOR CLOSE?
+ if(thinglist)
+ {
+ door->timer = SDOORWAIT;
+ return;
+ }
+ else
+ {
+
+ speed = sec->ceilingheight -
+ sec->floorheight - (10*FRACUNIT);
+
+ // something blocking it?
+ // [STRIFE] TODO this function here is causing some abnormalites when closing
+ if(T_MovePlane(sec, speed, sec->floorheight, thinglist, 1, -1) == 1)
+ {
+ door->timer = SDOORWAIT;
+ return;
+ }
+ else
+ {
+ // Instantly move plane
+ T_MovePlane(sec, (128*FRACUNIT), sec->ceilingheight, 0, 1, 1);
+
+ // turn line blocking back on
+ door->line1->flags |= ML_BLOCKING;
+ door->line2->flags |= ML_BLOCKING;
+
+ // play close sound
+ S_StartSound(&sec->soundorg, slideCloseSounds[door->whichDoorIndex]);
+
+ door->status = sd_closing;
+ door->timer = SWAITTICS;
+ }
+ }
+ }
+
+ return;
+
+ case sd_closing:
+ if (!door->timer--)
+ {
+ if(--door->frame < 0)
+ {
+ // IF DOOR IS DONE CLOSING...
+ T_MovePlane(sec, (128*FRACUNIT), sec->floorheight, 0, 1, -1);
+ door->frontsector->specialdata = NULL;
+ P_RemoveThinker (&door->thinker);
+ return;
+ }
+ else
+ {
+ // IF DOOR NEEDS TO ANIMATE TO NEXT FRAME...
+ door->timer = SWAITTICS;
+
+ sides[door->line2->sidenum[0]].midtexture =
+ slideFrames[door->whichDoorIndex].frames[door->frame];
+
+ sides[door->line2->sidenum[1]].midtexture =
+ slideFrames[door->whichDoorIndex].frames[door->frame];
+
+ sides[door->line1->sidenum[0]].midtexture =
+ slideFrames[door->whichDoorIndex].frames[door->frame];
+
+ sides[door->line1->sidenum[1]].midtexture =
+ slideFrames[door->whichDoorIndex].frames[door->frame];
+ }
+ }
+
+ return;
}
}
+//
+// EV_RemoteSlidingDoor
+//
+// villsa [STRIFE] TODO
+//
+void EV_RemoteSlidingDoor(line_t* line, mobj_t* thing)
+{
+}
-void
-EV_SlidingDoor
-( line_t* line,
- mobj_t* thing )
+//
+// EV_SlidingDoor
+//
+// villsa [STRIFE]
+//
+void EV_SlidingDoor(line_t* line, mobj_t* thing)
{
- sector_t* sec;
- slidedoor_t* door;
-
- // DOOM II ONLY...
- if (gamemode != commercial)
- return;
-
+ sector_t* sec;
+ slidedoor_t* door;
+ int i;
+ line_t* secline;
+
// Make sure door isn't already being animated
- sec = line->frontsector;
+ sec = sides[line->sidenum[1]].sector;
door = NULL;
- if (sec->specialdata)
+ if(sec->specialdata)
{
- if (!thing->player)
- return;
-
- door = sec->specialdata;
- if (door->type == sdt_openAndClose)
- {
- if (door->status == sd_waiting)
- door->status = sd_closing;
- }
- else
- return;
+ if (!thing->player)
+ return;
+
+ door = sec->specialdata;
+ if(door->type == sdt_openAndClose)
+ {
+ if(door->status == sd_waiting)
+ {
+ // [STRIFE] TODO lines are still passable when closed manually by player
+ door->status = sd_closing;
+ door->timer = SWAITTICS; // villsa [STRIFE]
+ }
+ }
+ else
+ return;
}
-
+
// Init sliding door vars
- if (!door)
+ if(!door)
{
- door = Z_Malloc (sizeof(*door), PU_LEVSPEC, 0);
- P_AddThinker (&door->thinker);
- sec->specialdata = door;
-
- door->type = sdt_openAndClose;
- door->status = sd_opening;
- door->whichDoorIndex = P_FindSlidingDoorType(line);
+ door = Z_Malloc (sizeof(*door), PU_LEVSPEC, 0);
+ P_AddThinker (&door->thinker);
- if (door->whichDoorIndex < 0)
- I_Error("EV_SlidingDoor: Can't use texture for sliding door!");
-
- door->frontsector = sec;
- door->backsector = line->backsector;
- door->thinker.function = T_SlidingDoor;
- door->timer = SWAITTICS;
- door->frame = 0;
- door->line = line;
+ sec->specialdata = door;
+
+ door->type = sdt_openAndClose;
+ door->status = sd_opening;
+ door->whichDoorIndex = P_FindSlidingDoorType(line);
+
+ // villsa [STRIFE] different error message
+ if(door->whichDoorIndex < 0)
+ I_Error(DEH_String("EV_SlidingDoor: Textures are not defined for sliding door!"));
+
+ sides[line->sidenum[0]].midtexture = sides[line->sidenum[0]].toptexture;
+
+ // villsa [STRIFE]
+ door->line1 = line;
+ door->line2 = line;
+
+ // villsa [STRIFE] this loop assumes that the sliding door is made up
+ // of only four linedefs!
+ for(i = 0; i < 4; i++)
+ {
+ secline = sec->lines[i];
+ if(secline != line)
+ {
+ side_t* side1;
+ side_t* side2;
+
+ side1 = &sides[secline->sidenum[0]];
+ side2 = &sides[line->sidenum[0]];
+
+ if(side1->toptexture == side2->toptexture)
+ door->line2 = secline;
+ }
+ }
+
+ door->thinker.function.acp1 = (actionf_p1)T_SlidingDoor;
+ door->timer = SWAITTICS;
+ door->frontsector = sec;
+ door->frame = 0;
+
+ // villsa [STRIFE] preset flags
+ door->line1->flags |= ML_BLOCKING;
+ door->line2->flags |= ML_BLOCKING;
+
+ // villsa [STRIFE] set the closing sector
+ T_MovePlane(
+ door->frontsector,
+ (128*FRACUNIT),
+ P_FindLowestCeilingSurrounding(door->frontsector),
+ 0,
+ 1,
+ 1);
+
+ // villsa [STRIFE] play open sound
+ S_StartSound(&door->frontsector->soundorg, slideOpenSounds[door->whichDoorIndex]);
}
}
-#endif
+
--- a/src/strife/p_spec.c
+++ b/src/strife/p_spec.c
@@ -1598,6 +1598,6 @@
for (i = 0;i < MAXBUTTONS;i++)
memset(&buttonlist[i],0,sizeof(button_t));
- // UNUSED: no horizonal sliders.
- // P_InitSlidingDoorFrames();
+ // villsa [STRIFE]
+ P_InitSlidingDoorFrames();
}
--- a/src/strife/p_spec.h
+++ b/src/strife/p_spec.h
@@ -414,7 +414,7 @@
-#if 0 // UNUSED
+// villsa [STRIFE] resurrected sliding doors
//
// Sliding doors...
//
@@ -438,42 +438,40 @@
-
+// villsa [STRIFE] Rogue added a second line_t in the struct
+// backsector is removed
typedef struct
{
- thinker_t thinker;
- sdt_e type;
- line_t* line;
- int frame;
- int whichDoorIndex;
- int timer;
- sector_t* frontsector;
- sector_t* backsector;
- sd_e status;
+ thinker_t thinker;
+ sdt_e type;
+ line_t* line1;
+ line_t* line2;
+ int frame;
+ int whichDoorIndex;
+ int timer;
+ sector_t* frontsector;
+ sd_e status;
} slidedoor_t;
-
-
+// villsa [STRIFE] no front/back frames
typedef struct
{
- char frontFrame1[9];
- char frontFrame2[9];
- char frontFrame3[9];
- char frontFrame4[9];
- char backFrame1[9];
- char backFrame2[9];
- char backFrame3[9];
- char backFrame4[9];
+ char frame1[9];
+ char frame2[9];
+ char frame3[9];
+ char frame4[9];
+ char frame5[9];
+ char frame6[9];
+ char frame7[9];
+ char frame8[9];
} slidename_t;
-
-
+// villsa [STRIFE] no front/back frames
typedef struct
{
- int frontFrames[4];
- int backFrames[4];
+ int frames[8];
} slideframe_t;
@@ -480,21 +478,16 @@
// how many frames of animation
-#define SNUMFRAMES 4
+#define SNUMFRAMES 8 // villsa [STRIFE] changed from 4 to 8
-#define SDOORWAIT 35*3
-#define SWAITTICS 4
+#define SDOORWAIT TICRATE*3
+#define SWAITTICS 4
// how many diff. types of anims
-#define MAXSLIDEDOORS 5
+#define MAXSLIDEDOORS 8 // villsa [STRIFE] changed from 5 to 8
void P_InitSlidingDoorFrames(void);
-
-void
-EV_SlidingDoor
-( line_t* line,
- mobj_t* thing );
-#endif
+void EV_SlidingDoor(line_t* line, mobj_t* thing);
--- a/src/strife/p_switch.c
+++ b/src/strife/p_switch.c
@@ -510,11 +510,6 @@
case 118: // Blazing door open
EV_VerticalDoor (line, thing);
break;
-
- //UNUSED - Door Slide Open&Close
- // case 124:
- // EV_SlidingDoor (line, thing);
- // break;
// SWITCHES
case 7:
@@ -820,8 +815,13 @@
P_ChangeSwitchTexture(line,1);
break;
- case 666: // villsa [STRIFE]
- // Move wall
+ case 144:
+ // villsa [STRIFE] manual sliding door
+ EV_SlidingDoor(line, thing);
+ break;
+
+ case 666:
+ // villsa [STRIFE] Move wall
P_MoveWall(line, thing);
break;