mirror of
https://github.com/RetroDECK/ES-DE.git
synced 2025-01-20 07:45:39 +00:00
160 lines
4.9 KiB
C++
160 lines
4.9 KiB
C++
// SPDX-License-Identifier: MIT
|
|
//
|
|
// EmulationStation Desktop Edition
|
|
// ViewController.h
|
|
//
|
|
// Handles overall system navigation including animations and transitions.
|
|
// Creates the gamelist views and handles refresh and reloads of these when needed
|
|
// (for example when metadata has been changed or when a list sorting has taken place).
|
|
// Initiates the launching of games, calling FileData to do the actual launch.
|
|
// Displays a dialog when there are no games found on startup.
|
|
//
|
|
|
|
#ifndef ES_APP_VIEWS_VIEW_CONTROLLER_H
|
|
#define ES_APP_VIEWS_VIEW_CONTROLLER_H
|
|
|
|
#include "guis/GuiComplexTextEditPopup.h"
|
|
#include "guis/GuiMsgBox.h"
|
|
#include "renderers/Renderer.h"
|
|
#include "FileData.h"
|
|
#include "GuiComponent.h"
|
|
|
|
#include <vector>
|
|
|
|
class IGameListView;
|
|
class SystemData;
|
|
class SystemView;
|
|
|
|
// Handles transitions between views, e.g. from system to system and from gamelist to gamelist.
|
|
// Also sets up the initial gamelists and refreshes and reloads them as required.
|
|
class ViewController : public GuiComponent
|
|
{
|
|
public:
|
|
static void init(Window* window);
|
|
static ViewController* get();
|
|
|
|
virtual ~ViewController();
|
|
|
|
// These functions are called from main().
|
|
void noSystemsFileDialog();
|
|
void noGamesDialog();
|
|
|
|
// Try to completely populate the GameListView map.
|
|
// Caches things so there's no pauses during transitions.
|
|
void preload();
|
|
|
|
// If a basic view detected a metadata change, it can request to recreate
|
|
// the current gamelist view (as it may change to be detailed).
|
|
void reloadGameListView(IGameListView* gamelist, bool reloadTheme = false);
|
|
inline void reloadGameListView(SystemData* system, bool reloadTheme = false)
|
|
{ reloadGameListView(getGameListView(system).get(), reloadTheme); }
|
|
// Reload everything with a theme.
|
|
// Used when the "ThemeSet" setting changes.
|
|
void reloadAll();
|
|
|
|
// Navigation.
|
|
void goToNextGameList();
|
|
void goToPrevGameList();
|
|
void goToGameList(SystemData* system);
|
|
void goToSystemView(SystemData* system, bool playTransition);
|
|
void goToSystem(SystemData* system, bool animate);
|
|
void goToStart();
|
|
void ReloadAndGoToStart();
|
|
|
|
// Functions to make the GUI behave properly.
|
|
bool isCameraMoving();
|
|
void cancelViewTransitions();
|
|
void stopScrolling();
|
|
|
|
void onFileChanged(FileData* file, bool reloadGameList);
|
|
void triggerGameLaunch(FileData* game) { mGameToLaunch = game; mLockInput = true; };
|
|
bool getGameLaunchTriggered() { return (mGameToLaunch != nullptr); };
|
|
|
|
bool input(InputConfig* config, Input input) override;
|
|
void update(int deltaTime) override;
|
|
void render(const Transform4x4f& parentTrans) override;
|
|
|
|
enum ViewMode {
|
|
NOTHING,
|
|
START_SCREEN,
|
|
SYSTEM_SELECT,
|
|
GAME_LIST
|
|
};
|
|
|
|
enum GameListViewStyle {
|
|
AUTOMATIC,
|
|
BASIC,
|
|
DETAILED,
|
|
GRID,
|
|
VIDEO
|
|
};
|
|
|
|
struct State {
|
|
ViewMode viewing;
|
|
GameListViewStyle viewstyle;
|
|
|
|
inline SystemData* getSystem() const
|
|
{
|
|
assert(viewing == GAME_LIST || viewing == SYSTEM_SELECT);
|
|
return system;
|
|
}
|
|
|
|
private:
|
|
friend ViewController;
|
|
SystemData* system;
|
|
};
|
|
|
|
inline const State& getState() const { return mState; }
|
|
|
|
virtual std::vector<HelpPrompt> getHelpPrompts() override;
|
|
virtual HelpStyle getHelpStyle() override;
|
|
|
|
std::shared_ptr<IGameListView> getGameListView(SystemData* system);
|
|
std::shared_ptr<SystemView> getSystemListView();
|
|
void removeGameListView(SystemData* system);
|
|
|
|
// Whether to run in the background while a game is launched.
|
|
bool runInBackground(SystemData* system);
|
|
|
|
static const std::string FAVORITE_CHAR;
|
|
static const std::string FOLDER_CHAR;
|
|
static const std::string TICKMARK_CHAR;
|
|
static const std::string CONTROLLER_CHAR;
|
|
static const std::string FILTER_CHAR;
|
|
|
|
private:
|
|
ViewController(Window* window);
|
|
static ViewController* sInstance;
|
|
|
|
void launch(FileData* game);
|
|
|
|
std::string mNoGamesErrorMessage;
|
|
std::string mRomDirectory;
|
|
GuiMsgBox* mNoGamesMessageBox;
|
|
|
|
void playViewTransition(bool instant = false);
|
|
int getSystemId(SystemData* system);
|
|
// Restore view position if it was moved during wrap around.
|
|
void restoreViewPosition();
|
|
|
|
std::shared_ptr<GuiComponent> mCurrentView;
|
|
std::shared_ptr<GuiComponent> mPreviousView;
|
|
std::shared_ptr<GuiComponent> mSkipView;
|
|
std::map<SystemData*, std::shared_ptr<IGameListView>> mGameListViews;
|
|
std::shared_ptr<SystemView> mSystemListView;
|
|
|
|
Transform4x4f mCamera;
|
|
bool mSystemViewTransition;
|
|
bool mWrappedViews;
|
|
float mWrapPreviousPositionX;
|
|
float mFadeOpacity;
|
|
bool mCancelledTransition; // Needed only for the Fade transition style.
|
|
bool mLockInput;
|
|
bool mNextSystem;
|
|
FileData* mGameToLaunch;
|
|
|
|
State mState;
|
|
};
|
|
|
|
#endif // ES_APP_VIEWS_VIEW_CONTROLLER_H
|