* proper fix for the window resizing problem, thanks to Nemirtingas
* remove the code which adds custom Windows fonts but keep scaling * only attempt to load achievements images when hook is ready * cleanup overlay images on unhook * free the detector when we get a renderer hook instance * lock everywhere! * prefix the debug messages for a cleaner debug log
This commit is contained in:
parent
b137cf0f38
commit
88ab37d78f
@ -118,7 +118,7 @@ struct Overlay_Appearance {
|
|||||||
|
|
||||||
constexpr const static NotificationPosition default_pos = NotificationPosition::top_right;
|
constexpr const static NotificationPosition default_pos = NotificationPosition::top_right;
|
||||||
|
|
||||||
float font_size = 16.0;
|
float font_size = 13.5;
|
||||||
float icon_size = 64.0;
|
float icon_size = 64.0;
|
||||||
float notification_r = 0.16;
|
float notification_r = 0.16;
|
||||||
float notification_g = 0.29;
|
float notification_g = 0.29;
|
||||||
|
@ -116,7 +116,6 @@ class Steam_Overlay
|
|||||||
std::string show_url;
|
std::string show_url;
|
||||||
std::vector<Overlay_Achievement> achievements;
|
std::vector<Overlay_Achievement> achievements;
|
||||||
bool show_achievements, show_settings;
|
bool show_achievements, show_settings;
|
||||||
void *fonts_atlas;
|
|
||||||
|
|
||||||
// disable input when force_*.txt file is used
|
// disable input when force_*.txt file is used
|
||||||
bool disable_user_input;
|
bool disable_user_input;
|
||||||
|
@ -6,6 +6,7 @@
|
|||||||
// avoids confusing ImGui when another label has the same text "MyText"
|
// avoids confusing ImGui when another label has the same text "MyText"
|
||||||
|
|
||||||
#include "overlay/steam_overlay.h"
|
#include "overlay/steam_overlay.h"
|
||||||
|
#include "overlay/notification.h"
|
||||||
#include "overlay/steam_overlay_translations.h"
|
#include "overlay/steam_overlay_translations.h"
|
||||||
|
|
||||||
#include <thread>
|
#include <thread>
|
||||||
@ -59,6 +60,10 @@ static constexpr char *valid_languages[] = {
|
|||||||
|
|
||||||
#define URL_WINDOW_NAME "URL Window"
|
#define URL_WINDOW_NAME "URL Window"
|
||||||
|
|
||||||
|
ImFontAtlas fonts_atlas{};
|
||||||
|
ImFont *font_default{};
|
||||||
|
ImFont *font_notif{};
|
||||||
|
|
||||||
int find_free_id(std::vector<int> & ids, int base)
|
int find_free_id(std::vector<int> & ids, int base)
|
||||||
{
|
{
|
||||||
std::sort(ids.begin(), ids.end());
|
std::sort(ids.begin(), ids.end());
|
||||||
@ -101,7 +106,6 @@ int find_free_notification_id(std::vector<Notification> const& notifications)
|
|||||||
return find_free_id(ids, base_friend_window_id);
|
return find_free_id(ids, base_friend_window_id);
|
||||||
}
|
}
|
||||||
|
|
||||||
#include "overlay/notification.h"
|
|
||||||
char *notif_achievement_wav_custom;
|
char *notif_achievement_wav_custom;
|
||||||
char *notif_invite_wav_custom;
|
char *notif_invite_wav_custom;
|
||||||
bool notif_achievement_wav_custom_inuse = false;
|
bool notif_achievement_wav_custom_inuse = false;
|
||||||
@ -135,8 +139,7 @@ Steam_Overlay::Steam_Overlay(Settings* settings, SteamCallResults* callback_resu
|
|||||||
i_have_lobby(false),
|
i_have_lobby(false),
|
||||||
show_achievements(false),
|
show_achievements(false),
|
||||||
show_settings(false),
|
show_settings(false),
|
||||||
_renderer(nullptr),
|
_renderer(nullptr)
|
||||||
fonts_atlas(nullptr)
|
|
||||||
{
|
{
|
||||||
strncpy(username_text, settings->get_local_name(), sizeof(username_text));
|
strncpy(username_text, settings->get_local_name(), sizeof(username_text));
|
||||||
|
|
||||||
@ -185,6 +188,7 @@ bool Steam_Overlay::NeedPresent() const
|
|||||||
|
|
||||||
void Steam_Overlay::SetNotificationPosition(ENotificationPosition eNotificationPosition)
|
void Steam_Overlay::SetNotificationPosition(ENotificationPosition eNotificationPosition)
|
||||||
{
|
{
|
||||||
|
std::lock_guard<std::recursive_mutex> lock(overlay_mutex);
|
||||||
notif_position = eNotificationPosition;
|
notif_position = eNotificationPosition;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -216,54 +220,52 @@ void Steam_Overlay::UnSetupOverlay()
|
|||||||
InGameOverlay::FreeDetector();
|
InGameOverlay::FreeDetector();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (_renderer) {
|
||||||
|
for (auto &ach : achievements) {
|
||||||
|
if (!ach.icon.expired()) _renderer->ReleaseImageResource(ach.icon);
|
||||||
|
if (!ach.icon_gray.expired()) _renderer->ReleaseImageResource(ach.icon_gray);
|
||||||
|
}
|
||||||
|
|
||||||
|
_renderer = nullptr;
|
||||||
|
PRINT_DEBUG("Steam_Overlay::UnSetupOverlay freed all images\n");
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
void Steam_Overlay::HookReady(bool ready)
|
void Steam_Overlay::HookReady(bool ready)
|
||||||
{
|
{
|
||||||
PRINT_DEBUG("Steam_Overlay::HookReady %i\n", (int)ready);
|
PRINT_DEBUG("Steam_Overlay::HookReady %i\n", (int)ready);
|
||||||
{
|
std::lock_guard<std::recursive_mutex> lock(overlay_mutex);
|
||||||
// TODO: Uncomment this and draw our own cursor (cosmetics)
|
|
||||||
|
is_ready = ready;
|
||||||
|
|
||||||
ImGuiIO &io = ImGui::GetIO();
|
ImGuiIO &io = ImGui::GetIO();
|
||||||
|
ImGuiStyle &style = ImGui::GetStyle();
|
||||||
|
|
||||||
|
// disable loading the default ini file
|
||||||
|
io.IniFilename = NULL;
|
||||||
|
|
||||||
|
// Disable round window
|
||||||
|
style.WindowRounding = 0.0;
|
||||||
|
|
||||||
|
// TODO: Uncomment this and draw our own cursor (cosmetics)
|
||||||
//io.WantSetMousePos = false;
|
//io.WantSetMousePos = false;
|
||||||
//io.MouseDrawCursor = false;
|
//io.MouseDrawCursor = false;
|
||||||
//io.ConfigFlags |= ImGuiConfigFlags_NoMouseCursorChange;
|
//io.ConfigFlags |= ImGuiConfigFlags_NoMouseCursorChange;
|
||||||
|
|
||||||
io.IniFilename = NULL;
|
|
||||||
|
|
||||||
#ifdef __WINDOWS__
|
|
||||||
// https://github.com/ocornut/imgui/blob/fbf45ad149b10ff8d9cb97aefe0dc5a9562fd66e/backends/imgui_impl_win32.cpp#L373-L382
|
|
||||||
struct ImGui_ImplWin32_Data
|
|
||||||
{
|
|
||||||
HWND hWnd;
|
|
||||||
};
|
|
||||||
|
|
||||||
auto bd = ImGui::GetCurrentContext() ? (ImGui_ImplWin32_Data*)ImGui::GetIO().BackendPlatformUserData : nullptr;;
|
|
||||||
if (bd) {
|
|
||||||
|
|
||||||
// IM_ASSERT(bd != nullptr && "Did you call ImGui_ImplWin32_Init()?");
|
|
||||||
|
|
||||||
// Setup display size (every frame to accommodate for window resizing)
|
|
||||||
RECT rect = { 0, 0, 0, 0 };
|
|
||||||
::GetClientRect(bd->hWnd, &rect);
|
|
||||||
io.DisplaySize = ImVec2((float)(rect.right - rect.left), (float)(rect.bottom - rect.top));
|
|
||||||
|
|
||||||
}
|
|
||||||
#endif // __WINDOWS__
|
|
||||||
|
|
||||||
is_ready = ready;
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void Steam_Overlay::OpenOverlayInvite(CSteamID lobbyId)
|
void Steam_Overlay::OpenOverlayInvite(CSteamID lobbyId)
|
||||||
{
|
{
|
||||||
|
std::lock_guard<std::recursive_mutex> lock(overlay_mutex);
|
||||||
ShowOverlay(true);
|
ShowOverlay(true);
|
||||||
}
|
}
|
||||||
|
|
||||||
void Steam_Overlay::OpenOverlay(const char* pchDialog)
|
void Steam_Overlay::OpenOverlay(const char* pchDialog)
|
||||||
{
|
{
|
||||||
|
std::lock_guard<std::recursive_mutex> lock(overlay_mutex);
|
||||||
// TODO: Show pages depending on pchDialog
|
// TODO: Show pages depending on pchDialog
|
||||||
if ((strncmp(pchDialog, "Friends", sizeof("Friends") - 1) == 0) && (settings->overlayAutoAcceptInvitesCount() > 0)) {
|
if ((strncmp(pchDialog, "Friends", sizeof("Friends") - 1) == 0) && (settings->overlayAutoAcceptInvitesCount() > 0)) {
|
||||||
PRINT_DEBUG("Not opening overlay's friends list because some friends are defined in the auto accept list\n");
|
PRINT_DEBUG("Steam_Overlay won't open overlay's friends list because some friends are defined in the auto accept list\n");
|
||||||
AddAutoAcceptInviteNotification();
|
AddAutoAcceptInviteNotification();
|
||||||
} else {
|
} else {
|
||||||
ShowOverlay(true);
|
ShowOverlay(true);
|
||||||
@ -272,6 +274,7 @@ void Steam_Overlay::OpenOverlay(const char* pchDialog)
|
|||||||
|
|
||||||
void Steam_Overlay::OpenOverlayWebpage(const char* pchURL)
|
void Steam_Overlay::OpenOverlayWebpage(const char* pchURL)
|
||||||
{
|
{
|
||||||
|
std::lock_guard<std::recursive_mutex> lock(overlay_mutex);
|
||||||
show_url = pchURL;
|
show_url = pchURL;
|
||||||
ShowOverlay(true);
|
ShowOverlay(true);
|
||||||
}
|
}
|
||||||
@ -283,6 +286,7 @@ bool Steam_Overlay::ShowOverlay() const
|
|||||||
|
|
||||||
bool Steam_Overlay::OpenOverlayHook(bool toggle)
|
bool Steam_Overlay::OpenOverlayHook(bool toggle)
|
||||||
{
|
{
|
||||||
|
std::lock_guard<std::recursive_mutex> lock(overlay_mutex);
|
||||||
if (toggle) {
|
if (toggle) {
|
||||||
ShowOverlay(!show_overlay);
|
ShowOverlay(!show_overlay);
|
||||||
}
|
}
|
||||||
@ -292,15 +296,19 @@ bool Steam_Overlay::OpenOverlayHook(bool toggle)
|
|||||||
|
|
||||||
void Steam_Overlay::ShowOverlay(bool state)
|
void Steam_Overlay::ShowOverlay(bool state)
|
||||||
{
|
{
|
||||||
|
std::lock_guard<std::recursive_mutex> lock(overlay_mutex);
|
||||||
if (!Ready() || show_overlay == state)
|
if (!Ready() || show_overlay == state)
|
||||||
return;
|
return;
|
||||||
|
|
||||||
ImGuiIO &io = ImGui::GetIO();
|
// this is very important, it doesn't just prevent input confusion between game's window
|
||||||
|
// and overlay's window, but internally it calls the necessary fuctions to properly update
|
||||||
|
// ImGui window size
|
||||||
if (state) {
|
if (state) {
|
||||||
io.MouseDrawCursor = true;
|
_renderer->HideAppInputs(true);
|
||||||
|
_renderer->HideOverlayInputs(false);
|
||||||
} else {
|
} else {
|
||||||
io.MouseDrawCursor = false;
|
_renderer->HideAppInputs(false);
|
||||||
|
_renderer->HideOverlayInputs(true);
|
||||||
}
|
}
|
||||||
|
|
||||||
show_overlay = state;
|
show_overlay = state;
|
||||||
@ -399,7 +407,7 @@ void Steam_Overlay::FriendConnect(Friend _friend)
|
|||||||
item.joinable = false;
|
item.joinable = false;
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
PRINT_DEBUG("No more free id to create a friend window\n");
|
PRINT_DEBUG("Steam_Overlay error no free id to create a friend window\n");
|
||||||
}
|
}
|
||||||
|
|
||||||
void Steam_Overlay::FriendDisconnect(Friend _friend)
|
void Steam_Overlay::FriendDisconnect(Friend _friend)
|
||||||
@ -426,7 +434,7 @@ void Steam_Overlay::AddMessageNotification(std::string const& message)
|
|||||||
have_notifications = true;
|
have_notifications = true;
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
PRINT_DEBUG("No more free id to create a notification window\n");
|
PRINT_DEBUG("Steam_Overlay error no free id to create a notification window\n");
|
||||||
}
|
}
|
||||||
|
|
||||||
// show a notification when the user unlocks an achievement
|
// show a notification when the user unlocks an achievement
|
||||||
@ -462,7 +470,7 @@ void Steam_Overlay::AddAchievementNotification(nlohmann::json const& ach)
|
|||||||
have_notifications = true;
|
have_notifications = true;
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
PRINT_DEBUG("No more free id to create a notification window\n");
|
PRINT_DEBUG("Steam_Overlay error no free id to create a notification window\n");
|
||||||
}
|
}
|
||||||
|
|
||||||
std::string ach_name = ach.value("name", "");
|
std::string ach_name = ach.value("name", "");
|
||||||
@ -502,7 +510,7 @@ void Steam_Overlay::AddInviteNotification(std::pair<const Friend, friend_window_
|
|||||||
have_notifications = true;
|
have_notifications = true;
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
PRINT_DEBUG("No more free id to create a notification window\n");
|
PRINT_DEBUG("Steam_Overlay error no free id to create a notification window\n");
|
||||||
}
|
}
|
||||||
|
|
||||||
void Steam_Overlay::AddAutoAcceptInviteNotification()
|
void Steam_Overlay::AddAutoAcceptInviteNotification()
|
||||||
@ -526,7 +534,7 @@ void Steam_Overlay::AddAutoAcceptInviteNotification()
|
|||||||
NotifySoundAutoAcceptFriendInvite();
|
NotifySoundAutoAcceptFriendInvite();
|
||||||
have_notifications = true;
|
have_notifications = true;
|
||||||
} else {
|
} else {
|
||||||
PRINT_DEBUG("No free id to create an auto-accept notification window\n");
|
PRINT_DEBUG("Steam_Overlay error no free id to create an auto-accept notification window\n");
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -712,9 +720,6 @@ void Steam_Overlay::BuildFriendWindow(Friend const& frd, friend_window_state& st
|
|||||||
ImGui::End();
|
ImGui::End();
|
||||||
}
|
}
|
||||||
|
|
||||||
ImFont *font_default;
|
|
||||||
ImFont *font_notif;
|
|
||||||
|
|
||||||
// set the position of the next notification
|
// set the position of the next notification
|
||||||
void Steam_Overlay::SetNextNotificationPos(float width, float height, float font_size, notification_type type, struct NotificationsIndexes &idx)
|
void Steam_Overlay::SetNextNotificationPos(float width, float height, float font_size, notification_type type, struct NotificationsIndexes &idx)
|
||||||
{
|
{
|
||||||
@ -875,105 +880,32 @@ void Steam_Overlay::BuildNotifications(int width, int height)
|
|||||||
|
|
||||||
void Steam_Overlay::CreateFonts()
|
void Steam_Overlay::CreateFonts()
|
||||||
{
|
{
|
||||||
if (fonts_atlas) return;
|
std::lock_guard<std::recursive_mutex> lock(overlay_mutex);
|
||||||
|
static bool configured_font = false;
|
||||||
|
|
||||||
ImFontAtlas *Fonts = new ImFontAtlas();
|
if (configured_font) return;
|
||||||
|
configured_font = true;
|
||||||
|
|
||||||
ImFontConfig fontcfg;
|
ImFontConfig fontcfg{};
|
||||||
|
|
||||||
float font_size = settings->overlay_appearance.font_size;
|
float font_size = settings->overlay_appearance.font_size;
|
||||||
fontcfg.OversampleH = fontcfg.OversampleV = 1;
|
fontcfg.OversampleH = fontcfg.OversampleV = 1;
|
||||||
fontcfg.PixelSnapH = true;
|
fontcfg.PixelSnapH = true;
|
||||||
fontcfg.SizePixels = font_size;
|
fontcfg.SizePixels = font_size;
|
||||||
|
fontcfg.GlyphRanges = fonts_atlas.GetGlyphRangesDefault();
|
||||||
|
|
||||||
ImFontGlyphRangesBuilder font_builder;
|
ImFont *font = fonts_atlas.AddFontDefault(&fontcfg);
|
||||||
for (auto & x : achievements) {
|
|
||||||
font_builder.AddText(x.title.c_str());
|
|
||||||
font_builder.AddText(x.description.c_str());
|
|
||||||
}
|
|
||||||
for (int i = 0; i < TRANSLATION_NUMBER_OF_LANGUAGES; i++) {
|
|
||||||
font_builder.AddText(translationChat[i]);
|
|
||||||
font_builder.AddText(translationInvite[i]);
|
|
||||||
font_builder.AddText(translationJoin[i]);
|
|
||||||
font_builder.AddText(translationInvitedYouToJoinTheGame[i]);
|
|
||||||
font_builder.AddText(translationAccept[i]);
|
|
||||||
font_builder.AddText(translationRefuse[i]);
|
|
||||||
font_builder.AddText(translationSend[i]);
|
|
||||||
font_builder.AddText(translationSteamOverlay[i]);
|
|
||||||
font_builder.AddText(translationUserPlaying[i]);
|
|
||||||
font_builder.AddText(translationRenderer[i]);
|
|
||||||
font_builder.AddText(translationShowAchievements[i]);
|
|
||||||
font_builder.AddText(translationSettings[i]);
|
|
||||||
font_builder.AddText(translationFriends[i]);
|
|
||||||
font_builder.AddText(translationAchievementWindow[i]);
|
|
||||||
font_builder.AddText(translationListOfAchievements[i]);
|
|
||||||
font_builder.AddText(translationAchievements[i]);
|
|
||||||
font_builder.AddText(translationHiddenAchievement[i]);
|
|
||||||
font_builder.AddText(translationAchievedOn[i]);
|
|
||||||
font_builder.AddText(translationNotAchieved[i]);
|
|
||||||
font_builder.AddText(translationGlobalSettingsWindow[i]);
|
|
||||||
font_builder.AddText(translationGlobalSettingsWindowDescription[i]);
|
|
||||||
font_builder.AddText(translationUsername[i]);
|
|
||||||
font_builder.AddText(translationLanguage[i]);
|
|
||||||
font_builder.AddText(translationSelectedLanguage[i]);
|
|
||||||
font_builder.AddText(translationRestartTheGameToApply[i]);
|
|
||||||
font_builder.AddText(translationSave[i]);
|
|
||||||
font_builder.AddText(translationWarning[i]);
|
|
||||||
font_builder.AddText(translationWarningWarningWarning[i]);
|
|
||||||
font_builder.AddText(translationWarningDescription1[i]);
|
|
||||||
font_builder.AddText(translationWarningDescription2[i]);
|
|
||||||
font_builder.AddText(translationWarningDescription3[i]);
|
|
||||||
font_builder.AddText(translationWarningDescription4[i]);
|
|
||||||
font_builder.AddText(translationSteamOverlayURL[i]);
|
|
||||||
font_builder.AddText(translationClose[i]);
|
|
||||||
font_builder.AddText(translationPlaying[i]);
|
|
||||||
}
|
|
||||||
|
|
||||||
font_builder.AddRanges(Fonts->GetGlyphRangesDefault());
|
|
||||||
|
|
||||||
ImVector<ImWchar> ranges;
|
|
||||||
font_builder.BuildRanges(&ranges);
|
|
||||||
|
|
||||||
bool need_extra_fonts = false;
|
|
||||||
for (auto &x : ranges) {
|
|
||||||
if (x > 0xFF) {
|
|
||||||
need_extra_fonts = true;
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
fontcfg.GlyphRanges = ranges.Data;
|
|
||||||
ImFont *font = NULL;
|
|
||||||
|
|
||||||
#if defined(__WINDOWS__)
|
|
||||||
font = Fonts->AddFontFromFileTTF("C:\\Windows\\Fonts\\micross.ttf", font_size, &fontcfg);
|
|
||||||
#endif
|
|
||||||
|
|
||||||
if (!font) {
|
|
||||||
font = Fonts->AddFontDefault(&fontcfg);
|
|
||||||
}
|
|
||||||
|
|
||||||
font_notif = font_default = font;
|
font_notif = font_default = font;
|
||||||
|
|
||||||
if (need_extra_fonts) {
|
fonts_atlas.Build();
|
||||||
PRINT_DEBUG("Steam_Overlay loading extra fonts\n");
|
|
||||||
fontcfg.MergeMode = true;
|
|
||||||
#if defined(__WINDOWS__)
|
|
||||||
Fonts->AddFontFromFileTTF("C:\\Windows\\Fonts\\simsun.ttc", font_size, &fontcfg);
|
|
||||||
Fonts->AddFontFromFileTTF("C:\\Windows\\Fonts\\malgun.ttf", font_size, &fontcfg);
|
|
||||||
#endif
|
|
||||||
}
|
|
||||||
|
|
||||||
Fonts->Build();
|
|
||||||
fonts_atlas = (void *)Fonts;
|
|
||||||
|
|
||||||
// ImGuiStyle& style = ImGui::GetStyle();
|
|
||||||
// style.WindowRounding = 0.0; // Disable round window
|
|
||||||
reset_LastError();
|
reset_LastError();
|
||||||
}
|
}
|
||||||
|
|
||||||
void Steam_Overlay::LoadAudio()
|
void Steam_Overlay::LoadAudio()
|
||||||
{
|
{
|
||||||
|
std::lock_guard<std::recursive_mutex> lock(overlay_mutex);
|
||||||
std::string file_path;
|
std::string file_path;
|
||||||
std::string file_name;
|
std::string file_name;
|
||||||
unsigned long long file_size;
|
unsigned long long file_size;
|
||||||
@ -1028,26 +960,33 @@ static inline bool ImGuiHelper_BeginListBox(const char* label, int items_count)
|
|||||||
// Try to make this function as short as possible or it might affect game's fps.
|
// Try to make this function as short as possible or it might affect game's fps.
|
||||||
void Steam_Overlay::OverlayProc()
|
void Steam_Overlay::OverlayProc()
|
||||||
{
|
{
|
||||||
|
std::lock_guard<std::recursive_mutex> lock(overlay_mutex);
|
||||||
if (!Ready())
|
if (!Ready())
|
||||||
return;
|
return;
|
||||||
|
|
||||||
ImGuiIO& io = ImGui::GetIO();
|
ImGuiIO& io = ImGui::GetIO();
|
||||||
|
|
||||||
|
if (show_overlay) {
|
||||||
|
// Set the overlay windows to the size of the game window
|
||||||
|
ImGui::SetNextWindowPos({ 0,0 });
|
||||||
|
ImGui::SetNextWindowSize({ io.DisplaySize.x, io.DisplaySize.y });
|
||||||
|
|
||||||
|
ImGui::SetNextWindowBgAlpha(0.50);
|
||||||
|
|
||||||
|
ImGui::PushFont(font_default);
|
||||||
|
}
|
||||||
|
|
||||||
if (have_notifications) {
|
if (have_notifications) {
|
||||||
ImGui::PushFont(font_notif);
|
ImGui::PushFont(font_notif);
|
||||||
BuildNotifications(io.DisplaySize.x, io.DisplaySize.y);
|
BuildNotifications(io.DisplaySize.x, io.DisplaySize.y);
|
||||||
ImGui::PopFont();
|
ImGui::PopFont();
|
||||||
}
|
}
|
||||||
|
|
||||||
if (show_overlay) {
|
// ******************** exit early if we shouldn't show the overlay
|
||||||
// Set the overlay windows to the size of the game window
|
if (!show_overlay) {
|
||||||
ImGui::SetNextWindowPos({ 0,0 });
|
return;
|
||||||
ImGui::SetNextWindowSize({ static_cast<float>(io.DisplaySize.x),
|
}
|
||||||
static_cast<float>(io.DisplaySize.y) });
|
// ********************
|
||||||
|
|
||||||
ImGui::SetNextWindowBgAlpha(0.50);
|
|
||||||
|
|
||||||
ImGui::PushFont(font_default);
|
|
||||||
|
|
||||||
bool show = true;
|
bool show = true;
|
||||||
|
|
||||||
@ -1319,7 +1258,6 @@ void Steam_Overlay::OverlayProc()
|
|||||||
if (!show)
|
if (!show)
|
||||||
ShowOverlay(false);
|
ShowOverlay(false);
|
||||||
}
|
}
|
||||||
}
|
|
||||||
|
|
||||||
void Steam_Overlay::Callback(Common_Message *msg)
|
void Steam_Overlay::Callback(Common_Message *msg)
|
||||||
{
|
{
|
||||||
@ -1344,7 +1282,8 @@ void Steam_Overlay::Callback(Common_Message *msg)
|
|||||||
|
|
||||||
void Steam_Overlay::RunCallbacks()
|
void Steam_Overlay::RunCallbacks()
|
||||||
{
|
{
|
||||||
if (!achievements.size() && load_achievements_trials > 0) {
|
std::lock_guard<std::recursive_mutex> lock(overlay_mutex);
|
||||||
|
if (Ready() && !achievements.size() && load_achievements_trials > 0) {
|
||||||
--load_achievements_trials;
|
--load_achievements_trials;
|
||||||
Steam_User_Stats* steamUserStats = get_steam_client()->steam_user_stats;
|
Steam_User_Stats* steamUserStats = get_steam_client()->steam_user_stats;
|
||||||
uint32 achievements_num = steamUserStats->GetNumAchievements();
|
uint32 achievements_num = steamUserStats->GetNumAchievements();
|
||||||
@ -1378,28 +1317,42 @@ void Steam_Overlay::RunCallbacks()
|
|||||||
achievements.push_back(ach);
|
achievements.push_back(ach);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// don't punish successfull attempts
|
||||||
|
if (achievements.size()) {
|
||||||
|
++load_achievements_trials;
|
||||||
|
}
|
||||||
PRINT_DEBUG("Steam_Overlay POPULATE OVERLAY ACHIEVEMENTS DONE\n");
|
PRINT_DEBUG("Steam_Overlay POPULATE OVERLAY ACHIEVEMENTS DONE\n");
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// if the detector has finished its job, and the overlay was still not ready
|
||||||
|
// then get the renderer hook instance
|
||||||
if (!Ready() && future_renderer.valid()) {
|
if (!Ready() && future_renderer.valid()) {
|
||||||
if (future_renderer.wait_for(std::chrono::milliseconds{0}) == std::future_status::ready) {
|
if (future_renderer.wait_for(std::chrono::milliseconds{0}) == std::future_status::ready) {
|
||||||
_renderer = future_renderer.get();
|
_renderer = future_renderer.get();
|
||||||
|
InGameOverlay::StopRendererDetection();
|
||||||
|
InGameOverlay::FreeDetector();
|
||||||
PRINT_DEBUG("Steam_Overlay got renderer %p\n", _renderer);
|
PRINT_DEBUG("Steam_Overlay got renderer %p\n", _renderer);
|
||||||
CreateFonts();
|
CreateFonts();
|
||||||
LoadAudio();
|
LoadAudio();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// if we have a renderer hook instance but it wasn't started yet
|
||||||
if (!Ready() && _renderer && !_renderer->IsStarted()) {
|
if (!Ready() && _renderer && !_renderer->IsStarted()) {
|
||||||
const static std::set<InGameOverlay::ToggleKey> keys = {InGameOverlay::ToggleKey::SHIFT, InGameOverlay::ToggleKey::TAB};
|
const static std::set<InGameOverlay::ToggleKey> overlay_toggle_keys = {
|
||||||
auto key_combination_callback = [this]() { OpenOverlayHook(true); };
|
InGameOverlay::ToggleKey::SHIFT, InGameOverlay::ToggleKey::TAB
|
||||||
|
};
|
||||||
|
auto overlay_toggle_callback = [this]() { OpenOverlayHook(true); };
|
||||||
_renderer->OverlayProc = [this]() { OverlayProc(); };
|
_renderer->OverlayProc = [this]() { OverlayProc(); };
|
||||||
_renderer->OverlayHookReady = [this](InGameOverlay::OverlayHookState state) {
|
_renderer->OverlayHookReady = [this](InGameOverlay::OverlayHookState state) {
|
||||||
PRINT_DEBUG("Steam_Overlay hook state changed %i\n", (int)state);
|
PRINT_DEBUG("Steam_Overlay hook state changed %i\n", (int)state);
|
||||||
|
if (state == InGameOverlay::OverlayHookState::Removing) {
|
||||||
|
_renderer = nullptr;
|
||||||
|
}
|
||||||
HookReady(state == InGameOverlay::OverlayHookState::Ready || state == InGameOverlay::OverlayHookState::Reset);
|
HookReady(state == InGameOverlay::OverlayHookState::Ready || state == InGameOverlay::OverlayHookState::Reset);
|
||||||
};
|
};
|
||||||
bool started = _renderer->StartHook(key_combination_callback, keys, fonts_atlas);
|
bool started = _renderer->StartHook(overlay_toggle_callback, overlay_toggle_keys, &fonts_atlas);
|
||||||
PRINT_DEBUG("Steam_Overlay tried to start renderer hook (result=%u)\n", started);
|
PRINT_DEBUG("Steam_Overlay tried to start renderer hook (result=%u)\n", started);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -1409,6 +1362,7 @@ void Steam_Overlay::RunCallbacks()
|
|||||||
GameOverlayActivated_t data{};
|
GameOverlayActivated_t data{};
|
||||||
data.m_bActive = show_overlay;
|
data.m_bActive = show_overlay;
|
||||||
data.m_bUserInitiated = true;
|
data.m_bUserInitiated = true;
|
||||||
|
data.m_dwOverlayPID = 123;
|
||||||
data.m_nAppID = settings->get_local_game_id().AppID();
|
data.m_nAppID = settings->get_local_game_id().AppID();
|
||||||
callbacks->addCBResult(data.k_iCallback, &data, sizeof(data));
|
callbacks->addCBResult(data.k_iCallback, &data, sizeof(data));
|
||||||
}
|
}
|
||||||
@ -1428,7 +1382,6 @@ void Steam_Overlay::RunCallbacks()
|
|||||||
}
|
}
|
||||||
|
|
||||||
i_have_lobby = IHaveLobby();
|
i_have_lobby = IHaveLobby();
|
||||||
std::lock_guard<std::recursive_mutex> lock(overlay_mutex);
|
|
||||||
std::for_each(friends.begin(), friends.end(), [this](std::pair<Friend const, friend_window_state> &i)
|
std::for_each(friends.begin(), friends.end(), [this](std::pair<Friend const, friend_window_state> &i)
|
||||||
{
|
{
|
||||||
i.second.joinable = FriendJoinable(i);
|
i.second.joinable = FriendJoinable(i);
|
||||||
@ -1515,9 +1468,9 @@ void Steam_Overlay::RunCallbacks()
|
|||||||
}
|
}
|
||||||
|
|
||||||
// if variable == true, then set it to false and return true (because state was changed) in that case
|
// if variable == true, then set it to false and return true (because state was changed) in that case
|
||||||
bool true_tmp = true;
|
bool yes_clicked = true;
|
||||||
if (invite_all_friends_clicked.compare_exchange_weak(true_tmp, false)) {
|
if (invite_all_friends_clicked.compare_exchange_weak(yes_clicked, false)) {
|
||||||
PRINT_DEBUG("Overlay will send invitations to [%zu] friends if they're using the same app\n", friends.size());
|
PRINT_DEBUG("Steam_Overlay will send invitations to [%zu] friends if they're using the same app\n", friends.size());
|
||||||
uint32 current_appid = settings->get_local_game_id().AppID();
|
uint32 current_appid = settings->get_local_game_id().AppID();
|
||||||
for (auto &fr : friends) {
|
for (auto &fr : friends) {
|
||||||
if (fr.first.appid() == current_appid) { // friend is playing the same game
|
if (fr.first.appid() == current_appid) { // friend is playing the same game
|
||||||
@ -1533,10 +1486,10 @@ void Steam_Overlay::InviteFriend(uint64 friend_id, class Steam_Friends* steamFri
|
|||||||
std::string connect_str = steamFriends->GetFriendRichPresence(settings->get_local_steam_id(), "connect");
|
std::string connect_str = steamFriends->GetFriendRichPresence(settings->get_local_steam_id(), "connect");
|
||||||
if (connect_str.length() > 0) {
|
if (connect_str.length() > 0) {
|
||||||
steamFriends->InviteUserToGame(friend_id, connect_str.c_str());
|
steamFriends->InviteUserToGame(friend_id, connect_str.c_str());
|
||||||
PRINT_DEBUG("Overlay sent game invitation to friend with id = %llu\n", friend_id);
|
PRINT_DEBUG("Steam_Overlay sent game invitation to friend with id = %llu\n", friend_id);
|
||||||
} else if (settings->get_lobby().IsValid()) {
|
} else if (settings->get_lobby().IsValid()) {
|
||||||
steamMatchmaking->InviteUserToLobby(settings->get_lobby(), friend_id);
|
steamMatchmaking->InviteUserToLobby(settings->get_lobby(), friend_id);
|
||||||
PRINT_DEBUG("Overlay sent lobby invitation to friend with id = %llu\n", friend_id);
|
PRINT_DEBUG("Steam_Overlay sent lobby invitation to friend with id = %llu\n", friend_id);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1,5 +1,4 @@
|
|||||||
|
Font_Size 13.5
|
||||||
Font_Size 16.0
|
|
||||||
Icon_Size 64.0
|
Icon_Size 64.0
|
||||||
|
|
||||||
Notification_R 0.16
|
Notification_R 0.16
|
||||||
|
Loading…
x
Reference in New Issue
Block a user