A global draw management interface. More...
Functions | |
static void | update () |
static void | layout () |
static void | render () |
static bool | expose () |
static void | wait_for_vsync () |
static void | tidy_drawables () |
void | invalidate_region (const rect ®ion) |
Mark a region of the screen as requiring redraw. More... | |
void | invalidate_all () |
Mark the entire screen as requiring redraw. More... | |
void | request_extra_render_pass () |
Request an extra render pass. More... | |
void | sparkle () |
Ensure that everything which needs to be drawn is drawn. More... | |
std::chrono::milliseconds | get_frame_length () |
Returns the length of one display frame, in milliseconds. More... | |
void | register_drawable (gui2::top_level_drawable *tld) |
Register a top-level drawable. More... | |
void | deregister_drawable (gui2::top_level_drawable *tld) |
Remove a top-level drawable from the drawing stack. More... | |
void | raise_drawable (gui2::top_level_drawable *tld) |
Raise a TLD to the top of the drawing stack. More... | |
A global draw management interface.
This interface governs drawing things to the screen in the correct order. Drawable objects must inherit from gui2::top_level_drawable, and may be referred to as "TLD"s.
There is an absolute requirement that events happen in a certain order. This is mostly managed by this interface, which calls the TLD methods in order at most once every vsync.
The order of events is:
The draw manager will call layout(), render() and expose() in the correct order to ensure all TLD objects are laid out correctly and drawn in the correct order.
Drawing order of TLDs is initially set by creation time, but a TLD may be raised to the top of the drawing stack by calling draw_manager::raise_drawable() manually. register_drawable() and deregister_drawable() are called automatically by gui2::top_level_drawable in its constructor and destructor, and do not need to be manually managed.
The drawing process happens inside draw_manager::sparkle(). In general, a game loop should perform two basic steps.
The main sparkle() function will also rate-limit, so callers do not need to add their own delay to their loops. If vsync is disabled, drawing will happen as frequently as possible. If vsync is enabled, this function will wait for the next screen refresh before drawing. In both cases, if nothing needs to be drawn the function will block for an appropriate length of time before returning.
To ensure they are presented for drawing, any drawable object must call draw_manager::invalidate_region() to indicate that an area of the screen needs to be redrawn. This may be called during any phase other than the draw phase. Invalidating regions during the draw phase is an error and will throw an exception.
void draw_manager::deregister_drawable | ( | top_level_drawable * | tld | ) |
Remove a top-level drawable from the drawing stack.
Definition at line 291 of file draw_manager.cpp.
References DBG_DM, utils::find(), and WRN_DM.
Referenced by gui2::top_level_drawable::~top_level_drawable().
|
static |
Definition at line 225 of file draw_manager.cpp.
References rect::area(), DBG_DM, utils::get_unknown_exception_type(), i, rect::intersect(), rect::minimal_cover(), draw::override_clip(), and WRN_DM.
Referenced by sparkle().
std::chrono::milliseconds draw_manager::get_frame_length | ( | ) |
Returns the length of one display frame, in milliseconds.
This will usually be determined by the active monitor's refresh rate.
Definition at line 179 of file draw_manager.cpp.
References video::current_refresh_rate().
Referenced by gui2::dialogs::loading_screen::spin(), gui2::dialogs::file_progress::update_progress(), and wait_for_vsync().
void draw_manager::invalidate_all | ( | ) |
Mark the entire screen as requiring redraw.
Definition at line 119 of file draw_manager.cpp.
References video::game_canvas(), and invalidate_region().
Referenced by play_controller::check_victory(), events::pump(), display::queue_repaint(), display::queue_rerender(), and video::update_buffers().
void draw_manager::invalidate_region | ( | const rect & | region | ) |
Mark a region of the screen as requiring redraw.
This should be called any time an item changes in such a way as to require redrawing.
This may only be called outside the Draw phase.
Regions are combined to result in a minimal number of draw calls, so this may be called for every invalidation without much concern.
Definition at line 61 of file draw_manager.cpp.
References rect::area(), rect::contains(), DBG_DM, ERR_DM, rect::expand_to_cover(), and rect::minimal_cover().
Referenced by display::draw(), display::draw_invalidated(), display::fade_to(), display::fade_tod_mask(), invalidate_all(), halo::halo_impl::effect::queue_redraw(), gui::widget::queue_redraw(), gui2::widget::queue_redraw(), halo::halo_impl::effect::queue_undraw(), display::redraw_minimap(), display::refresh_report(), display::scroll(), font::floating_label::undraw(), and font::floating_label::update().
|
static |
Definition at line 209 of file draw_manager.cpp.
References i, and gui2::top_level_drawable::layout().
Referenced by font::pango_text::calculate_size(), font::pango_text::get_lines(), font::pango_text::render(), font::pango_text::set_markup(), and sparkle().
void draw_manager::raise_drawable | ( | top_level_drawable * | tld | ) |
Raise a TLD to the top of the drawing stack.
Definition at line 308 of file draw_manager.cpp.
References DBG_DM, ERR_DM, and utils::find().
Referenced by gui2::dialogs::loading_screen::raise(), tooltips::raise_to_top(), and register_drawable().
void draw_manager::register_drawable | ( | gui2::top_level_drawable * | tld | ) |
Register a top-level drawable.
Registered drawables will be drawn in the order of registration, so the most recently-registered drawable will be "on top".
Definition at line 280 of file draw_manager.cpp.
References DBG_DM, utils::find(), and raise_drawable().
Referenced by gui2::top_level_drawable::operator=(), and gui2::top_level_drawable::top_level_drawable().
|
static |
Definition at line 217 of file draw_manager.cpp.
References i, and gui2::top_level_drawable::render().
Referenced by sparkle().
void draw_manager::request_extra_render_pass | ( | ) |
Request an extra render pass.
This is used for blur effects, which need to first render what's underneath so that it can be blurred.
There is not currently any limit to the number of extra render passes, but do try to keep it finite.
Definition at line 125 of file draw_manager.cpp.
Referenced by gui2::canvas::update_blur().
void draw_manager::sparkle | ( | ) |
Ensure that everything which needs to be drawn is drawn.
This includes making sure window sizes and locations are up to date, updating animation frames, and drawing whatever regions of the screen need drawing or redrawing.
If vsync is enabled, this function will block until the next vblank. If nothing is drawn, it will still block for an appropriate amount of time to simulate vsync, even if vsync is disabled.
Definition at line 130 of file draw_manager.cpp.
References ERR_DM, expose(), video::headless(), layout(), render(), video::render_screen(), video::testing(), tidy_drawables(), update(), and wait_for_vsync().
Referenced by events::draw().
|
static |
Definition at line 328 of file draw_manager.cpp.
References DBG_DM, and utils::erase().
Referenced by sparkle().
|
static |
Definition at line 201 of file draw_manager.cpp.
References i, and gui2::top_level_drawable::update().
Referenced by editor::editor_controller::mouse_motion(), events::mouse_handler::mouse_motion(), unit_display::unit_mover::proceed_to(), sparkle(), events::mouse_handler::touch_motion(), and t_string_base::walker::update().
|
static |
Definition at line 191 of file draw_manager.cpp.
References get_frame_length(), and s.
Referenced by sparkle().