mirror of
https://github.com/RetroDECK/ES-DE.git
synced 2025-01-17 22:55:38 +00:00
Found a better method to limit buffer swaps during splash screen rendering.
This commit is contained in:
parent
8c03c97e57
commit
022446bce7
|
@ -25,6 +25,8 @@
|
||||||
#include "views/GamelistView.h"
|
#include "views/GamelistView.h"
|
||||||
#include "views/ViewController.h"
|
#include "views/ViewController.h"
|
||||||
|
|
||||||
|
#include <SDL2/SDL_timer.h>
|
||||||
|
|
||||||
#include <fstream>
|
#include <fstream>
|
||||||
#include <pugixml.hpp>
|
#include <pugixml.hpp>
|
||||||
#include <random>
|
#include <random>
|
||||||
|
@ -511,6 +513,7 @@ bool SystemData::loadConfig()
|
||||||
const bool splashScreen {Settings::getInstance()->getBool("SplashScreen")};
|
const bool splashScreen {Settings::getInstance()->getBool("SplashScreen")};
|
||||||
float systemCount {0.0f};
|
float systemCount {0.0f};
|
||||||
float loadedSystems {0.0f};
|
float loadedSystems {0.0f};
|
||||||
|
long unsigned int lastTime {0};
|
||||||
|
|
||||||
for (pugi::xml_node system {systemList.child("system")}; system;
|
for (pugi::xml_node system {systemList.child("system")}; system;
|
||||||
system = system.next_sibling("system")) {
|
system = system.next_sibling("system")) {
|
||||||
|
@ -531,10 +534,17 @@ bool SystemData::loadConfig()
|
||||||
path = system.child("path").text().get();
|
path = system.child("path").text().get();
|
||||||
|
|
||||||
if (splashScreen) {
|
if (splashScreen) {
|
||||||
|
const long unsigned int curTime {SDL_GetTicks64()};
|
||||||
|
const long unsigned int deltaTime {curTime - lastTime};
|
||||||
|
lastTime = curTime;
|
||||||
++loadedSystems;
|
++loadedSystems;
|
||||||
const float progress {glm::mix(0.0f, 0.5f, loadedSystems / systemCount)};
|
// This prevents Renderer::swapBuffers() from being called excessively which
|
||||||
Window::getInstance()->renderSplashScreen(Window::SplashScreenState::SCANNING,
|
// could lead to significantly longer application startup times.
|
||||||
progress);
|
if (deltaTime > 15) {
|
||||||
|
const float progress {glm::mix(0.0f, 0.5f, loadedSystems / systemCount)};
|
||||||
|
Window::getInstance()->renderSplashScreen(Window::SplashScreenState::SCANNING,
|
||||||
|
progress);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
auto nameFindFunc = [&] {
|
auto nameFindFunc = [&] {
|
||||||
|
|
|
@ -707,15 +707,7 @@ int main(int argc, char* argv[])
|
||||||
AudioManager::getInstance();
|
AudioManager::getInstance();
|
||||||
MameNames::getInstance();
|
MameNames::getInstance();
|
||||||
ThemeData::populateThemeSets();
|
ThemeData::populateThemeSets();
|
||||||
// We need to temporarily disable VSync as the splash screen may otherwise slow down
|
|
||||||
// application startup significantly due to excessive swapBuffers() calls.
|
|
||||||
const bool splashScreen {Settings::getInstance()->getBool("SplashScreen")};
|
|
||||||
const bool vSync {Settings::getInstance()->getBool("VSync")};
|
|
||||||
if (splashScreen && vSync)
|
|
||||||
SDL_GL_SetSwapInterval(0);
|
|
||||||
loadSystemsReturnCode loadSystemsStatus {loadSystemConfigFile()};
|
loadSystemsReturnCode loadSystemsStatus {loadSystemConfigFile()};
|
||||||
if (splashScreen && vSync)
|
|
||||||
SDL_GL_SetSwapInterval(1);
|
|
||||||
|
|
||||||
if (loadSystemsStatus) {
|
if (loadSystemsStatus) {
|
||||||
// If there was an issue parsing the es_systems.xml file, display an error message.
|
// If there was an issue parsing the es_systems.xml file, display an error message.
|
||||||
|
|
|
@ -1104,6 +1104,9 @@ void ViewController::preload()
|
||||||
{
|
{
|
||||||
unsigned int systemCount {static_cast<unsigned int>(SystemData::sSystemVector.size())};
|
unsigned int systemCount {static_cast<unsigned int>(SystemData::sSystemVector.size())};
|
||||||
|
|
||||||
|
if (Settings::getInstance()->getBool("SplashScreen"))
|
||||||
|
mWindow->renderSplashScreen(Window::SplashScreenState::POPULATING, 0.5f);
|
||||||
|
|
||||||
// This reduces the amount of texture pop-in when loading theme extras.
|
// This reduces the amount of texture pop-in when loading theme extras.
|
||||||
if (!SystemData::sSystemVector.empty())
|
if (!SystemData::sSystemVector.empty())
|
||||||
getSystemListView();
|
getSystemListView();
|
||||||
|
|
Loading…
Reference in a new issue