Red's last commit should have been using "pgl", not "gl" for function name prefixes, so the compiler would be happy. Also, more simplicity in my camera code please! Simplified some of the checks for whether a camera should chase or not etc

git-svn-id: https://code.orospakr.ca/svn/srb2/trunk@9046 6de4a73c-47e2-0310-b8c1-93d6ecd3f8cd
This commit is contained in:
MonsterIestyn 2015-02-20 13:00:40 +00:00 committed by Alam Ed Arias
parent 308a958653
commit a797e88bb9
3 changed files with 29 additions and 35 deletions

View file

@ -1913,8 +1913,8 @@ EXPORT void HWRAPI(DrawMD2i) (INT32 *gl_cmd_buffer, md2_frame_t *frame, UINT32 d
// Remove depth mask when the model is transparent so it doesn't cut thorugh sprites // SRB2CBTODO: For all stuff too?! // Remove depth mask when the model is transparent so it doesn't cut thorugh sprites // SRB2CBTODO: For all stuff too?!
if (color[3] < 255) if (color[3] < 255)
{ {
glBlendFunc(GL_SRC_ALPHA, GL_ONE_MINUS_SRC_ALPHA); // alpha = level of transparency pglBlendFunc(GL_SRC_ALPHA, GL_ONE_MINUS_SRC_ALPHA); // alpha = level of transparency
glDepthMask(GL_FALSE); pglDepthMask(GL_FALSE);
} }
val = *gl_cmd_buffer++; val = *gl_cmd_buffer++;

View file

@ -7783,24 +7783,24 @@ boolean P_MoveChaseCamera(player_t *player, camera_t *thiscam, boolean resetcall
angle_t angle = 0, focusangle = 0, focusaiming = 0; angle_t angle = 0, focusangle = 0, focusaiming = 0;
fixed_t x, y, z, dist, checkdist, viewpointx, viewpointy, camspeed, camdist, camheight, pviewheight; fixed_t x, y, z, dist, checkdist, viewpointx, viewpointy, camspeed, camdist, camheight, pviewheight;
INT32 camrotate; INT32 camrotate;
boolean camstill, forceon = false, cameranoclip; boolean camstill, cameranoclip;
mobj_t *mo; mobj_t *mo;
subsector_t *newsubsec; subsector_t *newsubsec;
fixed_t f1, f2; fixed_t f1, f2;
cameranoclip = (player->pflags & (PF_NOCLIP|PF_NIGHTSMODE)) || (player->mo->flags & (MF_NOCLIP|MF_NOCLIPHEIGHT)); // Noclipping player camera noclips too!! cameranoclip = (player->pflags & (PF_NOCLIP|PF_NIGHTSMODE)) || (player->mo->flags & (MF_NOCLIP|MF_NOCLIPHEIGHT)); // Noclipping player camera noclips too!!
if (player->climbing || (player->pflags & PF_NIGHTSMODE) || player->playerstate == PST_DEAD) if (!(player->climbing || (player->pflags & PF_NIGHTSMODE) || player->playerstate == PST_DEAD))
forceon = true; {
if (player->spectator) // force cam off for spectators
if (!forceon && player->spectator) // force cam off for spectators
return true; return true;
if (!forceon && !cv_chasecam.value && thiscam == &camera) if (!cv_chasecam.value && thiscam == &camera)
return true; return true;
if (!forceon && !cv_chasecam2.value && thiscam == &camera2) if (!cv_chasecam2.value && thiscam == &camera2)
return true; return true;
}
if (!thiscam->chase && !resetcalled) if (!thiscam->chase && !resetcalled)
{ {
@ -9091,7 +9091,7 @@ void P_PlayerAfterThink(player_t *player)
{ {
ticcmd_t *cmd; ticcmd_t *cmd;
INT32 oldweapon = player->currentweapon; INT32 oldweapon = player->currentweapon;
camera_t *thiscam; camera_t *thiscam = NULL; // if not one of the displayed players, just don't bother
#ifdef PARANOIA #ifdef PARANOIA
if (!player->mo) if (!player->mo)
@ -9105,7 +9105,7 @@ void P_PlayerAfterThink(player_t *player)
if (splitscreen && player == &players[secondarydisplayplayer]) if (splitscreen && player == &players[secondarydisplayplayer])
thiscam = &camera2; thiscam = &camera2;
else else if (player == &players[displayplayer])
thiscam = &camera; thiscam = &camera;
if (player->playerstate == PST_DEAD) if (player->playerstate == PST_DEAD)
@ -9113,7 +9113,7 @@ void P_PlayerAfterThink(player_t *player)
// camera may still move when guy is dead // camera may still move when guy is dead
//if (!netgame) //if (!netgame)
{ {
if (((splitscreen && player == &players[secondarydisplayplayer]) || player == &players[displayplayer]) && thiscam->chase) if (thiscam && thiscam->chase)
P_MoveChaseCamera(player, thiscam, false); P_MoveChaseCamera(player, thiscam, false);
} }
return; return;
@ -9368,7 +9368,7 @@ void P_PlayerAfterThink(player_t *player)
} }
} }
if ((splitscreen && player == &players[secondarydisplayplayer]) || player == &players[displayplayer]) if (thiscam)
{ {
if (!thiscam->chase) // bob view only if looking through the player's eyes if (!thiscam->chase) // bob view only if looking through the player's eyes
{ {

View file

@ -1026,34 +1026,31 @@ void R_SetupFrame(player_t *player, boolean skybox)
{ {
INT32 dy = 0; INT32 dy = 0;
camera_t *thiscam; camera_t *thiscam;
boolean forcechase = false; boolean chasecam = false;
if (splitscreen && player == &players[secondarydisplayplayer] if (splitscreen && player == &players[secondarydisplayplayer]
&& player != &players[consoleplayer]) && player != &players[consoleplayer])
{ {
thiscam = &camera2; thiscam = &camera2;
chasecam = (cv_chasecam2.value != 0);
} }
else else
{
thiscam = &camera; thiscam = &camera;
chasecam = (cv_chasecam.value != 0);
}
if (player->climbing || (player->pflags & PF_NIGHTSMODE) || player->playerstate == PST_DEAD) if (player->climbing || (player->pflags & PF_NIGHTSMODE) || player->playerstate == PST_DEAD)
forcechase = true; chasecam = true; // force chasecam on
else if (player->spectator) // no spectator chasecam
chasecam = false; // force chasecam off
if (!forcechase && player->spectator) // no spectator chasecam if (chasecam && !thiscam->chase)
thiscam->chase = false;
else if ((cv_chasecam.value || forcechase) && !player->spectator && thiscam == &camera && !thiscam->chase)
{ {
P_ResetCamera(player, &camera); P_ResetCamera(player, thiscam);
thiscam->chase = true; thiscam->chase = true;
} }
else if ((cv_chasecam2.value || forcechase) && !player->spectator && thiscam == &camera2 && !thiscam->chase) else if (!chasecam)
{
P_ResetCamera(player, &camera2);
thiscam->chase = true;
}
else if (!(cv_chasecam.value || forcechase) && thiscam == &camera)
thiscam->chase = false;
else if (!(cv_chasecam2.value || forcechase) && thiscam == &camera2)
thiscam->chase = false; thiscam->chase = false;
viewsky = !skybox; viewsky = !skybox;
@ -1066,9 +1063,7 @@ void R_SetupFrame(player_t *player, boolean skybox)
aimingangle = player->awayviewaiming; aimingangle = player->awayviewaiming;
viewangle = viewmobj->angle; viewangle = viewmobj->angle;
} }
else if (!player->spectator && (forcechase else if (!player->spectator && chasecam)
|| (cv_chasecam.value && thiscam == &camera)
|| (cv_chasecam2.value && thiscam == &camera2)))
// use outside cam view // use outside cam view
{ {
viewmobj = NULL; viewmobj = NULL;
@ -1105,8 +1100,7 @@ void R_SetupFrame(player_t *player, boolean skybox)
viewplayer = player; viewplayer = player;
if ((forcechase || (cv_chasecam.value && thiscam == &camera) || (cv_chasecam2.value && thiscam == &camera2)) if (chasecam && !player->awayviewtics && !player->spectator)
&& !player->awayviewtics && !player->spectator)
{ {
viewx = thiscam->x; viewx = thiscam->x;
viewy = thiscam->y; viewy = thiscam->y;