2023-04-30 00:03:50 +02:00
|
|
|
/*
|
|
|
|
* WindowHandler.h, part of VCMI engine
|
|
|
|
*
|
|
|
|
* Authors: listed in file AUTHORS in main folder
|
|
|
|
*
|
|
|
|
* License: GNU General Public License v2.0 or later
|
|
|
|
* Full text of license available in license.txt file, in main folder
|
|
|
|
*
|
|
|
|
*/
|
|
|
|
|
|
|
|
#pragma once
|
|
|
|
|
|
|
|
struct SDL_Texture;
|
|
|
|
struct SDL_Window;
|
|
|
|
struct SDL_Renderer;
|
|
|
|
struct SDL_Surface;
|
|
|
|
|
|
|
|
#include "../../lib/Point.h"
|
2023-04-30 17:47:52 +02:00
|
|
|
#include "../render/IWindowHandler.h"
|
2023-04-30 00:03:50 +02:00
|
|
|
|
|
|
|
enum class EWindowMode
|
|
|
|
{
|
|
|
|
// game runs in a window that covers part of the screen
|
|
|
|
WINDOWED,
|
|
|
|
// game runs in a 'window' that always covers entire screen and uses unmodified desktop resolution
|
|
|
|
// The only mode that is available on mobile devices
|
|
|
|
FULLSCREEN_WINDOWED,
|
|
|
|
// game runs in a fullscreen mode with resolution selected by player
|
|
|
|
FULLSCREEN_TRUE
|
|
|
|
};
|
|
|
|
|
|
|
|
/// This class is responsible for management of game window and its main rendering surface
|
2023-04-30 17:47:52 +02:00
|
|
|
class WindowHandler : public IWindowHandler
|
2023-04-30 00:03:50 +02:00
|
|
|
{
|
|
|
|
/// Dimensions of target surfaces/textures, this value is what game logic views as screen size
|
|
|
|
Point getPreferredLogicalResolution() const;
|
|
|
|
|
|
|
|
/// Dimensions of output window, if different from logicalResolution SDL will perform scaling
|
|
|
|
/// This value is what player views as window size
|
|
|
|
Point getPreferredRenderingResolution() const;
|
|
|
|
|
|
|
|
EWindowMode getPreferredWindowMode() const;
|
|
|
|
|
|
|
|
/// Returns index of display on which window should be created
|
|
|
|
int getPreferredDisplayIndex() const;
|
|
|
|
|
|
|
|
/// Returns index of rendering driver preferred by player or -1 if no preference
|
|
|
|
int getPreferredRenderingDriver() const;
|
|
|
|
|
|
|
|
/// Creates SDL window with specified parameters
|
2023-04-30 00:38:28 +02:00
|
|
|
SDL_Window * createWindowImpl(Point dimensions, int flags, bool center);
|
2023-04-30 00:03:50 +02:00
|
|
|
|
|
|
|
/// Creates SDL window using OS-specific settings & user-specific config
|
|
|
|
SDL_Window * createWindow();
|
|
|
|
|
|
|
|
void initializeRenderer();
|
|
|
|
void initializeScreen();
|
|
|
|
void updateFullscreenState();
|
|
|
|
|
|
|
|
bool recreateWindow();
|
|
|
|
void destroyScreen();
|
|
|
|
void destroyWindow();
|
|
|
|
|
|
|
|
void validateSettings();
|
|
|
|
public:
|
|
|
|
|
|
|
|
/// Creates and initializes screen, window and SDL state
|
|
|
|
WindowHandler();
|
|
|
|
|
|
|
|
/// Updates and potentially recreates target screen to match selected fullscreen status
|
2023-05-04 21:33:25 +02:00
|
|
|
void onScreenResize() final;
|
2023-04-30 00:03:50 +02:00
|
|
|
|
|
|
|
/// De-initializes and destroys screen, window and SDL state
|
2023-04-30 17:47:52 +02:00
|
|
|
void close() final;
|
2023-04-30 00:38:28 +02:00
|
|
|
|
|
|
|
/// Fills screen with black color, erasing any existing content
|
2023-04-30 17:47:52 +02:00
|
|
|
void clearScreen() final;
|
|
|
|
|
|
|
|
std::vector<Point> getSupportedResolutions() const final;
|
|
|
|
std::vector<Point> getSupportedResolutions(int displayIndex) const;
|
2023-05-04 22:50:33 +02:00
|
|
|
std::tuple<double, double> getSupportedScalingRange() const final;
|
2023-04-30 00:03:50 +02:00
|
|
|
};
|