OpenTTD Source 20241224-master-gee860a5c8e
VideoDriver_SDL Class Reference

The SDL video driver. More...

#include <sdl_v.h>

Inheritance diagram for VideoDriver_SDL:
VideoDriver Driver

Public Member Functions

std::optional< std::string_view > Start (const StringList &param) override
 Start this driver.
 
void Stop () override
 Stop this driver.
 
void MakeDirty (int left, int top, int width, int height) override
 Mark a particular area dirty.
 
void MainLoop () override
 Perform the actual drawing.
 
bool ChangeResolution (int w, int h) override
 Change the resolution of the window.
 
bool ToggleFullscreen (bool fullscreen) override
 Change the full screen setting.
 
bool AfterBlitterChange () override
 Callback invoked after the blitter was changed.
 
bool ClaimMousePointer () override
 
std::string_view GetName () const override
 Get the name of this driver.
 
- Public Member Functions inherited from VideoDriver
 VideoDriver (bool uses_hardware_acceleration=false)
 
virtual void ToggleVsync (bool vsync)
 Change the vsync setting.
 
virtual bool UseSystemCursor ()
 Get whether the mouse cursor is drawn by the video driver.
 
virtual void PopulateSystemSprites ()
 Populate all sprites in cache.
 
virtual void ClearSystemSprites ()
 Clear all cached sprites.
 
virtual bool HasGUI () const
 Whether the driver has a graphical user interface with the end user.
 
virtual bool HasEfficient8Bpp () const
 Has this video driver an efficient code path for palette animated 8-bpp sprites?
 
virtual bool HasAnimBuffer ()
 Does this video driver support a separate animation buffer in addition to the colour buffer?
 
virtual uint8_t * GetAnimBuffer ()
 Get a pointer to the animation buffer of the video back-end.
 
virtual void EditBoxLostFocus ()
 An edit box lost the input focus.
 
virtual void EditBoxGainedFocus ()
 An edit box gained the input focus.
 
virtual std::vector< int > GetListOfMonitorRefreshRates ()
 Get a list of refresh rates of each available monitor.
 
virtual int GetSuggestedUIScale ()
 Get a suggested default GUI scale taking screen DPI into account.
 
virtual std::string_view GetInfoString () const
 
void QueueOnMainThread (std::function< void()> &&func)
 Queue a function to be called on the main thread with game state lock held and video buffer locked.
 
void GameLoopPause ()
 Pause the game-loop for a bit, releasing the game-state lock.
 

Protected Member Functions

void InputLoop () override
 Handle input logic, is CTRL pressed, should we fast-forward, etc.
 
void Paint () override
 Paint the window.
 
void CheckPaletteAnim () override
 Process any pending palette animation.
 
bool PollEvent () override
 Process a single system event.
 
- Protected Member Functions inherited from VideoDriver
virtual Dimension GetScreenSize () const
 Get the resolution of the main screen.
 
virtual float GetDPIScale ()
 Get DPI scaling factor of the screen OTTD is displayed on.
 
void UpdateAutoResolution ()
 Apply resolution auto-detection and clamp to sensible defaults.
 
virtual bool LockVideoBuffer ()
 Make sure the video buffer is ready for drawing.
 
virtual void UnlockVideoBuffer ()
 Unlock a previously locked video buffer.
 
void StartGameThread ()
 Start the loop for game-tick.
 
void StopGameThread ()
 Stop the loop for the game-tick.
 
void Tick ()
 Give the video-driver a tick.
 
void SleepTillNextTick ()
 Sleep till the next tick is about to happen.
 
std::chrono::steady_clock::duration GetGameInterval ()
 
std::chrono::steady_clock::duration GetDrawInterval ()
 
void DrainCommandQueue ()
 Execute all queued commands.
 

Private Member Functions

bool CreateMainSurface (uint w, uint h)
 
void SetupKeyboard ()
 

Additional Inherited Members

- Public Types inherited from Driver
enum  Type {
  DT_BEGIN = 0 , DT_MUSIC = 0 , DT_SOUND , DT_VIDEO ,
  DT_END
}
 The type of driver. More...
 
- Static Public Member Functions inherited from VideoDriver
static VideoDriverGetInstance ()
 Get the currently active instance of the video driver.
 
static std::string GetCaption ()
 Get the caption to use for the game's title bar.
 
- Static Protected Member Functions inherited from VideoDriver
static void GameThreadThunk (VideoDriver *drv)
 
- Protected Attributes inherited from VideoDriver
const uint ALLOWED_DRIFT = 5
 How many times videodriver can miss deadlines without it being overly compensated.
 
std::chrono::steady_clock::time_point next_game_tick
 
std::chrono::steady_clock::time_point next_draw_tick
 
bool fast_forward_key_pressed
 The fast-forward key is being pressed.
 
bool fast_forward_via_key
 The fast-forward was enabled by key press.
 
bool is_game_threaded
 
std::thread game_thread
 
std::mutex game_state_mutex
 
std::mutex game_thread_wait_mutex
 
bool uses_hardware_acceleration
 

Detailed Description

The SDL video driver.

Definition at line 16 of file sdl_v.h.

Member Function Documentation

◆ AfterBlitterChange()

bool VideoDriver_SDL::AfterBlitterChange ( )
overridevirtual

Callback invoked after the blitter was changed.

Returns
True if no error.

Reimplemented from VideoDriver.

Definition at line 692 of file sdl_v.cpp.

◆ ChangeResolution()

bool VideoDriver_SDL::ChangeResolution ( int  w,
int  h 
)
overridevirtual

Change the resolution of the window.

Parameters
wThe new width.
hThe new height.
Returns
True if the change succeeded.

Implements VideoDriver.

Definition at line 672 of file sdl_v.cpp.

◆ CheckPaletteAnim()

void VideoDriver_SDL::CheckPaletteAnim ( )
overrideprotectedvirtual

◆ ClaimMousePointer()

bool VideoDriver_SDL::ClaimMousePointer ( )
overridevirtual

Reimplemented from VideoDriver.

Definition at line 369 of file sdl_v.cpp.

◆ CreateMainSurface()

bool VideoDriver_SDL::CreateMainSurface ( uint  w,
uint  h 
)
private

Definition at line 225 of file sdl_v.cpp.

◆ GetName()

std::string_view VideoDriver_SDL::GetName ( ) const
inlineoverridevirtual

Get the name of this driver.

Returns
The name of the driver.

Implements Driver.

Definition at line 34 of file sdl_v.h.

◆ InputLoop()

void VideoDriver_SDL::InputLoop ( )
overrideprotectedvirtual

Handle input logic, is CTRL pressed, should we fast-forward, etc.

Reimplemented from VideoDriver.

Definition at line 633 of file sdl_v.cpp.

References _ctrl_pressed, _dirkeys, _shift_pressed, VideoDriver::fast_forward_key_pressed, and HandleCtrlChanged().

◆ MainLoop()

void VideoDriver_SDL::MainLoop ( )
overridevirtual

Perform the actual drawing.

Implements VideoDriver.

Definition at line 658 of file sdl_v.cpp.

References VideoDriver::SleepTillNextTick(), VideoDriver::StartGameThread(), VideoDriver::StopGameThread(), and VideoDriver::Tick().

◆ MakeDirty()

void VideoDriver_SDL::MakeDirty ( int  left,
int  top,
int  width,
int  height 
)
overridevirtual

Mark a particular area dirty.

Parameters
leftThe left most line of the dirty area.
topThe top most line of the dirty area.
widthThe width of the dirty area.
heightThe height of the dirty area.

Implements VideoDriver.

Definition at line 43 of file sdl_v.cpp.

◆ Paint()

void VideoDriver_SDL::Paint ( )
overrideprotectedvirtual

Paint the window.

Reimplemented from VideoDriver.

Definition at line 136 of file sdl_v.cpp.

References PFE_VIDEO.

◆ PollEvent()

bool VideoDriver_SDL::PollEvent ( )
overrideprotectedvirtual

Process a single system event.

Returns
False if there are no more events to process.

Reimplemented from VideoDriver.

Definition at line 477 of file sdl_v.cpp.

References _left_button_clicked, _left_button_down, _right_button_clicked, _right_button_down, _rightclick_emulate, CursorVars::fix_at, HandleKeypress(), HandleMouseEvents(), CursorVars::in_window, CursorVars::pos, CursorVars::UpdateCursorPosition(), and CursorVars::wheel.

◆ SetupKeyboard()

void VideoDriver_SDL::SetupKeyboard ( )
private

Definition at line 619 of file sdl_v.cpp.

◆ Start()

std::optional< std::string_view > VideoDriver_SDL::Start ( const StringList parm)
overridevirtual

Start this driver.

Parameters
parmParameters passed to the driver.
Returns
std::nullopt if everything went okay, otherwise an error message.

Implements Driver.

Definition at line 585 of file sdl_v.cpp.

References _cur_resolution, Debug, GetDriverParamBool(), GetDriverParamInt(), MarkWholeScreenDirty(), and VideoDriver::UpdateAutoResolution().

◆ Stop()

void VideoDriver_SDL::Stop ( )
overridevirtual

Stop this driver.

Implements Driver.

Definition at line 625 of file sdl_v.cpp.

◆ ToggleFullscreen()

bool VideoDriver_SDL::ToggleFullscreen ( bool  fullscreen)
overridevirtual

Change the full screen setting.

Parameters
fullscreenThe new setting.
Returns
True if the change succeeded.

Implements VideoDriver.

Definition at line 677 of file sdl_v.cpp.

References _cur_resolution, _resolutions, InvalidateWindowClassesData(), and WC_GAME_OPTIONS.


The documentation for this class was generated from the following files: