mirror of
https://github.com/ZDoom/Raze.git
synced 2025-01-17 22:30:59 +00:00
splitscreen: handle crosshairs for above/below split and regard crosshairscale.
git-svn-id: https://svn.eduke32.com/eduke32@2945 1a8010ca-5511-0410-912e-c29ae57300e0
This commit is contained in:
parent
b6090152ac
commit
60b876aa46
2 changed files with 28 additions and 5 deletions
|
@ -53,6 +53,7 @@ gamevar pangsin 0 0 // Sinus of player angle
|
|||
gamevar pinput 0 0 // Set to input, used in the PROCESSINPUT event
|
||||
|
||||
gamevar pcrosshair 0 0 // Do you like crosshairs? Game options will tell.
|
||||
gamevar crossscale 0 0 // crosshair scale
|
||||
gamevar pweapon 0 0 // Player weapon
|
||||
gamevar pfta 0 0 // Both used for quotes
|
||||
gamevar pftq 0 0
|
||||
|
@ -263,7 +264,7 @@ endevent
|
|||
// NOTE: status bar is displayed for both players (EDuke32 splitscreen hack)
|
||||
|
||||
|
||||
// orientation bits for the crosshairs
|
||||
// orientation bits for the crosshairs for left/right split
|
||||
define ORIENT 1032 // 26
|
||||
|
||||
// gametext args
|
||||
|
@ -338,8 +339,24 @@ onevent EVENT_DISPLAYROOMS
|
|||
getuserdef[THISACTOR].crosshair pcrosshair
|
||||
ifvare pcrosshair 1
|
||||
{
|
||||
rotatesprite 80 100 32768 0 CROSSHAIR 0 0 ORIENT 0 0 xdim ydim
|
||||
rotatesprite 240 100 32768 0 CROSSHAIR 0 0 ORIENT 0 0 xdim ydim
|
||||
getuserdef .crosshairscale crossscale
|
||||
shiftvarl crossscale 16, divvar crossscale 100
|
||||
|
||||
getuserdef .screen_size tmp
|
||||
ifvarn tmp 0
|
||||
{
|
||||
// left/right
|
||||
|
||||
rotatesprite 80 100 crossscale 0 CROSSHAIR 0 0 ORIENT 0 0 xdim ydim
|
||||
rotatesprite 240 100 crossscale 0 CROSSHAIR 0 0 ORIENT 0 0 xdim ydim
|
||||
}
|
||||
else
|
||||
{
|
||||
// above/below
|
||||
setvar tmp 8
|
||||
rotatesprite 160 50 crossscale 0 CROSSHAIR 0 0 tmp 0 0 xdim ydim
|
||||
rotatesprite 160 150 crossscale 0 CROSSHAIR 0 0 tmp 0 0 xdim ydim
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
|
|
|
@ -2006,6 +2006,7 @@ static int32_t P_DisplayFist(int32_t gs,int32_t snum)
|
|||
|
||||
fistpal = get_hud_pal(ps);
|
||||
|
||||
// XXX: this is outdated, doesn't handle above/below split.
|
||||
if (g_fakeMultiMode && ud.multimode==2)
|
||||
wx[(g_snum==0)] = (wx[0]+wx[1])/2+1;
|
||||
|
||||
|
@ -2118,6 +2119,10 @@ static void G_DrawWeaponTile(int32_t x, int32_t y, int32_t tilenum, int32_t shad
|
|||
G_DrawTileScaled(x,y,tilenum,shadef[slot],orientation,p);
|
||||
return;
|
||||
case 2:
|
||||
{
|
||||
const DukePlayer_t *const ps = g_player[screenpeek].ps;
|
||||
const int32_t sc = scale(65536,ud.statusbarscale,100);
|
||||
|
||||
switch (g_currentweapon)
|
||||
{
|
||||
case PISTOL_WEAPON:
|
||||
|
@ -2131,14 +2136,15 @@ static void G_DrawWeaponTile(int32_t x, int32_t y, int32_t tilenum, int32_t shad
|
|||
case HANDREMOTE_WEAPON:
|
||||
case HANDBOMB_WEAPON:
|
||||
case SHOTGUN_WEAPON:
|
||||
rotatesprite_win(160<<16,(180+(g_player[screenpeek].ps->weapon_pos*g_player[screenpeek].ps->weapon_pos))<<16,
|
||||
scale(65536,ud.statusbarscale,100),0,g_currentweapon==GROW_WEAPON?GROWSPRITEICON:WeaponPickupSprites[g_currentweapon],
|
||||
rotatesprite_win(160<<16,(180+(ps->weapon_pos*ps->weapon_pos))<<16,
|
||||
sc,0,g_currentweapon==GROW_WEAPON?GROWSPRITEICON:WeaponPickupSprites[g_currentweapon],
|
||||
0,0,2);
|
||||
return;
|
||||
default:
|
||||
return;
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
static int32_t P_DisplayKnee(int32_t gs,int32_t snum)
|
||||
|
|
Loading…
Reference in a new issue