rpcsx/rpcs3/Emu/RSX/Overlays/HomeMenu/overlay_home_menu_settings.h

243 lines
7.9 KiB
C++

#pragma once
#include "overlay_home_menu_page.h"
#include "Emu/System.h"
#include "Utilities/Config.h"
namespace rsx
{
namespace overlays
{
struct home_menu_settings : public home_menu_page
{
public:
home_menu_settings(u16 x, u16 y, u16 width, u16 height, bool use_separators, home_menu_page* parent);
private:
std::vector<std::shared_ptr<home_menu_page>> m_settings_pages;
};
struct home_menu_settings_page : public home_menu_page
{
using home_menu_page::home_menu_page;
void add_checkbox(cfg::_bool* setting, const std::string& text)
{
ensure(setting && setting->get_is_dynamic());
std::unique_ptr<overlay_element> elem = std::make_unique<home_menu_checkbox>(setting, text);
add_item(elem, [this, setting, text](pad_button btn) -> page_navigation
{
if (btn != pad_button::cross) return page_navigation::stay;
if (setting)
{
const bool value = !setting->get();
rsx_log.notice("User toggled '%s' in '%s'. Setting '%s' to %d", text, title, setting->get_name(), value);
setting->set(value);
Emu.GetCallbacks().update_emu_settings();
if (m_config_changed) *m_config_changed = true;
refresh();
}
return page_navigation::stay;
});
}
template <typename T>
void add_dropdown(cfg::_enum<T>* setting, const std::string& text)
{
ensure(setting && setting->get_is_dynamic());
std::unique_ptr<overlay_element> elem = std::make_unique<home_menu_dropdown<T>>(setting, text);
add_item(elem, [this, setting, text](pad_button btn) -> page_navigation
{
if (btn != pad_button::cross) return page_navigation::stay;
if (setting)
{
usz new_index = 0;
T value = setting->get();
const std::string val = fmt::format("%s", value);
const std::vector<std::string> list = setting->to_list();
for (usz i = 0; i < list.size(); i++)
{
const std::string& entry = list[i];
if (entry == val)
{
new_index = (i + 1) % list.size();
break;
}
}
if (const std::string& next_value = ::at32(list, new_index); setting->from_string(next_value))
{
rsx_log.notice("User toggled '%s' in '%s'. Setting '%s' to %s", text, title, setting->get_name(), next_value);
}
else
{
rsx_log.error("Can't toggle '%s' in '%s'. Setting '%s' to '%s' failed", text, title, setting->get_name(), next_value);
}
Emu.GetCallbacks().update_emu_settings();
if (m_config_changed) *m_config_changed = true;
refresh();
}
return page_navigation::stay;
});
}
template <s64 Min, s64 Max>
void add_signed_slider(cfg::_int<Min, Max>* setting, const std::string& text, const std::string& suffix, s64 step_size, std::map<s64, std::string> special_labels = {}, s64 minimum = Min, s64 maximum = Max)
{
ensure(setting && setting->get_is_dynamic());
std::unique_ptr<overlay_element> elem = std::make_unique<home_menu_signed_slider<Min, Max>>(setting, text, suffix, special_labels, minimum, maximum);
add_item(elem, [this, setting, text, step_size, minimum, maximum](pad_button btn) -> page_navigation
{
if (setting)
{
s64 value = setting->get();
switch (btn)
{
case pad_button::dpad_left:
case pad_button::ls_left:
value = std::max(value - step_size, minimum);
break;
case pad_button::dpad_right:
case pad_button::ls_right:
value = std::min(value + step_size, maximum);
break;
default:
return page_navigation::stay;
}
if (value != setting->get())
{
rsx_log.notice("User toggled '%s' in '%s'. Setting '%s' to %d", text, title, setting->get_name(), value);
setting->set(value);
Emu.GetCallbacks().update_emu_settings();
if (m_config_changed) *m_config_changed = true;
refresh();
}
}
return page_navigation::stay;
});
}
template <u64 Min, u64 Max>
void add_unsigned_slider(cfg::uint<Min, Max>* setting, const std::string& text, const std::string& suffix, u64 step_size, std::map<u64, std::string> special_labels = {}, u64 minimum = Min, u64 maximum = Max)
{
ensure(setting && setting->get_is_dynamic());
std::unique_ptr<overlay_element> elem = std::make_unique<home_menu_unsigned_slider<Min, Max>>(setting, text, suffix, special_labels, minimum, maximum);
add_item(elem, [this, setting, text, step_size, minimum, maximum](pad_button btn) -> page_navigation
{
if (setting)
{
u64 value = setting->get();
switch (btn)
{
case pad_button::dpad_left:
case pad_button::ls_left:
value = step_size > value ? minimum : std::max(value - step_size, minimum);
break;
case pad_button::dpad_right:
case pad_button::ls_right:
value = std::min(value + step_size, maximum);
break;
default:
return page_navigation::stay;
}
if (value != setting->get())
{
rsx_log.notice("User toggled '%s' in '%s'. Setting '%s' to %d", text, title, setting->get_name(), value);
setting->set(value);
Emu.GetCallbacks().update_emu_settings();
if (m_config_changed) *m_config_changed = true;
refresh();
}
}
return page_navigation::stay;
});
}
template <s32 Min, s32 Max>
void add_float_slider(cfg::_float<Min, Max>* setting, const std::string& text, const std::string& suffix, f32 step_size, std::map<f64, std::string> special_labels = {}, s32 minimum = Min, s32 maximum = Max)
{
ensure(setting && setting->get_is_dynamic());
std::unique_ptr<overlay_element> elem = std::make_unique<home_menu_float_slider<Min, Max>>(setting, text, suffix, special_labels, minimum, maximum);
add_item(elem, [this, setting, text, step_size, minimum, maximum](pad_button btn) -> page_navigation
{
if (setting)
{
f64 value = setting->get();
switch (btn)
{
case pad_button::dpad_left:
case pad_button::ls_left:
value = std::max(value - step_size, static_cast<f64>(minimum));
break;
case pad_button::dpad_right:
case pad_button::ls_right:
value = std::min(value + step_size, static_cast<f64>(maximum));
break;
default:
return page_navigation::stay;
}
if (value != setting->get())
{
rsx_log.notice("User toggled '%s' in '%s'. Setting '%s' to %.2f", text, title, setting->get_name(), value);
setting->set(value);
Emu.GetCallbacks().update_emu_settings();
if (m_config_changed) *m_config_changed = true;
refresh();
}
}
return page_navigation::stay;
});
}
};
struct home_menu_settings_audio : public home_menu_settings_page
{
home_menu_settings_audio(u16 x, u16 y, u16 width, u16 height, bool use_separators, home_menu_page* parent);
};
struct home_menu_settings_video : public home_menu_settings_page
{
home_menu_settings_video(u16 x, u16 y, u16 width, u16 height, bool use_separators, home_menu_page* parent);
};
struct home_menu_settings_advanced : public home_menu_settings_page
{
home_menu_settings_advanced(u16 x, u16 y, u16 width, u16 height, bool use_separators, home_menu_page* parent);
};
struct home_menu_settings_input : public home_menu_settings_page
{
home_menu_settings_input(u16 x, u16 y, u16 width, u16 height, bool use_separators, home_menu_page* parent);
};
struct home_menu_settings_overlays : public home_menu_settings_page
{
home_menu_settings_overlays(u16 x, u16 y, u16 width, u16 height, bool use_separators, home_menu_page* parent);
};
struct home_menu_settings_performance_overlay : public home_menu_settings_page
{
home_menu_settings_performance_overlay(u16 x, u16 y, u16 width, u16 height, bool use_separators, home_menu_page* parent);
};
struct home_menu_settings_debug : public home_menu_settings_page
{
home_menu_settings_debug(u16 x, u16 y, u16 width, u16 height, bool use_separators, home_menu_page* parent);
};
}
}