mirror of
https://git.rip/DMCA_FUCKER/re3.git
synced 2025-01-11 20:47:05 +00:00
.ini for scaling, radar, sprites
This commit is contained in:
parent
6e42c791cf
commit
00d23c61d9
|
@ -1,5 +1,6 @@
|
||||||
#pragma once
|
#pragma once
|
||||||
#include "Sprite2d.h"
|
#include "Sprite2d.h"
|
||||||
|
#include "Draw.h"
|
||||||
|
|
||||||
enum eBlipType
|
enum eBlipType
|
||||||
{
|
{
|
||||||
|
@ -95,9 +96,11 @@ VALIDATE_SIZE(sRadarTrace, 0x30);
|
||||||
#ifdef FIX_RADAR
|
#ifdef FIX_RADAR
|
||||||
/*
|
/*
|
||||||
The values are from an early screenshot taken before R* broke radar
|
The values are from an early screenshot taken before R* broke radar
|
||||||
|
#define RADAR_WIDTH (82.0f)
|
||||||
|
#define RADAR_HEIGHT (82.0f)
|
||||||
*/
|
*/
|
||||||
#define RADAR_WIDTH (82.0f)
|
#define RADAR_WIDTH ((CDraw::ms_bFixRadar) ? (82.0f) : (94.0f))
|
||||||
#define RADAR_HEIGHT (82.0f)
|
#define RADAR_HEIGHT ((CDraw::ms_bFixRadar) ? (82.0f) : (76.0f))
|
||||||
#else
|
#else
|
||||||
/*
|
/*
|
||||||
broken since forever, someone tried to fix size for 640x512(PAL)
|
broken since forever, someone tried to fix size for 640x512(PAL)
|
||||||
|
|
|
@ -176,6 +176,12 @@ inline uint32 ldb(uint32 p, uint32 s, uint32 w)
|
||||||
#ifdef ASPECT_RATIO_SCALE
|
#ifdef ASPECT_RATIO_SCALE
|
||||||
#define SCREEN_SCALE_AR(a) ((a) * DEFAULT_ASPECT_RATIO / SCREEN_ASPECT_RATIO)
|
#define SCREEN_SCALE_AR(a) ((a) * DEFAULT_ASPECT_RATIO / SCREEN_ASPECT_RATIO)
|
||||||
#define SCALE_AND_CENTER_X(x) ((SCREEN_WIDTH == DEFAULT_SCREEN_WIDTH) ? (x) : (SCREEN_WIDTH - SCREEN_SCALE_X(DEFAULT_SCREEN_WIDTH)) / 2 + SCREEN_SCALE_X((x)))
|
#define SCALE_AND_CENTER_X(x) ((SCREEN_WIDTH == DEFAULT_SCREEN_WIDTH) ? (x) : (SCREEN_WIDTH - SCREEN_SCALE_X(DEFAULT_SCREEN_WIDTH)) / 2 + SCREEN_SCALE_X((x)))
|
||||||
|
#ifdef PROPER_SCALING
|
||||||
|
#ifndef FORCE_PC_SCALING
|
||||||
|
#undef SCREEN_SCALE_Y
|
||||||
|
#define SCREEN_SCALE_Y(a) CDraw::ScaleY(SCREEN_STRETCH_Y(a))
|
||||||
|
#endif
|
||||||
|
#endif
|
||||||
#else
|
#else
|
||||||
#define SCREEN_SCALE_AR(a) (a)
|
#define SCREEN_SCALE_AR(a) (a)
|
||||||
#define SCALE_AND_CENTER_X(x) SCREEN_STRETCH_X(x)
|
#define SCALE_AND_CENTER_X(x) SCREEN_STRETCH_X(x)
|
||||||
|
|
|
@ -214,6 +214,16 @@ void LoadINISettings()
|
||||||
CustomPipes::LightmapMult = CheckAndReadIniFloat("CustomPipesValues", "LightmapMult", CustomPipes::LightmapMult);
|
CustomPipes::LightmapMult = CheckAndReadIniFloat("CustomPipesValues", "LightmapMult", CustomPipes::LightmapMult);
|
||||||
CustomPipes::GlossMult = CheckAndReadIniFloat("CustomPipesValues", "GlossMult", CustomPipes::GlossMult);
|
CustomPipes::GlossMult = CheckAndReadIniFloat("CustomPipesValues", "GlossMult", CustomPipes::GlossMult);
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
#ifdef PROPER_SCALING
|
||||||
|
CDraw::ms_bProperScaling = CheckAndReadIniInt("Draw", "ProperScaling", CDraw::ms_bProperScaling);
|
||||||
|
#endif
|
||||||
|
#ifdef FIX_SPRITES
|
||||||
|
CDraw::ms_bFixRadar = CheckAndReadIniInt("Draw", "FixRadar", CDraw::ms_bFixRadar);
|
||||||
|
#endif
|
||||||
|
#ifdef FIX_RADAR
|
||||||
|
CDraw::ms_bFixSprites = CheckAndReadIniInt("Draw", "FixSprites", CDraw::ms_bFixSprites);
|
||||||
|
#endif
|
||||||
}
|
}
|
||||||
|
|
||||||
void SaveINISettings()
|
void SaveINISettings()
|
||||||
|
@ -252,6 +262,16 @@ void SaveINISettings()
|
||||||
CheckAndSaveIniFloat("CustomPipesValues", "GlossMult", CustomPipes::GlossMult, changed);
|
CheckAndSaveIniFloat("CustomPipesValues", "GlossMult", CustomPipes::GlossMult, changed);
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
#ifdef PROPER_SCALING
|
||||||
|
CheckAndSaveIniInt("Draw", "ProperScaling", CDraw::ms_bProperScaling, changed);
|
||||||
|
#endif
|
||||||
|
#ifdef FIX_SPRITES
|
||||||
|
CheckAndSaveIniInt("Draw", "FixRadar", CDraw::ms_bFixRadar, changed);
|
||||||
|
#endif
|
||||||
|
#ifdef FIX_RADAR
|
||||||
|
CheckAndSaveIniInt("Draw", "FixSprites", CDraw::ms_bFixSprites, changed);
|
||||||
|
#endif
|
||||||
|
|
||||||
if (changed)
|
if (changed)
|
||||||
cfg.write_file("re3.ini");
|
cfg.write_file("re3.ini");
|
||||||
}
|
}
|
||||||
|
|
|
@ -20,6 +20,16 @@ uint8 CDraw::FadeRed;
|
||||||
uint8 CDraw::FadeGreen;
|
uint8 CDraw::FadeGreen;
|
||||||
uint8 CDraw::FadeBlue;
|
uint8 CDraw::FadeBlue;
|
||||||
|
|
||||||
|
#ifdef PROPER_SCALING
|
||||||
|
int32 CDraw::ms_bProperScaling = true;
|
||||||
|
#endif
|
||||||
|
#ifdef FIX_SPRITES
|
||||||
|
int32 CDraw::ms_bFixRadar = true;
|
||||||
|
#endif
|
||||||
|
#ifdef FIX_RADAR
|
||||||
|
int32 CDraw::ms_bFixSprites = true;
|
||||||
|
#endif
|
||||||
|
|
||||||
float
|
float
|
||||||
CDraw::FindAspectRatio(void)
|
CDraw::FindAspectRatio(void)
|
||||||
{
|
{
|
||||||
|
@ -75,4 +85,11 @@ CDraw::SetFOV(float fov)
|
||||||
ms_fScaledFOV = fov;
|
ms_fScaledFOV = fov;
|
||||||
#endif
|
#endif
|
||||||
ms_fFOV = fov;
|
ms_fFOV = fov;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#ifdef PROPER_SCALING
|
||||||
|
float CDraw::ScaleY(float y)
|
||||||
|
{
|
||||||
|
return ms_bProperScaling ? y : y * ((float)DEFAULT_SCREEN_HEIGHT/SCREEN_HEIGHT_NTSC);
|
||||||
|
}
|
||||||
|
#endif
|
|
@ -34,6 +34,16 @@ public:
|
||||||
static uint8 FadeRed;
|
static uint8 FadeRed;
|
||||||
static uint8 FadeGreen;
|
static uint8 FadeGreen;
|
||||||
static uint8 FadeBlue;
|
static uint8 FadeBlue;
|
||||||
|
|
||||||
|
#ifdef PROPER_SCALING
|
||||||
|
static int32 ms_bProperScaling;
|
||||||
|
#endif
|
||||||
|
#ifdef FIX_SPRITES
|
||||||
|
static int32 ms_bFixRadar;
|
||||||
|
#endif
|
||||||
|
#ifdef FIX_RADAR
|
||||||
|
static int32 ms_bFixSprites;
|
||||||
|
#endif
|
||||||
|
|
||||||
static void SetNearClipZ(float nearclip) { ms_fNearClipZ = nearclip; }
|
static void SetNearClipZ(float nearclip) { ms_fNearClipZ = nearclip; }
|
||||||
static float GetNearClipZ(void) { return ms_fNearClipZ; }
|
static float GetNearClipZ(void) { return ms_fNearClipZ; }
|
||||||
|
@ -56,4 +66,8 @@ public:
|
||||||
#else
|
#else
|
||||||
static float GetAspectRatio(void) { return FindAspectRatio(); }
|
static float GetAspectRatio(void) { return FindAspectRatio(); }
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
#ifdef PROPER_SCALING
|
||||||
|
static float ScaleY(float y);
|
||||||
|
#endif
|
||||||
};
|
};
|
||||||
|
|
|
@ -38,7 +38,7 @@ CSprite::CalcScreenCoors(const RwV3d &in, RwV3d *out, float *outw, float *outh,
|
||||||
float fovScale = fov / CDraw::GetFOV();
|
float fovScale = fov / CDraw::GetFOV();
|
||||||
|
|
||||||
#ifdef FIX_SPRITES
|
#ifdef FIX_SPRITES
|
||||||
*outw = fovScale * recip * SCREEN_HEIGHT;
|
*outw = CDraw::ms_bFixSprites ? (fovScale * recip * SCREEN_HEIGHT) : (fovScale * SCREEN_SCALE_AR(recip) * SCREEN_WIDTH);
|
||||||
#else
|
#else
|
||||||
*outw = fovScale * SCREEN_SCALE_AR(recip) * SCREEN_WIDTH;
|
*outw = fovScale * SCREEN_SCALE_AR(recip) * SCREEN_WIDTH;
|
||||||
#endif
|
#endif
|
||||||
|
|
Loading…
Reference in a new issue