Merge pull request #8603 from jordan-woyak/deadzone-too-dark

DolphinQt/Mapping: Tweak "Dead Zone" and "Gate" colors.
This commit is contained in:
Tilka 2020-02-10 23:28:56 +00:00 committed by GitHub
commit a9dc4ac3f0
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
2 changed files with 24 additions and 11 deletions

View File

@ -30,6 +30,7 @@
namespace namespace
{ {
const QColor STICK_GATE_COLOR = Qt::lightGray;
const QColor C_STICK_GATE_COLOR = Qt::yellow; const QColor C_STICK_GATE_COLOR = Qt::yellow;
const QColor CURSOR_TV_COLOR = 0xaed6f1; const QColor CURSOR_TV_COLOR = 0xaed6f1;
const QColor TILT_GATE_COLOR = 0xa2d9ce; const QColor TILT_GATE_COLOR = 0xa2d9ce;
@ -72,7 +73,9 @@ QColor MappingIndicator::GetCenterColor() const
QColor MappingIndicator::GetDeadZoneColor() const QColor MappingIndicator::GetDeadZoneColor() const
{ {
return palette().shadow().color(); QColor color = GetBBoxBrush().color().valueF() > 0.5 ? Qt::black : Qt::white;
color.setAlphaF(0.25);
return color;
} }
QPen MappingIndicator::GetDeadZonePen() const QPen MappingIndicator::GetDeadZonePen() const
@ -96,9 +99,10 @@ QColor MappingIndicator::GetAltTextColor() const
return palette().highlightedText().color(); return palette().highlightedText().color();
} }
QColor MappingIndicator::GetGateColor() const void MappingIndicator::AdjustGateColor(QColor* color)
{ {
return palette().mid().color(); if (GetBBoxBrush().color().valueF() < 0.5)
color->setHsvF(color->hueF(), color->saturationF(), 1 - color->valueF());
} }
MappingIndicator::MappingIndicator(ControllerEmu::ControlGroup* group) : m_group(group) MappingIndicator::MappingIndicator(ControllerEmu::ControlGroup* group) : m_group(group)
@ -211,8 +215,11 @@ void MappingIndicator::DrawCursor(ControllerEmu::Cursor& cursor)
{ {
const auto center = cursor.GetCenter(); const auto center = cursor.GetCenter();
const QColor tv_brush_color = CURSOR_TV_COLOR; QColor tv_brush_color = CURSOR_TV_COLOR;
const QColor tv_pen_color = tv_brush_color.darker(125); QColor tv_pen_color = tv_brush_color.darker(125);
AdjustGateColor(&tv_brush_color);
AdjustGateColor(&tv_pen_color);
const auto raw_coord = cursor.GetState(false); const auto raw_coord = cursor.GetState(false);
const auto adj_coord = cursor.GetState(true); const auto adj_coord = cursor.GetState(true);
@ -294,14 +301,17 @@ void MappingIndicator::DrawReshapableInput(ControllerEmu::ReshapableInput& stick
const auto center = stick.GetCenter(); const auto center = stick.GetCenter();
QColor gate_brush_color = GetGateColor(); QColor gate_brush_color = STICK_GATE_COLOR;
if (is_c_stick) if (is_c_stick)
gate_brush_color = C_STICK_GATE_COLOR; gate_brush_color = C_STICK_GATE_COLOR;
else if (is_tilt) else if (is_tilt)
gate_brush_color = TILT_GATE_COLOR; gate_brush_color = TILT_GATE_COLOR;
const QColor gate_pen_color = gate_brush_color.darker(125); QColor gate_pen_color = gate_brush_color.darker(125);
AdjustGateColor(&gate_brush_color);
AdjustGateColor(&gate_pen_color);
const auto raw_coord = stick.GetReshapableState(false); const auto raw_coord = stick.GetReshapableState(false);
@ -482,8 +492,11 @@ void MappingIndicator::DrawForce(ControllerEmu::Force& force)
{ {
const auto center = force.GetCenter(); const auto center = force.GetCenter();
const QColor gate_brush_color = SWING_GATE_COLOR; QColor gate_brush_color = SWING_GATE_COLOR;
const QColor gate_pen_color = gate_brush_color.darker(125); QColor gate_pen_color = gate_brush_color.darker(125);
AdjustGateColor(&gate_brush_color);
AdjustGateColor(&gate_pen_color);
const auto raw_coord = force.GetState(false); const auto raw_coord = force.GetState(false);
WiimoteEmu::EmulateSwing(&m_motion_state, &force, 1.f / INDICATOR_UPDATE_FREQ); WiimoteEmu::EmulateSwing(&m_motion_state, &force, 1.f / INDICATOR_UPDATE_FREQ);
@ -677,7 +690,7 @@ void ShakeMappingIndicator::DrawShake()
p.drawLine(QPointF{grid_line_x, -1.0} * scale, QPointF{grid_line_x, 1.0} * scale); p.drawLine(QPointF{grid_line_x, -1.0} * scale, QPointF{grid_line_x, 1.0} * scale);
// Position history. // Position history.
const QColor component_colors[] = {Qt::red, Qt::green, Qt::blue}; const QColor component_colors[] = {Qt::blue, Qt::green, Qt::red};
p.setBrush(Qt::NoBrush); p.setBrush(Qt::NoBrush);
for (std::size_t c = 0; c != raw_coord.data.size(); ++c) for (std::size_t c = 0; c != raw_coord.data.size(); ++c)
{ {

View File

@ -44,7 +44,7 @@ public:
QBrush GetDeadZoneBrush() const; QBrush GetDeadZoneBrush() const;
QColor GetTextColor() const; QColor GetTextColor() const;
QColor GetAltTextColor() const; QColor GetAltTextColor() const;
QColor GetGateColor() const; void AdjustGateColor(QColor*);
protected: protected:
double GetScale() const; double GetScale() const;