Video: polish aspect ratio related code comments to make it clearer
This commit is contained in:
parent
b4bfc4feba
commit
24004af814
|
@ -477,7 +477,7 @@ float VideoInterfaceManager::GetAspectRatio() const
|
||||||
// signal (which would be 4:3)
|
// signal (which would be 4:3)
|
||||||
|
|
||||||
// This function only deals with standard aspect ratios. For widescreen aspect ratios,
|
// This function only deals with standard aspect ratios. For widescreen aspect ratios,
|
||||||
// multiply the result by 1.33333..
|
// multiply the result by 1.33333... (the ratio between 16:9 and 4:3)
|
||||||
|
|
||||||
// 1. Get our active area in BT.601 samples (more or less pixels)
|
// 1. Get our active area in BT.601 samples (more or less pixels)
|
||||||
int active_lines = m_vertical_timing_register.ACV;
|
int active_lines = m_vertical_timing_register.ACV;
|
||||||
|
|
|
@ -388,9 +388,9 @@ public:
|
||||||
u32 GetTicksPerHalfLine() const;
|
u32 GetTicksPerHalfLine() const;
|
||||||
u32 GetTicksPerField() const;
|
u32 GetTicksPerField() const;
|
||||||
|
|
||||||
// Get the aspect ratio of VI's active area.
|
// Get the aspect ratio of VI's active area (rarely matching pure 4:3).
|
||||||
// This function only deals with standard aspect ratios. For widescreen aspect ratios, multiply
|
// This function only deals with standard aspect ratios. For widescreen aspect ratios, multiply
|
||||||
// the result by 1.33333..
|
// the result by 1.33333... (the ratio between 16:9 and 4:3)
|
||||||
float GetAspectRatio() const;
|
float GetAspectRatio() const;
|
||||||
|
|
||||||
// Create a fake VI mode for a fifolog
|
// Create a fake VI mode for a fifolog
|
||||||
|
|
|
@ -561,12 +561,11 @@ void EnhancementsWidget::AddDescriptions()
|
||||||
"causes slowdowns or graphical issues.<br><br><dolphin_emphasis>If unsure, leave "
|
"causes slowdowns or graphical issues.<br><br><dolphin_emphasis>If unsure, leave "
|
||||||
"this unchecked.</dolphin_emphasis>");
|
"this unchecked.</dolphin_emphasis>");
|
||||||
static const char TR_WIDESCREEN_HACK_DESCRIPTION[] = QT_TR_NOOP(
|
static const char TR_WIDESCREEN_HACK_DESCRIPTION[] = QT_TR_NOOP(
|
||||||
"Forces the game to output graphics for any aspect ratio. Use with \"Aspect Ratio\" set to "
|
"Forces the game to output graphics at any aspect ratio by expanding the view frustum "
|
||||||
"\"Force 16:9\" to force 4:3-only games to run at 16:9.<br><br>Rarely produces good "
|
"without stretching the image.<br>This is a hack, and its results will vary widely game "
|
||||||
"results and "
|
"to game (it often causes the UI to stretch).<br>"
|
||||||
"often partially breaks graphics and game UIs. Unnecessary (and detrimental) if using any "
|
"Game-specific AR/Gecko-code aspect ratio patches are preferable over this if available."
|
||||||
"AR/Gecko-code widescreen patches.<br><br><dolphin_emphasis>If unsure, leave "
|
"<br><br><dolphin_emphasis>If unsure, leave this unchecked.</dolphin_emphasis>");
|
||||||
"this unchecked.</dolphin_emphasis>");
|
|
||||||
static const char TR_REMOVE_FOG_DESCRIPTION[] =
|
static const char TR_REMOVE_FOG_DESCRIPTION[] =
|
||||||
QT_TR_NOOP("Makes distant objects more visible by removing fog, thus increasing the overall "
|
QT_TR_NOOP("Makes distant objects more visible by removing fog, thus increasing the overall "
|
||||||
"detail.<br><br>Disabling fog will break some games which rely on proper fog "
|
"detail.<br><br>Disabling fog will break some games which rely on proper fog "
|
||||||
|
|
|
@ -46,7 +46,7 @@ public:
|
||||||
|
|
||||||
void ConfigChanged(u32 changed_bits);
|
void ConfigChanged(u32 changed_bits);
|
||||||
|
|
||||||
// Display resolution
|
// Window resolution (display resolution if fullscreen)
|
||||||
int GetBackbufferWidth() const { return m_backbuffer_width; }
|
int GetBackbufferWidth() const { return m_backbuffer_width; }
|
||||||
int GetBackbufferHeight() const { return m_backbuffer_height; }
|
int GetBackbufferHeight() const { return m_backbuffer_height; }
|
||||||
float GetBackbufferScale() const { return m_backbuffer_scale; }
|
float GetBackbufferScale() const { return m_backbuffer_scale; }
|
||||||
|
@ -58,6 +58,7 @@ public:
|
||||||
|
|
||||||
void UpdateDrawRectangle();
|
void UpdateDrawRectangle();
|
||||||
|
|
||||||
|
// Returns the target aspect ratio the XFB output should be drawn with.
|
||||||
float CalculateDrawAspectRatio(bool allow_stretch = true) const;
|
float CalculateDrawAspectRatio(bool allow_stretch = true) const;
|
||||||
|
|
||||||
// Crops the target rectangle to the framebuffer dimensions, reducing the size of the source
|
// Crops the target rectangle to the framebuffer dimensions, reducing the size of the source
|
||||||
|
@ -126,6 +127,9 @@ private:
|
||||||
Common::Flag m_surface_changed;
|
Common::Flag m_surface_changed;
|
||||||
Common::Flag m_surface_resized;
|
Common::Flag m_surface_resized;
|
||||||
|
|
||||||
|
// The presentation rectangle.
|
||||||
|
// Width and height correspond to the final output resolution.
|
||||||
|
// Offsets imply black borders (if the window aspect ratio doesn't match the game's one).
|
||||||
MathUtil::Rectangle<int> m_target_rectangle = {};
|
MathUtil::Rectangle<int> m_target_rectangle = {};
|
||||||
|
|
||||||
RcTcacheEntry m_xfb_entry;
|
RcTcacheEntry m_xfb_entry;
|
||||||
|
|
|
@ -91,8 +91,9 @@ static bool IsAnamorphicProjection(const Projection::Raw& projection, const View
|
||||||
const VideoConfig& config)
|
const VideoConfig& config)
|
||||||
{
|
{
|
||||||
// If ratio between our projection and viewport aspect ratios is similar to 16:9 / 4:3
|
// If ratio between our projection and viewport aspect ratios is similar to 16:9 / 4:3
|
||||||
// we have an anamorphic projection. This value can be overridden
|
// we have an anamorphic projection. This value can be overridden by a GameINI.
|
||||||
// by a GameINI.
|
// Game cheats that change the aspect ratio to natively unsupported ones
|
||||||
|
// won't be automatically recognized here.
|
||||||
|
|
||||||
return std::abs(CalculateProjectionViewportRatio(projection, viewport) -
|
return std::abs(CalculateProjectionViewportRatio(projection, viewport) -
|
||||||
config.widescreen_heuristic_widescreen_ratio) <
|
config.widescreen_heuristic_widescreen_ratio) <
|
||||||
|
|
|
@ -53,6 +53,7 @@ void WidescreenManager::Update()
|
||||||
}
|
}
|
||||||
|
|
||||||
// Heuristic to detect if a GameCube game is in 16:9 anamorphic widescreen mode.
|
// Heuristic to detect if a GameCube game is in 16:9 anamorphic widescreen mode.
|
||||||
|
// Cheats that change the game aspect ratio to natively unsupported ones won't be recognized here.
|
||||||
void WidescreenManager::UpdateWidescreenHeuristic()
|
void WidescreenManager::UpdateWidescreenHeuristic()
|
||||||
{
|
{
|
||||||
const auto flush_statistics = g_vertex_manager->ResetFlushAspectRatioCount();
|
const auto flush_statistics = g_vertex_manager->ResetFlushAspectRatioCount();
|
||||||
|
|
|
@ -11,11 +11,14 @@
|
||||||
class PointerWrap;
|
class PointerWrap;
|
||||||
|
|
||||||
// This class is responsible for tracking the game's aspect ratio.
|
// This class is responsible for tracking the game's aspect ratio.
|
||||||
|
// This exclusively supports 4:3 or 16:9 detection by default.
|
||||||
class WidescreenManager
|
class WidescreenManager
|
||||||
{
|
{
|
||||||
public:
|
public:
|
||||||
WidescreenManager();
|
WidescreenManager();
|
||||||
|
|
||||||
|
// Just a helper to tell whether the game seems to be running in widescreen,
|
||||||
|
// or if it's being forced to.
|
||||||
bool IsGameWidescreen() const { return m_is_game_widescreen; }
|
bool IsGameWidescreen() const { return m_is_game_widescreen; }
|
||||||
|
|
||||||
void DoState(PointerWrap& p);
|
void DoState(PointerWrap& p);
|
||||||
|
|
Loading…
Reference in New Issue