mirror of
https://github.com/KartKrewDev/RingRacers.git
synced 2025-10-30 08:01:28 +00:00
Merge branch 'hud-track-anything' into 'k-hud-track-cpp'
HUD track UFO catcher; hide TARGET text in 3P and 4P splitscreen See merge request KartKrew/Kart!957
This commit is contained in:
commit
022665b7dc
4 changed files with 42 additions and 11 deletions
13
src/k_hud.c
13
src/k_hud.c
|
|
@ -177,6 +177,7 @@ static patch_t *kp_trickcool[2];
|
|||
patch_t *kp_capsuletarget_arrow[2][2];
|
||||
patch_t *kp_capsuletarget_icon[2];
|
||||
patch_t *kp_capsuletarget_far[2];
|
||||
patch_t *kp_capsuletarget_far_text[2];
|
||||
patch_t *kp_capsuletarget_near[8];
|
||||
|
||||
void K_LoadKartHUDGraphics(void)
|
||||
|
|
@ -665,6 +666,13 @@ void K_LoadKartHUDGraphics(void)
|
|||
}
|
||||
}
|
||||
|
||||
sprintf(buffer, "HUDCAPDx");
|
||||
for (i = 0; i < 2; i++)
|
||||
{
|
||||
buffer[7] = '0'+i;
|
||||
HU_UpdatePatch(&kp_capsuletarget_far_text[i], "%s", buffer);
|
||||
}
|
||||
|
||||
sprintf(buffer, "HUDCAPCx");
|
||||
for (i = 0; i < 2; i++)
|
||||
{
|
||||
|
|
@ -3274,10 +3282,7 @@ static void K_drawKartNameTags(void)
|
|||
}
|
||||
}
|
||||
|
||||
if (battlecapsules == true)
|
||||
{
|
||||
K_drawTargetHUD(&c, stplyr);
|
||||
}
|
||||
K_drawTargetHUD(&c, stplyr);
|
||||
|
||||
for (i = 0; i < MAXPLAYERS; i++)
|
||||
{
|
||||
|
|
|
|||
|
|
@ -50,6 +50,7 @@ extern patch_t *kp_facehighlight[8];
|
|||
extern patch_t *kp_capsuletarget_arrow[2][2];
|
||||
extern patch_t *kp_capsuletarget_icon[2];
|
||||
extern patch_t *kp_capsuletarget_far[2];
|
||||
extern patch_t *kp_capsuletarget_far_text[2];
|
||||
extern patch_t *kp_capsuletarget_near[8];
|
||||
|
||||
#ifdef __cplusplus
|
||||
|
|
|
|||
|
|
@ -174,7 +174,6 @@ void K_DrawTargetTracking(const TargetTracking& target)
|
|||
const fixed_t farDistance = 1280 * mapobjectscale;
|
||||
bool useNear = (target.camDist < farDistance);
|
||||
|
||||
patch_t* targetPatch = nullptr;
|
||||
vector2_t targetPos = {};
|
||||
|
||||
bool visible = P_CheckSight(stplyr->mo, target.mobj);
|
||||
|
|
@ -188,21 +187,46 @@ void K_DrawTargetTracking(const TargetTracking& target)
|
|||
targetPos.x = result.x;
|
||||
targetPos.y = result.y;
|
||||
|
||||
auto draw = [&](patch_t* patch)
|
||||
{
|
||||
V_DrawFixedPatch(
|
||||
targetPos.x - ((patch->width << FRACBITS) >> 1),
|
||||
targetPos.y - ((patch->height << FRACBITS) >> 1),
|
||||
FRACUNIT,
|
||||
V_SPLITSCREEN,
|
||||
patch,
|
||||
nullptr
|
||||
);
|
||||
};
|
||||
|
||||
if (useNear == true)
|
||||
{
|
||||
timer = (leveltime / 2);
|
||||
targetPatch = kp_capsuletarget_near[timer % 8];
|
||||
draw(kp_capsuletarget_near[timer % 8]);
|
||||
}
|
||||
else
|
||||
{
|
||||
timer = (leveltime / 3);
|
||||
targetPatch = kp_capsuletarget_far[timer & 1];
|
||||
draw(kp_capsuletarget_far[timer & 1]);
|
||||
|
||||
if (r_splitscreen <= 1)
|
||||
{
|
||||
draw(kp_capsuletarget_far_text[timer & 1]);
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
targetPos.x -= (targetPatch->width << FRACBITS) >> 1;
|
||||
targetPos.y -= (targetPatch->height << FRACBITS) >> 1;
|
||||
bool is_object_tracking_target(const mobj_t* mobj)
|
||||
{
|
||||
switch (mobj->type)
|
||||
{
|
||||
case MT_BATTLECAPSULE:
|
||||
case MT_SPECIAL_UFO:
|
||||
return true;
|
||||
|
||||
V_DrawFixedPatch(targetPos.x, targetPos.y, FRACUNIT, V_SPLITSCREEN, targetPatch, nullptr);
|
||||
default:
|
||||
return false;
|
||||
}
|
||||
}
|
||||
|
||||
|
|
@ -224,7 +248,7 @@ void K_drawTargetHUD(const vector3_t* origin, player_t* player)
|
|||
continue;
|
||||
}
|
||||
|
||||
if (mobj->type != MT_BATTLECAPSULE)
|
||||
if (is_object_tracking_target(mobj) == false)
|
||||
{
|
||||
continue;
|
||||
}
|
||||
|
|
|
|||
|
|
@ -5247,6 +5247,7 @@ static boolean P_IsTrackerType(INT32 type)
|
|||
// Primarily for minimap data, handle with care
|
||||
case MT_SPB:
|
||||
case MT_BATTLECAPSULE:
|
||||
case MT_SPECIAL_UFO:
|
||||
return true;
|
||||
|
||||
default:
|
||||
|
|
|
|||
Loading…
Add table
Reference in a new issue