Merge pull request #8820 from iwubcode/freelook_field_of_view
Core / VideoCommon / DolphinQt - allow tweaking freelook camera's field of view
This commit is contained in:
commit
b36ab8360e
|
@ -24,7 +24,7 @@
|
||||||
#include "InputCommon/GCPadStatus.h"
|
#include "InputCommon/GCPadStatus.h"
|
||||||
|
|
||||||
// clang-format off
|
// clang-format off
|
||||||
constexpr std::array<const char*, 134> s_hotkey_labels{{
|
constexpr std::array<const char*, 138> s_hotkey_labels{{
|
||||||
_trans("Open"),
|
_trans("Open"),
|
||||||
_trans("Change Disc"),
|
_trans("Change Disc"),
|
||||||
_trans("Eject Disc"),
|
_trans("Eject Disc"),
|
||||||
|
@ -127,6 +127,10 @@ constexpr std::array<const char*, 134> s_hotkey_labels{{
|
||||||
_trans("Freelook Zoom Out"),
|
_trans("Freelook Zoom Out"),
|
||||||
_trans("Freelook Reset"),
|
_trans("Freelook Reset"),
|
||||||
_trans("Freelook Toggle"),
|
_trans("Freelook Toggle"),
|
||||||
|
_trans("Freelook Increase Field of View X"),
|
||||||
|
_trans("Freelook Decrease Field of View X"),
|
||||||
|
_trans("Freelook Increase Field of View Y"),
|
||||||
|
_trans("Freelook Decrease Field of View Y"),
|
||||||
|
|
||||||
_trans("Toggle 3D Side-by-Side"),
|
_trans("Toggle 3D Side-by-Side"),
|
||||||
_trans("Toggle 3D Top-Bottom"),
|
_trans("Toggle 3D Top-Bottom"),
|
||||||
|
@ -334,7 +338,7 @@ constexpr std::array<HotkeyGroupInfo, NUM_HOTKEY_GROUPS> s_groups_info = {
|
||||||
{_trans("Controller Profile 4"), HK_NEXT_WIIMOTE_PROFILE_4, HK_PREV_GAME_WIIMOTE_PROFILE_4},
|
{_trans("Controller Profile 4"), HK_NEXT_WIIMOTE_PROFILE_4, HK_PREV_GAME_WIIMOTE_PROFILE_4},
|
||||||
{_trans("Graphics Toggles"), HK_TOGGLE_CROP, HK_TOGGLE_TEXTURES},
|
{_trans("Graphics Toggles"), HK_TOGGLE_CROP, HK_TOGGLE_TEXTURES},
|
||||||
{_trans("Internal Resolution"), HK_INCREASE_IR, HK_DECREASE_IR},
|
{_trans("Internal Resolution"), HK_INCREASE_IR, HK_DECREASE_IR},
|
||||||
{_trans("Freelook"), HK_FREELOOK_DECREASE_SPEED, HK_FREELOOK_TOGGLE},
|
{_trans("Freelook"), HK_FREELOOK_DECREASE_SPEED, HK_FREELOOK_DECREASE_FOV_Y},
|
||||||
// i18n: Stereoscopic 3D
|
// i18n: Stereoscopic 3D
|
||||||
{_trans("3D"), HK_TOGGLE_STEREO_SBS, HK_TOGGLE_STEREO_ANAGLYPH},
|
{_trans("3D"), HK_TOGGLE_STEREO_SBS, HK_TOGGLE_STEREO_ANAGLYPH},
|
||||||
// i18n: Stereoscopic 3D
|
// i18n: Stereoscopic 3D
|
||||||
|
@ -469,6 +473,10 @@ void HotkeyManager::LoadDefaults(const ControllerInterface& ciface)
|
||||||
set_key_expression(HK_FREELOOK_ZOOM_IN, SHIFT + " & W");
|
set_key_expression(HK_FREELOOK_ZOOM_IN, SHIFT + " & W");
|
||||||
set_key_expression(HK_FREELOOK_ZOOM_OUT, SHIFT + " & S");
|
set_key_expression(HK_FREELOOK_ZOOM_OUT, SHIFT + " & S");
|
||||||
set_key_expression(HK_FREELOOK_RESET, SHIFT + " & R");
|
set_key_expression(HK_FREELOOK_RESET, SHIFT + " & R");
|
||||||
|
set_key_expression(HK_FREELOOK_INCREASE_FOV_X, SHIFT + " & `Axis Z+`");
|
||||||
|
set_key_expression(HK_FREELOOK_DECREASE_FOV_X, SHIFT + " & `Axis Z-`");
|
||||||
|
set_key_expression(HK_FREELOOK_INCREASE_FOV_Y, SHIFT + " & `Axis Z+`");
|
||||||
|
set_key_expression(HK_FREELOOK_DECREASE_FOV_Y, SHIFT + " & `Axis Z-`");
|
||||||
|
|
||||||
// Savestates
|
// Savestates
|
||||||
const std::string non_fmt = NON + " & `F{}`";
|
const std::string non_fmt = NON + " & `F{}`";
|
||||||
|
|
|
@ -111,6 +111,10 @@ enum Hotkey
|
||||||
HK_FREELOOK_ZOOM_OUT,
|
HK_FREELOOK_ZOOM_OUT,
|
||||||
HK_FREELOOK_RESET,
|
HK_FREELOOK_RESET,
|
||||||
HK_FREELOOK_TOGGLE,
|
HK_FREELOOK_TOGGLE,
|
||||||
|
HK_FREELOOK_INCREASE_FOV_X,
|
||||||
|
HK_FREELOOK_DECREASE_FOV_X,
|
||||||
|
HK_FREELOOK_INCREASE_FOV_Y,
|
||||||
|
HK_FREELOOK_DECREASE_FOV_Y,
|
||||||
|
|
||||||
HK_TOGGLE_STEREO_SBS,
|
HK_TOGGLE_STEREO_SBS,
|
||||||
HK_TOGGLE_STEREO_TAB,
|
HK_TOGGLE_STEREO_TAB,
|
||||||
|
|
|
@ -74,7 +74,7 @@ static Common::Event g_compressAndDumpStateSyncEvent;
|
||||||
static std::thread g_save_thread;
|
static std::thread g_save_thread;
|
||||||
|
|
||||||
// Don't forget to increase this after doing changes on the savestate system
|
// Don't forget to increase this after doing changes on the savestate system
|
||||||
constexpr u32 STATE_VERSION = 118; // Last changed in PR 8813
|
constexpr u32 STATE_VERSION = 119; // Last changed in PR 8820
|
||||||
|
|
||||||
// Maps savestate versions to Dolphin versions.
|
// Maps savestate versions to Dolphin versions.
|
||||||
// Versions after 42 don't need to be added to this list,
|
// Versions after 42 don't need to be added to this list,
|
||||||
|
|
|
@ -563,6 +563,18 @@ void HotkeyScheduler::Run()
|
||||||
if (IsHotkey(HK_FREELOOK_ZOOM_OUT, true))
|
if (IsHotkey(HK_FREELOOK_ZOOM_OUT, true))
|
||||||
g_freelook_camera.Zoom(-fl_speed);
|
g_freelook_camera.Zoom(-fl_speed);
|
||||||
|
|
||||||
|
if (IsHotkey(HK_FREELOOK_INCREASE_FOV_X, true))
|
||||||
|
g_freelook_camera.IncreaseFovX(g_freelook_camera.GetFovStepSize());
|
||||||
|
|
||||||
|
if (IsHotkey(HK_FREELOOK_DECREASE_FOV_X, true))
|
||||||
|
g_freelook_camera.IncreaseFovX(-1.0f * g_freelook_camera.GetFovStepSize());
|
||||||
|
|
||||||
|
if (IsHotkey(HK_FREELOOK_INCREASE_FOV_Y, true))
|
||||||
|
g_freelook_camera.IncreaseFovY(g_freelook_camera.GetFovStepSize());
|
||||||
|
|
||||||
|
if (IsHotkey(HK_FREELOOK_DECREASE_FOV_Y, true))
|
||||||
|
g_freelook_camera.IncreaseFovY(-1.0f * g_freelook_camera.GetFovStepSize());
|
||||||
|
|
||||||
if (IsHotkey(HK_FREELOOK_RESET, true))
|
if (IsHotkey(HK_FREELOOK_RESET, true))
|
||||||
g_freelook_camera.Reset();
|
g_freelook_camera.Reset();
|
||||||
|
|
||||||
|
|
|
@ -204,6 +204,11 @@ Common::Matrix44 FreeLookCamera::GetView()
|
||||||
return m_camera_controller->GetView();
|
return m_camera_controller->GetView();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Common::Vec2 FreeLookCamera::GetFieldOfView() const
|
||||||
|
{
|
||||||
|
return Common::Vec2{m_fov_x, m_fov_y};
|
||||||
|
}
|
||||||
|
|
||||||
void FreeLookCamera::MoveVertical(float amt)
|
void FreeLookCamera::MoveVertical(float amt)
|
||||||
{
|
{
|
||||||
m_camera_controller->MoveVertical(amt);
|
m_camera_controller->MoveVertical(amt);
|
||||||
|
@ -228,9 +233,28 @@ void FreeLookCamera::Rotate(const Common::Vec3& amt)
|
||||||
m_dirty = true;
|
m_dirty = true;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void FreeLookCamera::IncreaseFovX(float fov)
|
||||||
|
{
|
||||||
|
m_fov_x += fov;
|
||||||
|
m_fov_x = std::clamp(m_fov_x, m_fov_step_size, m_fov_x);
|
||||||
|
}
|
||||||
|
|
||||||
|
void FreeLookCamera::IncreaseFovY(float fov)
|
||||||
|
{
|
||||||
|
m_fov_y += fov;
|
||||||
|
m_fov_y = std::clamp(m_fov_y, m_fov_step_size, m_fov_y);
|
||||||
|
}
|
||||||
|
|
||||||
|
float FreeLookCamera::GetFovStepSize() const
|
||||||
|
{
|
||||||
|
return m_fov_step_size;
|
||||||
|
}
|
||||||
|
|
||||||
void FreeLookCamera::Reset()
|
void FreeLookCamera::Reset()
|
||||||
{
|
{
|
||||||
m_camera_controller->Reset();
|
m_camera_controller->Reset();
|
||||||
|
m_fov_x = 1.0f;
|
||||||
|
m_fov_y = 1.0f;
|
||||||
m_dirty = true;
|
m_dirty = true;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -239,6 +263,8 @@ void FreeLookCamera::DoState(PointerWrap& p)
|
||||||
if (p.mode == PointerWrap::MODE_WRITE || p.mode == PointerWrap::MODE_MEASURE)
|
if (p.mode == PointerWrap::MODE_WRITE || p.mode == PointerWrap::MODE_MEASURE)
|
||||||
{
|
{
|
||||||
p.Do(m_current_type);
|
p.Do(m_current_type);
|
||||||
|
p.Do(m_fov_x);
|
||||||
|
p.Do(m_fov_y);
|
||||||
if (m_camera_controller)
|
if (m_camera_controller)
|
||||||
{
|
{
|
||||||
m_camera_controller->DoState(p);
|
m_camera_controller->DoState(p);
|
||||||
|
|
|
@ -43,6 +43,7 @@ class FreeLookCamera
|
||||||
public:
|
public:
|
||||||
void SetControlType(FreelookControlType type);
|
void SetControlType(FreelookControlType type);
|
||||||
Common::Matrix44 GetView();
|
Common::Matrix44 GetView();
|
||||||
|
Common::Vec2 GetFieldOfView() const;
|
||||||
|
|
||||||
void MoveVertical(float amt);
|
void MoveVertical(float amt);
|
||||||
void MoveHorizontal(float amt);
|
void MoveHorizontal(float amt);
|
||||||
|
@ -51,6 +52,10 @@ public:
|
||||||
|
|
||||||
void Rotate(const Common::Vec3& amt);
|
void Rotate(const Common::Vec3& amt);
|
||||||
|
|
||||||
|
void IncreaseFovX(float fov);
|
||||||
|
void IncreaseFovY(float fov);
|
||||||
|
float GetFovStepSize() const;
|
||||||
|
|
||||||
void Reset();
|
void Reset();
|
||||||
|
|
||||||
void DoState(PointerWrap& p);
|
void DoState(PointerWrap& p);
|
||||||
|
@ -60,8 +65,12 @@ public:
|
||||||
|
|
||||||
private:
|
private:
|
||||||
bool m_dirty = false;
|
bool m_dirty = false;
|
||||||
|
float m_fov_x = 1.0f;
|
||||||
|
float m_fov_y = 1.0f;
|
||||||
std::optional<FreelookControlType> m_current_type;
|
std::optional<FreelookControlType> m_current_type;
|
||||||
std::unique_ptr<CameraController> m_camera_controller;
|
std::unique_ptr<CameraController> m_camera_controller;
|
||||||
|
|
||||||
|
float m_fov_step_size = 0.025f;
|
||||||
};
|
};
|
||||||
|
|
||||||
extern FreeLookCamera g_freelook_camera;
|
extern FreeLookCamera g_freelook_camera;
|
||||||
|
|
|
@ -355,14 +355,17 @@ void VertexShaderManager::SetConstants()
|
||||||
switch (xfmem.projection.type)
|
switch (xfmem.projection.type)
|
||||||
{
|
{
|
||||||
case GX_PERSPECTIVE:
|
case GX_PERSPECTIVE:
|
||||||
g_fProjectionMatrix[0] = rawProjection[0] * g_ActiveConfig.fAspectRatioHackW;
|
{
|
||||||
|
const Common::Vec2 fov =
|
||||||
|
g_ActiveConfig.bFreeLook ? g_freelook_camera.GetFieldOfView() : Common::Vec2{1, 1};
|
||||||
|
g_fProjectionMatrix[0] = rawProjection[0] * g_ActiveConfig.fAspectRatioHackW * fov.x;
|
||||||
g_fProjectionMatrix[1] = 0.0f;
|
g_fProjectionMatrix[1] = 0.0f;
|
||||||
g_fProjectionMatrix[2] = rawProjection[1] * g_ActiveConfig.fAspectRatioHackW;
|
g_fProjectionMatrix[2] = rawProjection[1] * g_ActiveConfig.fAspectRatioHackW * fov.x;
|
||||||
g_fProjectionMatrix[3] = 0.0f;
|
g_fProjectionMatrix[3] = 0.0f;
|
||||||
|
|
||||||
g_fProjectionMatrix[4] = 0.0f;
|
g_fProjectionMatrix[4] = 0.0f;
|
||||||
g_fProjectionMatrix[5] = rawProjection[2] * g_ActiveConfig.fAspectRatioHackH;
|
g_fProjectionMatrix[5] = rawProjection[2] * g_ActiveConfig.fAspectRatioHackH * fov.y;
|
||||||
g_fProjectionMatrix[6] = rawProjection[3] * g_ActiveConfig.fAspectRatioHackH;
|
g_fProjectionMatrix[6] = rawProjection[3] * g_ActiveConfig.fAspectRatioHackH * fov.y;
|
||||||
g_fProjectionMatrix[7] = 0.0f;
|
g_fProjectionMatrix[7] = 0.0f;
|
||||||
|
|
||||||
g_fProjectionMatrix[8] = 0.0f;
|
g_fProjectionMatrix[8] = 0.0f;
|
||||||
|
@ -377,9 +380,11 @@ void VertexShaderManager::SetConstants()
|
||||||
g_fProjectionMatrix[15] = 0.0f;
|
g_fProjectionMatrix[15] = 0.0f;
|
||||||
|
|
||||||
g_stats.gproj = g_fProjectionMatrix;
|
g_stats.gproj = g_fProjectionMatrix;
|
||||||
break;
|
}
|
||||||
|
break;
|
||||||
|
|
||||||
case GX_ORTHOGRAPHIC:
|
case GX_ORTHOGRAPHIC:
|
||||||
|
{
|
||||||
g_fProjectionMatrix[0] = rawProjection[0];
|
g_fProjectionMatrix[0] = rawProjection[0];
|
||||||
g_fProjectionMatrix[1] = 0.0f;
|
g_fProjectionMatrix[1] = 0.0f;
|
||||||
g_fProjectionMatrix[2] = 0.0f;
|
g_fProjectionMatrix[2] = 0.0f;
|
||||||
|
@ -403,7 +408,8 @@ void VertexShaderManager::SetConstants()
|
||||||
|
|
||||||
g_stats.g2proj = g_fProjectionMatrix;
|
g_stats.g2proj = g_fProjectionMatrix;
|
||||||
g_stats.proj = rawProjection;
|
g_stats.proj = rawProjection;
|
||||||
break;
|
}
|
||||||
|
break;
|
||||||
|
|
||||||
default:
|
default:
|
||||||
ERROR_LOG(VIDEO, "Unknown projection type: %d", xfmem.projection.type);
|
ERROR_LOG(VIDEO, "Unknown projection type: %d", xfmem.projection.type);
|
||||||
|
|
Loading…
Reference in New Issue