wayland::presentation_feedback_t(3) | Wayland++ | wayland::presentation_feedback_t(3) |
wayland::presentation_feedback_t - presentation time feedback event
#include <wayland-client-protocol-extra.hpp>
Inherits wayland::proxy_t.
enum class wrapper_type { standard, display,
foreign, proxy_wrapper }
std::function< void(output_t)> &
on_sync_output ()
presentation synchronized to this output std::function< void(uint32_t,
uint32_t, uint32_t, uint32_t, uint32_t, uint32_t,
presentation_feedback_kind)> & on_presented ()
the content update was displayed std::function< void()> &
on_discarded ()
the content update was not displayed uint32_t get_id () const
Get the id of a proxy object. std::string get_class () const
Get the interface name (class) of a proxy object. uint32_t get_version
() const
Get the protocol object version of a proxy object. wrapper_type
get_wrapper_type () const
Get the type of a proxy object. void set_queue (event_queue_t
queue)
Assign a proxy to an event queue. wl_proxy * c_ptr () const
Get a pointer to the underlying C struct. bool proxy_has_object ()
const
Check whether this wrapper actually wraps an object. operator bool ()
const
Check whether this wrapper actually wraps an object. bool operator==
(const proxy_t &right) const
Check whether two wrappers refer to the same object. bool operator!=
(const proxy_t &right) const
Check whether two wrappers refer to different objects. void
proxy_release ()
Release the wrapped object (if any), making this an empty wrapper.
presentation time feedback event
A presentation_feedback object returns an indication that a wl_surface content update has become visible to the user. One object corresponds to one content update submission (wl_surface.commit). There are two possible outcomes: the content update is presented to the user, and a presentation timestamp delivered; or, the user did not see the content update because it was superseded or its surface destroyed, and the content update is discarded.
Once a presentation_feedback object has delivered a 'presented' or 'discarded' event it is automatically destroyed.
Definition at line 187 of file wayland-client-protocol-extra.hpp.
Underlying wl_proxy type and properties of a proxy_t that affect construction, destruction, and event handling
Enumerator
Definition at line 116 of file wayland-client.hpp.
Get a pointer to the underlying C struct.
Returns
Get the interface name (class) of a proxy object.
Returns
Get the id of a proxy object.
Returns
Get the protocol object version of a proxy object. Gets the protocol object version of a proxy object, or 0 if the proxy was created with unversioned API.
A returned value of 0 means that no version information is available, so the caller must make safe assumptions about the object's real version.
display_t will always return version 0.
Returns
Get the type of a proxy object.
Definition at line 302 of file wayland-client.hpp.
the content update was not displayed The content update was never displayed to the user.
Definition at line 804 of file wayland-client-protocol-extra.cpp.
the content update was displayed
Parameters
The associated content update was displayed to the user at the indicated time (tv_sec_hi/lo, tv_nsec). For the interpretation of the timestamp, see presentation.clock_id event.
The timestamp corresponds to the time when the content update turned into light the first time on the surface's main output. Compositors may approximate this from the framebuffer flip completion events from the system, and the latency of the physical display path if known.
This event is preceded by all related sync_output events telling which output's refresh cycle the feedback corresponds to, i.e. the main output for the surface. Compositors are recommended to choose the output containing the largest part of the wl_surface, or keeping the output they previously chose. Having a stable presentation output association helps clients predict future output refreshes (vblank).
The 'refresh' argument gives the compositor's prediction of how many nanoseconds after tv_sec, tv_nsec the very next output refresh may occur. This is to further aid clients in predicting future refreshes, i.e., estimating the timestamps targeting the next few vblanks. If such prediction cannot usefully be done, the argument is zero.
If the output does not have a constant refresh rate, explicit video mode switches excluded, then the refresh argument must be zero.
The 64-bit value combined from seq_hi and seq_lo is the value of the output's vertical retrace counter when the content update was first scanned out to the display. This value must be compatible with the definition of MSC in GLX_OML_sync_control specification. Note, that if the display path has a non-zero latency, the time instant specified by this counter may differ from the timestamp's.
If the output does not have a concept of vertical retrace or a refresh cycle, or the output device is self-refreshing without a way to query the refresh count, then the arguments seq_hi and seq_lo must be zero.
Definition at line 799 of file wayland-client-protocol-extra.cpp.
presentation synchronized to this output
Parameters
As presentation can be synchronized to only one output at a time, this event tells which output it was. This event is only sent prior to the presented event.
As clients may bind to the same global wl_output multiple times, this event is sent for each bound instance that matches the synchronized output. If a client has not bound to the right wl_output global at all, this event is not sent.
Definition at line 794 of file wayland-client-protocol-extra.cpp.
Check whether this wrapper actually wraps an object.
Returns
Check whether two wrappers refer to different objects.
Check whether two wrappers refer to the same object.
Check whether this wrapper actually wraps an object.
Returns
Release the wrapped object (if any), making this an empty wrapper. Note that display_t instances cannot be released this way. Attempts to do so are ignored.
Examples
foreign_display.cpp.
Assign a proxy to an event queue.
Parameters
Assign proxy to event queue. Events coming from proxy will be queued in queue instead of the display's main queue.
See also: display_t::dispatch_queue().
Examples
proxy_wrapper.cpp.
Generated automatically by Doxygen for Wayland++ from the source code.
Tue Oct 29 2024 13:36:49 | Version 1.0.0 |