DolphinQt: Add tooltip support to Hacks Graphics tab
This commit is contained in:
parent
1673442794
commit
2bfb8ebf96
|
@ -17,11 +17,12 @@
|
||||||
#include "DolphinQt/Config/Graphics/GraphicsBool.h"
|
#include "DolphinQt/Config/Graphics/GraphicsBool.h"
|
||||||
#include "DolphinQt/Config/Graphics/GraphicsSlider.h"
|
#include "DolphinQt/Config/Graphics/GraphicsSlider.h"
|
||||||
#include "DolphinQt/Config/Graphics/GraphicsWindow.h"
|
#include "DolphinQt/Config/Graphics/GraphicsWindow.h"
|
||||||
|
#include "DolphinQt/Config/ToolTipControls/ToolTipSlider.h"
|
||||||
#include "DolphinQt/Settings.h"
|
#include "DolphinQt/Settings.h"
|
||||||
|
|
||||||
#include "VideoCommon/VideoConfig.h"
|
#include "VideoCommon/VideoConfig.h"
|
||||||
|
|
||||||
HacksWidget::HacksWidget(GraphicsWindow* parent) : GraphicsWidget(parent)
|
HacksWidget::HacksWidget(GraphicsWindow* parent)
|
||||||
{
|
{
|
||||||
CreateWidgets();
|
CreateWidgets();
|
||||||
LoadSettings();
|
LoadSettings();
|
||||||
|
@ -60,7 +61,7 @@ void HacksWidget::CreateWidgets()
|
||||||
auto* texture_cache_layout = new QGridLayout();
|
auto* texture_cache_layout = new QGridLayout();
|
||||||
texture_cache_box->setLayout(texture_cache_layout);
|
texture_cache_box->setLayout(texture_cache_layout);
|
||||||
|
|
||||||
m_accuracy = new QSlider(Qt::Horizontal);
|
m_accuracy = new ToolTipSlider(Qt::Horizontal);
|
||||||
m_accuracy->setMinimum(0);
|
m_accuracy->setMinimum(0);
|
||||||
m_accuracy->setMaximum(2);
|
m_accuracy->setMaximum(2);
|
||||||
m_accuracy->setPageStep(1);
|
m_accuracy->setPageStep(1);
|
||||||
|
@ -207,81 +208,93 @@ void HacksWidget::SaveSettings()
|
||||||
|
|
||||||
void HacksWidget::AddDescriptions()
|
void HacksWidget::AddDescriptions()
|
||||||
{
|
{
|
||||||
static const char TR_SKIP_EFB_CPU_ACCESS_DESCRIPTION[] =
|
static const char TR_SKIP_EFB_CPU_ACCESS_DESCRIPTION[] = QT_TR_NOOP(
|
||||||
QT_TR_NOOP("Ignores any requests from the CPU to read from or write to the EFB. "
|
"Ignores any requests from the CPU to read from or write to the EFB. "
|
||||||
"\n\nImproves performance in some games, but will disable all EFB-based "
|
"<br><br>Improves performance in some games, but will disable all EFB-based "
|
||||||
"graphical effects or gameplay-related features.\n\nIf unsure, "
|
"graphical effects or gameplay-related features.<br><br><dolphin_emphasis>If unsure, "
|
||||||
"leave this unchecked.");
|
"leave this unchecked.</dolphin_emphasis>");
|
||||||
static const char TR_IGNORE_FORMAT_CHANGE_DESCRIPTION[] = QT_TR_NOOP(
|
static const char TR_IGNORE_FORMAT_CHANGE_DESCRIPTION[] = QT_TR_NOOP(
|
||||||
"Ignores any changes to the EFB format.\n\nImproves performance in many games without "
|
"Ignores any changes to the EFB format.<br><br>Improves performance in many games "
|
||||||
|
"without "
|
||||||
"any negative effect. Causes graphical defects in a small number of other "
|
"any negative effect. Causes graphical defects in a small number of other "
|
||||||
"games.\n\nIf unsure, leave this checked.");
|
"games.<br><br><dolphin_emphasis>If unsure, leave this checked.</dolphin_emphasis>");
|
||||||
static const char TR_STORE_EFB_TO_TEXTURE_DESCRIPTION[] = QT_TR_NOOP(
|
static const char TR_STORE_EFB_TO_TEXTURE_DESCRIPTION[] = QT_TR_NOOP(
|
||||||
"Stores EFB copies exclusively on the GPU, bypassing system memory. Causes graphical defects "
|
"Stores EFB copies exclusively on the GPU, bypassing system memory. Causes graphical defects "
|
||||||
"in a small number of games.\n\nEnabled = EFB Copies to Texture\nDisabled = EFB Copies to "
|
"in a small number of games.<br><br>Enabled = EFB Copies to Texture<br>Disabled = EFB "
|
||||||
"RAM (and Texture)\n\nIf unsure, leave this checked.");
|
"Copies to "
|
||||||
|
"RAM (and Texture)<br><br><dolphin_emphasis>If unsure, leave this "
|
||||||
|
"checked.</dolphin_emphasis>");
|
||||||
static const char TR_DEFER_EFB_COPIES_DESCRIPTION[] = QT_TR_NOOP(
|
static const char TR_DEFER_EFB_COPIES_DESCRIPTION[] = QT_TR_NOOP(
|
||||||
"Waits until the game synchronizes with the emulated GPU before writing the contents of EFB "
|
"Waits until the game synchronizes with the emulated GPU before writing the contents of EFB "
|
||||||
"copies to RAM.\n\nReduces the overhead of EFB RAM copies, providing a performance boost in "
|
"copies to RAM.<br><br>Reduces the overhead of EFB RAM copies, providing a performance "
|
||||||
|
"boost in "
|
||||||
"many games, at the risk of breaking those which do not safely synchronize with the "
|
"many games, at the risk of breaking those which do not safely synchronize with the "
|
||||||
"emulated GPU.\n\nIf unsure, leave this checked.");
|
"emulated GPU.<br><br><dolphin_emphasis>If unsure, leave this "
|
||||||
|
"checked.</dolphin_emphasis>");
|
||||||
static const char TR_ACCUARCY_DESCRIPTION[] = QT_TR_NOOP(
|
static const char TR_ACCUARCY_DESCRIPTION[] = QT_TR_NOOP(
|
||||||
"Adjusts the accuracy at which the GPU receives texture updates from RAM.\n\n"
|
"Adjusts the accuracy at which the GPU receives texture updates from RAM.<br><br>"
|
||||||
"The \"Safe\" setting eliminates the likelihood of the GPU missing texture updates "
|
"The \"Safe\" setting eliminates the likelihood of the GPU missing texture updates "
|
||||||
"from RAM. Lower accuracies cause in-game text to appear garbled in certain "
|
"from RAM. Lower accuracies cause in-game text to appear garbled in certain "
|
||||||
"games.\n\nIf unsure, select the rightmost value.");
|
"games.<br><br><dolphin_emphasis>If unsure, select the rightmost "
|
||||||
|
"value.</dolphin_emphasis>");
|
||||||
static const char TR_STORE_XFB_TO_TEXTURE_DESCRIPTION[] = QT_TR_NOOP(
|
static const char TR_STORE_XFB_TO_TEXTURE_DESCRIPTION[] = QT_TR_NOOP(
|
||||||
"Stores XFB copies exclusively on the GPU, bypassing system memory. Causes graphical defects "
|
"Stores XFB copies exclusively on the GPU, bypassing system memory. Causes graphical defects "
|
||||||
"in a small number of games.\n\nEnabled = XFB Copies to "
|
"in a small number of games.<br><br>Enabled = XFB Copies to "
|
||||||
"Texture\nDisabled = XFB Copies to RAM (and Texture)\n\nIf unsure, leave this checked.");
|
"Texture<br>Disabled = XFB Copies to RAM (and Texture)<br><br><dolphin_emphasis>If "
|
||||||
|
"unsure, leave this checked.</dolphin_emphasis>");
|
||||||
static const char TR_IMMEDIATE_XFB_DESCRIPTION[] =
|
static const char TR_IMMEDIATE_XFB_DESCRIPTION[] = QT_TR_NOOP(
|
||||||
QT_TR_NOOP("Displays XFB copies as soon as they are created, instead of waiting for "
|
"Displays XFB copies as soon as they are created, instead of waiting for "
|
||||||
"scanout.\n\nCan cause graphical defects in some games if the game doesn't "
|
"scanout.<br><br>Can cause graphical defects in some games if the game doesn't "
|
||||||
"expect all XFB copies to be displayed. However, turning this setting on reduces "
|
"expect all XFB copies to be displayed. However, turning this setting on reduces "
|
||||||
"latency.\n\nIf unsure, leave this unchecked.");
|
"latency.<br><br><dolphin_emphasis>If unsure, leave this unchecked.</dolphin_emphasis>");
|
||||||
|
|
||||||
static const char TR_SKIP_DUPLICATE_XFBS_DESCRIPTION[] = QT_TR_NOOP(
|
static const char TR_SKIP_DUPLICATE_XFBS_DESCRIPTION[] = QT_TR_NOOP(
|
||||||
"Skips presentation of duplicate frames (XFB copies) in 25fps/30fps games. This may improve "
|
"Skips presentation of duplicate frames (XFB copies) in 25fps/30fps games. This may improve "
|
||||||
"performance on low-end devices, while making frame pacing less consistent.\n\nDisable this "
|
"performance on low-end devices, while making frame pacing less consistent.<br><br "
|
||||||
"option as well as enabling V-Sync for optimal frame pacing.\n\nIf unsure, leave this "
|
"/>Disable this "
|
||||||
"checked.");
|
"option as well as enabling V-Sync for optimal frame pacing.<br><br><dolphin_emphasis>If "
|
||||||
|
"unsure, leave this "
|
||||||
static const char TR_GPU_DECODING_DESCRIPTION[] =
|
"checked.</dolphin_emphasis>");
|
||||||
QT_TR_NOOP("Enables texture decoding using the GPU instead of the CPU.\n\nThis may result in "
|
static const char TR_GPU_DECODING_DESCRIPTION[] = QT_TR_NOOP(
|
||||||
"performance gains in some scenarios, or on systems where the CPU is the "
|
"Enables texture decoding using the GPU instead of the CPU.<br><br>This may result in "
|
||||||
"bottleneck.\n\nIf unsure, leave this unchecked.");
|
"performance gains in some scenarios, or on systems where the CPU is the "
|
||||||
|
"bottleneck.<br><br><dolphin_emphasis>If unsure, leave this "
|
||||||
|
"unchecked.</dolphin_emphasis>");
|
||||||
static const char TR_FAST_DEPTH_CALC_DESCRIPTION[] = QT_TR_NOOP(
|
static const char TR_FAST_DEPTH_CALC_DESCRIPTION[] = QT_TR_NOOP(
|
||||||
"Uses a less accurate algorithm to calculate depth values.\n\nCauses issues in a few "
|
"Uses a less accurate algorithm to calculate depth values.<br><br>Causes issues in a few "
|
||||||
"games, but can result in a decent speed increase depending on the game and/or "
|
"games, but can result in a decent speed increase depending on the game and/or "
|
||||||
"GPU.\n\nIf unsure, leave this checked.");
|
"GPU.<br><br><dolphin_emphasis>If unsure, leave this checked.</dolphin_emphasis>");
|
||||||
static const char TR_DISABLE_BOUNDINGBOX_DESCRIPTION[] =
|
static const char TR_DISABLE_BOUNDINGBOX_DESCRIPTION[] =
|
||||||
QT_TR_NOOP("Disables bounding box emulation.\n\nThis may improve GPU performance "
|
QT_TR_NOOP("Disables bounding box emulation.<br><br>This may improve GPU performance "
|
||||||
"significantly, but some games will break.\n\nIf unsure, leave this checked.");
|
"significantly, but some games will break.<br><br><dolphin_emphasis>If "
|
||||||
static const char TR_SAVE_TEXTURE_CACHE_TO_STATE_DESCRIPTION[] = QT_TR_NOOP(
|
"unsure, leave this checked.</dolphin_emphasis>");
|
||||||
"Includes the contents of the embedded frame buffer (EFB) and upscaled EFB copies "
|
static const char TR_SAVE_TEXTURE_CACHE_TO_STATE_DESCRIPTION[] =
|
||||||
"in save states. Fixes missing and/or non-upscaled textures/objects when loading "
|
QT_TR_NOOP("Includes the contents of the embedded frame buffer (EFB) and upscaled EFB copies "
|
||||||
"states at the cost of additional save/load time.\n\nIf unsure, leave this checked.");
|
"in save states. Fixes missing and/or non-upscaled textures/objects when loading "
|
||||||
static const char TR_VERTEX_ROUNDING_DESCRIPTION[] =
|
"states at the cost of additional save/load time.<br><br><dolphin_emphasis>If "
|
||||||
QT_TR_NOOP("Rounds 2D vertices to whole pixels.\n\nFixes graphical problems in some games at "
|
"unsure, leave this checked.</dolphin_emphasis>");
|
||||||
"higher internal resolutions. This setting has no effect when native internal "
|
static const char TR_VERTEX_ROUNDING_DESCRIPTION[] = QT_TR_NOOP(
|
||||||
"resolution is used.\n\nIf unsure, leave this unchecked.");
|
"Rounds 2D vertices to whole pixels.<br><br>Fixes graphical problems in some games at "
|
||||||
|
"higher internal resolutions. This setting has no effect when native internal "
|
||||||
|
"resolution is used.<br><br><dolphin_emphasis>If unsure, leave this "
|
||||||
|
"unchecked.</dolphin_emphasis>");
|
||||||
|
|
||||||
AddDescription(m_skip_efb_cpu, TR_SKIP_EFB_CPU_ACCESS_DESCRIPTION);
|
m_skip_efb_cpu->SetDescription(QString::fromStdString(TR_SKIP_EFB_CPU_ACCESS_DESCRIPTION));
|
||||||
AddDescription(m_ignore_format_changes, TR_IGNORE_FORMAT_CHANGE_DESCRIPTION);
|
m_ignore_format_changes->SetDescription(
|
||||||
AddDescription(m_store_efb_copies, TR_STORE_EFB_TO_TEXTURE_DESCRIPTION);
|
QString::fromStdString(TR_IGNORE_FORMAT_CHANGE_DESCRIPTION));
|
||||||
AddDescription(m_defer_efb_copies, TR_DEFER_EFB_COPIES_DESCRIPTION);
|
m_store_efb_copies->SetDescription(QString::fromStdString(TR_STORE_EFB_TO_TEXTURE_DESCRIPTION));
|
||||||
AddDescription(m_accuracy, TR_ACCUARCY_DESCRIPTION);
|
m_defer_efb_copies->SetDescription(QString::fromStdString(TR_DEFER_EFB_COPIES_DESCRIPTION));
|
||||||
AddDescription(m_store_xfb_copies, TR_STORE_XFB_TO_TEXTURE_DESCRIPTION);
|
m_accuracy->SetTitle(tr("Texture Cache Accuracy"));
|
||||||
AddDescription(m_immediate_xfb, TR_IMMEDIATE_XFB_DESCRIPTION);
|
m_accuracy->SetDescription(QString::fromStdString(TR_ACCUARCY_DESCRIPTION));
|
||||||
AddDescription(m_skip_duplicate_xfbs, TR_SKIP_DUPLICATE_XFBS_DESCRIPTION);
|
m_store_xfb_copies->SetDescription(QString::fromStdString(TR_STORE_XFB_TO_TEXTURE_DESCRIPTION));
|
||||||
AddDescription(m_gpu_texture_decoding, TR_GPU_DECODING_DESCRIPTION);
|
m_immediate_xfb->SetDescription(QString::fromStdString(TR_IMMEDIATE_XFB_DESCRIPTION));
|
||||||
AddDescription(m_fast_depth_calculation, TR_FAST_DEPTH_CALC_DESCRIPTION);
|
m_skip_duplicate_xfbs->SetDescription(QString::fromStdString(TR_SKIP_DUPLICATE_XFBS_DESCRIPTION));
|
||||||
AddDescription(m_disable_bounding_box, TR_DISABLE_BOUNDINGBOX_DESCRIPTION);
|
m_gpu_texture_decoding->SetDescription(QString::fromStdString(TR_GPU_DECODING_DESCRIPTION));
|
||||||
AddDescription(m_save_texture_cache_state, TR_SAVE_TEXTURE_CACHE_TO_STATE_DESCRIPTION);
|
m_fast_depth_calculation->SetDescription(QString::fromStdString(TR_FAST_DEPTH_CALC_DESCRIPTION));
|
||||||
AddDescription(m_vertex_rounding, TR_VERTEX_ROUNDING_DESCRIPTION);
|
m_disable_bounding_box->SetDescription(
|
||||||
|
QString::fromStdString(TR_DISABLE_BOUNDINGBOX_DESCRIPTION));
|
||||||
|
m_save_texture_cache_state->SetDescription(
|
||||||
|
QString::fromStdString(TR_SAVE_TEXTURE_CACHE_TO_STATE_DESCRIPTION));
|
||||||
|
m_vertex_rounding->SetDescription(QString::fromStdString(TR_VERTEX_ROUNDING_DESCRIPTION));
|
||||||
}
|
}
|
||||||
|
|
||||||
void HacksWidget::UpdateDeferEFBCopiesEnabled()
|
void HacksWidget::UpdateDeferEFBCopiesEnabled()
|
||||||
|
|
|
@ -6,11 +6,10 @@
|
||||||
|
|
||||||
#include "DolphinQt/Config/Graphics/GraphicsWidget.h"
|
#include "DolphinQt/Config/Graphics/GraphicsWidget.h"
|
||||||
|
|
||||||
|
class GraphicsBool;
|
||||||
class GraphicsWindow;
|
class GraphicsWindow;
|
||||||
class QCheckBox;
|
|
||||||
class QLabel;
|
class QLabel;
|
||||||
class QRadioButton;
|
class ToolTipSlider;
|
||||||
class QSlider;
|
|
||||||
|
|
||||||
class HacksWidget final : public GraphicsWidget
|
class HacksWidget final : public GraphicsWidget
|
||||||
{
|
{
|
||||||
|
@ -25,26 +24,26 @@ private:
|
||||||
void OnBackendChanged(const QString& backend_name);
|
void OnBackendChanged(const QString& backend_name);
|
||||||
|
|
||||||
// EFB
|
// EFB
|
||||||
QCheckBox* m_skip_efb_cpu;
|
GraphicsBool* m_skip_efb_cpu;
|
||||||
QCheckBox* m_ignore_format_changes;
|
GraphicsBool* m_ignore_format_changes;
|
||||||
QCheckBox* m_store_efb_copies;
|
GraphicsBool* m_store_efb_copies;
|
||||||
|
|
||||||
// Texture Cache
|
// Texture Cache
|
||||||
QLabel* m_accuracy_label;
|
QLabel* m_accuracy_label;
|
||||||
QSlider* m_accuracy;
|
ToolTipSlider* m_accuracy;
|
||||||
QCheckBox* m_gpu_texture_decoding;
|
GraphicsBool* m_gpu_texture_decoding;
|
||||||
|
|
||||||
// External Framebuffer
|
// External Framebuffer
|
||||||
QCheckBox* m_store_xfb_copies;
|
GraphicsBool* m_store_xfb_copies;
|
||||||
QCheckBox* m_immediate_xfb;
|
GraphicsBool* m_immediate_xfb;
|
||||||
QCheckBox* m_skip_duplicate_xfbs;
|
GraphicsBool* m_skip_duplicate_xfbs;
|
||||||
|
|
||||||
// Other
|
// Other
|
||||||
QCheckBox* m_fast_depth_calculation;
|
GraphicsBool* m_fast_depth_calculation;
|
||||||
QCheckBox* m_disable_bounding_box;
|
GraphicsBool* m_disable_bounding_box;
|
||||||
QCheckBox* m_vertex_rounding;
|
GraphicsBool* m_vertex_rounding;
|
||||||
QCheckBox* m_save_texture_cache_state;
|
GraphicsBool* m_save_texture_cache_state;
|
||||||
QCheckBox* m_defer_efb_copies;
|
GraphicsBool* m_defer_efb_copies;
|
||||||
|
|
||||||
void CreateWidgets();
|
void CreateWidgets();
|
||||||
void ConnectWidgets();
|
void ConnectWidgets();
|
||||||
|
|
Loading…
Reference in New Issue