Achievements: Fix multiple leaderboard trackers

This commit is contained in:
Stenzek 2023-11-30 13:52:48 +10:00 committed by Connor McLaughlin
parent 9a932e7dd5
commit 9e720d1e2b
1 changed files with 27 additions and 16 deletions

View File

@ -103,9 +103,9 @@ namespace Achievements
struct LeaderboardTrackerIndicator struct LeaderboardTrackerIndicator
{ {
u32 tracker_id; u32 tracker_id;
ImVec2 size;
std::string text; std::string text;
Common::Timer show_hide_time; Common::Timer show_hide_time;
u32 display_length;
bool active; bool active;
}; };
@ -1223,17 +1223,10 @@ void Achievements::HandleLeaderboardTrackerShowEvent(const rc_client_event_t* ev
DevCon.WriteLn( DevCon.WriteLn(
"(Achievements) Showing leaderboard tracker: %u: %s", event->leaderboard_tracker->id, event->leaderboard_tracker->display); "(Achievements) Showing leaderboard tracker: %u: %s", event->leaderboard_tracker->id, event->leaderboard_tracker->display);
TinyString width_string;
width_string.append(ICON_FA_STOPWATCH);
const u32 display_len = static_cast<u32>(std::strlen(event->leaderboard_tracker->display));
for (u32 i = 0; i < display_len; i++)
width_string.append('0');
LeaderboardTrackerIndicator indicator; LeaderboardTrackerIndicator indicator;
indicator.tracker_id = event->leaderboard_tracker->id; indicator.tracker_id = event->leaderboard_tracker->id;
indicator.size = ImGuiFullscreen::g_medium_font->CalcTextSizeA( indicator.text = event->leaderboard_tracker->display;
ImGuiFullscreen::g_medium_font->FontSize, FLT_MAX, 0.0f, width_string.c_str(), width_string.end_ptr()); indicator.display_length = static_cast<u32>(std::strlen(event->leaderboard_tracker->display));
indicator.text = fmt::format(ICON_FA_STOPWATCH " {}", event->leaderboard_tracker->display);
indicator.active = true; indicator.active = true;
s_active_leaderboard_trackers.push_back(std::move(indicator)); s_active_leaderboard_trackers.push_back(std::move(indicator));
} }
@ -1262,8 +1255,7 @@ void Achievements::HandleLeaderboardTrackerUpdateEvent(const rc_client_event_t*
DevCon.WriteLn( DevCon.WriteLn(
"(Achievements) Updating leaderboard tracker: %u: %s", event->leaderboard_tracker->id, event->leaderboard_tracker->display); "(Achievements) Updating leaderboard tracker: %u: %s", event->leaderboard_tracker->id, event->leaderboard_tracker->display);
it->text.clear(); it->text = event->leaderboard_tracker->display;
fmt::format_to(std::back_inserter(it->text), ICON_FA_STOPWATCH " {}", event->leaderboard_tracker->display);
it->active = true; it->active = true;
} }
@ -1978,6 +1970,8 @@ void Achievements::DrawGameOverlays()
DevCon.WriteLn("(Achievements) Remove progress indicator"); DevCon.WriteLn("(Achievements) Remove progress indicator");
s_active_progress_indicator.reset(); s_active_progress_indicator.reset();
} }
position.y -= image_size.y - padding * 3.0f;
} }
if (!s_active_leaderboard_trackers.empty()) if (!s_active_leaderboard_trackers.empty())
@ -1987,18 +1981,32 @@ void Achievements::DrawGameOverlays()
const LeaderboardTrackerIndicator& indicator = *it; const LeaderboardTrackerIndicator& indicator = *it;
const float opacity = IndicatorOpacity(indicator); const float opacity = IndicatorOpacity(indicator);
const ImVec2 box_min = ImVec2(position.x - indicator.size.x - padding * 2.0f, position.y - indicator.size.y - padding * 2.0f); TinyString width_string;
width_string.append(ICON_FA_STOPWATCH);
for (u32 i = 0; i < indicator.display_length; i++)
width_string.append('0');
const ImVec2 size = ImGuiFullscreen::g_medium_font->CalcTextSizeA(
ImGuiFullscreen::g_medium_font->FontSize, FLT_MAX, 0.0f, width_string.c_str(), width_string.end_ptr());
const ImVec2 box_min = ImVec2(position.x - size.x - padding * 2.0f, position.y - size.y - padding * 2.0f);
const ImVec2 box_max = position; const ImVec2 box_max = position;
const float box_rounding = LayoutScale(1.0f); const float box_rounding = LayoutScale(1.0f);
dl->AddRectFilled(box_min, box_max, ImGui::GetColorU32(ImVec4(0.13f, 0.13f, 0.13f, opacity * 0.5f)), box_rounding); dl->AddRectFilled(box_min, box_max, ImGui::GetColorU32(ImVec4(0.13f, 0.13f, 0.13f, opacity * 0.5f)), box_rounding);
dl->AddRect(box_min, box_max, ImGui::GetColorU32(ImVec4(0.8f, 0.8f, 0.8f, opacity)), box_rounding); dl->AddRect(box_min, box_max, ImGui::GetColorU32(ImVec4(0.8f, 0.8f, 0.8f, opacity)), box_rounding);
const u32 text_col = ImGui::GetColorU32(ImVec4(1.0f, 1.0f, 1.0f, opacity)); const u32 text_col = ImGui::GetColorU32(ImVec4(1.0f, 1.0f, 1.0f, opacity));
const ImVec2 text_pos = box_min + ImVec2(padding, padding); const ImVec2 text_size = ImGuiFullscreen::g_medium_font->CalcTextSizeA(
const ImVec4 text_clip_rect(text_pos.x, text_pos.y, box_max.x, box_max.y); ImGuiFullscreen::g_medium_font->FontSize, FLT_MAX, 0.0f, indicator.text.c_str(),
indicator.text.c_str() + indicator.text.length());
const ImVec2 text_pos = ImVec2(box_max.x - padding - text_size.x, box_min.y + padding);
const ImVec4 text_clip_rect(box_min.x, box_min.y, box_max.x, box_max.y);
dl->AddText(g_medium_font, g_medium_font->FontSize, text_pos, text_col, indicator.text.c_str(), dl->AddText(g_medium_font, g_medium_font->FontSize, text_pos, text_col, indicator.text.c_str(),
indicator.text.c_str() + indicator.text.length(), 0.0f, &text_clip_rect); indicator.text.c_str() + indicator.text.length(), 0.0f, &text_clip_rect);
const ImVec2 icon_pos = ImVec2(box_min.x + padding, box_min.y + padding);
dl->AddText(g_medium_font, g_medium_font->FontSize, icon_pos, text_col, ICON_FA_STOPWATCH,
nullptr, 0.0f, &text_clip_rect);
if (!indicator.active && opacity <= 0.01f) if (!indicator.active && opacity <= 0.01f)
{ {
DevCon.WriteLn("(Achievements) Remove tracker indicator"); DevCon.WriteLn("(Achievements) Remove tracker indicator");
@ -2008,9 +2016,12 @@ void Achievements::DrawGameOverlays()
{ {
++it; ++it;
} }
position.x = box_min.x - padding;
} }
position.y -= image_size.y + padding; // Uncomment if there are any other overlays above this one.
//position.y -= image_size.y - padding * 3.0f;
} }
} }