gtkmm 4.16.0
|
Gdk::DmabufTextureBuilder is a builder used to construct Gdk::Texture objects from DMA buffers. More...
#include <gdkmm/dmabuftexturebuilder.h>
Public Types | |
using | SlotDmabufTextureReleased = sigc::slot< void()> |
For instance, void on_dmabuf_texture_released();. | |
Public Member Functions | |
DmabufTextureBuilder (DmabufTextureBuilder && src) noexcept | |
DmabufTextureBuilder & | operator= (DmabufTextureBuilder && src) noexcept |
~DmabufTextureBuilder () noexcept override | |
GdkDmabufTextureBuilder * | gobj () |
Provides access to the underlying C GObject. | |
const GdkDmabufTextureBuilder * | gobj () const |
Provides access to the underlying C GObject. | |
GdkDmabufTextureBuilder * | gobj_copy () |
Provides access to the underlying C instance. The caller is responsible for unrefing it. Use when directly setting fields in structs. | |
Glib::RefPtr< Display > | get_display () |
Returns the display that this texture builder is associated with. | |
Glib::RefPtr< const Display > | get_display () const |
Returns the display that this texture builder is associated with. | |
void | set_display (const Glib::RefPtr< Display > & display) |
Sets the display that this texture builder is associated with. | |
unsigned int | get_width () const |
Gets the width previously set via set_width() or 0 if the width wasn't set. | |
void | set_width (unsigned int width) |
Sets the width of the texture. | |
unsigned int | get_height () const |
Gets the height previously set via set_height() or 0 if the height wasn't set. | |
void | set_height (unsigned int height) |
Sets the height of the texture. | |
guint32 | get_fourcc () const |
Gets the format previously set via set_fourcc() or 0 if the format wasn't set. | |
void | set_fourcc (guint32 fourcc) |
Sets the format of the texture. | |
guint64 | get_modifier () const |
Gets the modifier value. | |
void | set_modifier (guint64 modifier) |
Sets the modifier. | |
bool | get_premultiplied () const |
Whether the data is premultiplied. | |
void | set_premultiplied (bool premultiplied=true) |
Sets whether the data is premultiplied. | |
unsigned int | get_n_planes () const |
Gets the number of planes. | |
void | set_n_planes (unsigned int n_planes) |
Sets the number of planes of the texture. | |
int | get_fd (unsigned int plane) const |
Gets the file descriptor for a plane. | |
void | set_fd (unsigned int plane, int fd) |
Sets the file descriptor for a plane. | |
unsigned int | get_stride (unsigned int plane) const |
Gets the stride value for a plane. | |
void | set_stride (unsigned int plane, unsigned int stride) |
Sets the stride for a plane. | |
unsigned int | get_offset (unsigned int plane) const |
Gets the offset value for a plane. | |
void | set_offset (unsigned int plane, unsigned int offset) |
Sets the offset for a plane. | |
Glib::RefPtr< ColorState > | get_color_state () const |
Gets the color state previously set via set_color_state(). | |
void | set_color_state (const Glib::RefPtr< const ColorState > & color_state) |
Sets the color state for the texture. | |
Glib::RefPtr< Texture > | get_update_texture () |
Gets the texture previously set via set_update_texture() or nullptr if none was set. | |
Glib::RefPtr< const Texture > | get_update_texture () const |
Gets the texture previously set via set_update_texture() or nullptr if none was set. | |
void | set_update_texture (const Glib::RefPtr< Texture > & texture) |
Sets the texture to be updated by this texture. | |
::Cairo::RefPtr< ::Cairo::Region > | get_update_region () |
Gets the region previously set via set_update_region() or nullptr if none was set. | |
::Cairo::RefPtr< const ::Cairo::Region > | get_update_region () const |
Gets the region previously set via set_update_region() or nullptr if none was set. | |
void | set_update_region (const ::Cairo::RefPtr< ::Cairo::Region > & region) |
Sets the region to be updated by this texture. | |
Glib::RefPtr< Texture > | build (const SlotDmabufTextureReleased & slot={}) |
Builds a new Gdk::Texture with the values set up in the builder. | |
Glib::PropertyProxy< Glib::RefPtr< Display > > | property_display () |
The display that this texture will be used on. | |
Glib::PropertyProxy_ReadOnly< Glib::RefPtr< Display > > | property_display () const |
The display that this texture will be used on. | |
Glib::PropertyProxy< unsigned int > | property_width () |
The width of the texture. | |
Glib::PropertyProxy_ReadOnly< unsigned int > | property_width () const |
The width of the texture. | |
Glib::PropertyProxy< unsigned int > | property_height () |
The height of the texture. | |
Glib::PropertyProxy_ReadOnly< unsigned int > | property_height () const |
The height of the texture. | |
Glib::PropertyProxy< unsigned int > | property_fourcc () |
The format of the texture, as a fourcc value. | |
Glib::PropertyProxy_ReadOnly< unsigned int > | property_fourcc () const |
The format of the texture, as a fourcc value. | |
Glib::PropertyProxy< guint64 > | property_modifier () |
The modifier. | |
Glib::PropertyProxy_ReadOnly< guint64 > | property_modifier () const |
The modifier. | |
Glib::PropertyProxy< bool > | property_premultiplied () |
Whether the alpha channel is premultiplied into the others. | |
Glib::PropertyProxy_ReadOnly< bool > | property_premultiplied () const |
Whether the alpha channel is premultiplied into the others. | |
Glib::PropertyProxy< unsigned int > | property_n_planes () |
The number of planes of the texture. | |
Glib::PropertyProxy_ReadOnly< unsigned int > | property_n_planes () const |
The number of planes of the texture. | |
Glib::PropertyProxy< Glib::RefPtr< ColorState > > | property_color_state () |
The color state of the texture. | |
Glib::PropertyProxy_ReadOnly< Glib::RefPtr< ColorState > > | property_color_state () const |
The color state of the texture. | |
Glib::PropertyProxy< ::Cairo::RefPtr< ::Cairo::Region > > | property_update_region () |
The update region for Gdk::GLTextureBuilder::property_update_texture(). | |
Glib::PropertyProxy_ReadOnly< ::Cairo::RefPtr< ::Cairo::Region > > | property_update_region () const |
The update region for Gdk::GLTextureBuilder::property_update_texture(). | |
Glib::PropertyProxy< Glib::RefPtr< Texture > > | property_update_texture () |
The texture property_update_region() is an update for. | |
Glib::PropertyProxy_ReadOnly< Glib::RefPtr< Texture > > | property_update_texture () const |
The texture property_update_region() is an update for. | |
Static Public Member Functions | |
static GType | get_type () |
Get the GType for this class, for use with the underlying GObject type system. | |
static Glib::RefPtr< DmabufTextureBuilder > | create () |
Protected Member Functions | |
DmabufTextureBuilder () | |
Related Symbols | |
(Note that these are not member symbols.) | |
Glib::RefPtr< Gdk::DmabufTextureBuilder > | wrap (GdkDmabufTextureBuilder * object, bool take_copy=false) |
A Glib::wrap() method for this object. | |
Gdk::DmabufTextureBuilder is a builder used to construct Gdk::Texture objects from DMA buffers.
DMA buffers are commonly called dma-bufs.
DMA buffers is a feature of the Linux kernel to enable efficient buffer and memory sharing between hardware such as codecs, GPUs, displays, cameras and the kernel drivers controlling them. For example, a decoder may want its output to be directly shared with the display server for rendering without a copy.
Any device driver which participates in DMA buffer sharing, can do so as either the exporter or importer of buffers (or both).
The memory that is shared via DMA buffers is usually stored in non-system memory (maybe in device's local memory or something else not directly accessible by the CPU), and accessing this memory from the CPU may have higher than usual overhead.
In particular for graphics data, it is not uncommon that data consists of multiple separate blocks of memory, for example one block for each of the red, green and blue channels. These blocks are called planes. DMA buffers can have up to four planes. Even if the memory is a single block, the data can be organized in multiple planes, by specifying offsets from the beginning of the data.
DMA buffers are exposed to user-space as file descriptors allowing to pass them between processes. If a DMA buffer has multiple planes, there is one file descriptor per plane.
The format of the data (for graphics data, essentially its colorspace) is described by a 32-bit integer. These format identifiers are defined in the header file drm/drm_fourcc.h and commonly referred to as fourcc values, since they are identified by 4 ASCII characters. Additionally, each DMA buffer has a modifier, which is a 64-bit integer that describes driver-specific details of the memory layout, such as tiling or compression.
The operation of Gdk::DmabufTextureBuilder is quite simple: Create a texture builder, set all the necessary properties, and then call build() to create the new texture.
The required properties for a dma-buf texture are
fourcc
code and modifier
which identify the format and memory layout of the dma-bufGdk::DmabufTextureBuilder can be used for quick one-shot construction of textures as well as kept around and reused to construct multiple textures.
using Gdk::DmabufTextureBuilder::SlotDmabufTextureReleased = sigc::slot<void()> |
For instance, void on_dmabuf_texture_released();.
|
noexcept |
|
overridenoexcept |
|
protected |
Glib::RefPtr< Texture > Gdk::DmabufTextureBuilder::build | ( | const SlotDmabufTextureReleased & | slot = {} | ) |
Builds a new Gdk::Texture
with the values set up in the builder.
It is a programming error to call this function if any mandatory property has not been set.
If the dmabuf is not supported by GTK, an exception will be thrown.
The slot gets called when the returned texture gets released.
It is possible to call this function multiple times to create multiple textures, possibly with changing properties in between.
It is the responsibility of the caller to keep the file descriptors for the planes open until the created texture is no longer used, and close them afterwards (possibly using the slot notify).
Not all formats defined in the drm_fourcc.h
header are supported. You can use Gdk::Display::get_dmabuf_formats() to get a list of supported formats.
slot | Destroy function to be called when the texture is released. |
Gdk::Texture
or an empty RefPtr if the format is not supported, or any mandatory property has not been set.Glib::Error |
|
static |
Glib::RefPtr< ColorState > Gdk::DmabufTextureBuilder::get_color_state | ( | ) | const |
Gets the color state previously set via set_color_state().
Glib::RefPtr< Display > Gdk::DmabufTextureBuilder::get_display | ( | ) |
Returns the display that this texture builder is associated with.
Glib::RefPtr< const Display > Gdk::DmabufTextureBuilder::get_display | ( | ) | const |
Returns the display that this texture builder is associated with.
int Gdk::DmabufTextureBuilder::get_fd | ( | unsigned int | plane | ) | const |
Gets the file descriptor for a plane.
plane | The plane to get the fd for. |
guint32 Gdk::DmabufTextureBuilder::get_fourcc | ( | ) | const |
Gets the format previously set via set_fourcc() or 0 if the format wasn't set.
The format is specified as a fourcc code.
unsigned int Gdk::DmabufTextureBuilder::get_height | ( | ) | const |
Gets the height previously set via set_height() or 0 if the height wasn't set.
guint64 Gdk::DmabufTextureBuilder::get_modifier | ( | ) | const |
unsigned int Gdk::DmabufTextureBuilder::get_n_planes | ( | ) | const |
unsigned int Gdk::DmabufTextureBuilder::get_offset | ( | unsigned int | plane | ) | const |
Gets the offset value for a plane.
plane | The plane to get the offset for. |
bool Gdk::DmabufTextureBuilder::get_premultiplied | ( | ) | const |
unsigned int Gdk::DmabufTextureBuilder::get_stride | ( | unsigned int | plane | ) | const |
Gets the stride value for a plane.
plane | The plane to get the stride for. |
|
static |
Get the GType for this class, for use with the underlying GObject type system.
::Cairo::RefPtr< ::Cairo::Region > Gdk::DmabufTextureBuilder::get_update_region | ( | ) |
Gets the region previously set via set_update_region() or nullptr
if none was set.
::Cairo::RefPtr< const ::Cairo::Region > Gdk::DmabufTextureBuilder::get_update_region | ( | ) | const |
Gets the region previously set via set_update_region() or nullptr
if none was set.
Glib::RefPtr< Texture > Gdk::DmabufTextureBuilder::get_update_texture | ( | ) |
Gets the texture previously set via set_update_texture() or nullptr
if none was set.
Glib::RefPtr< const Texture > Gdk::DmabufTextureBuilder::get_update_texture | ( | ) | const |
Gets the texture previously set via set_update_texture() or nullptr
if none was set.
unsigned int Gdk::DmabufTextureBuilder::get_width | ( | ) | const |
Gets the width previously set via set_width() or 0 if the width wasn't set.
|
inline |
Provides access to the underlying C GObject.
|
inline |
Provides access to the underlying C GObject.
GdkDmabufTextureBuilder * Gdk::DmabufTextureBuilder::gobj_copy | ( | ) |
Provides access to the underlying C instance. The caller is responsible for unrefing it. Use when directly setting fields in structs.
|
noexcept |
Glib::PropertyProxy< Glib::RefPtr< ColorState > > Gdk::DmabufTextureBuilder::property_color_state | ( | ) |
The color state of the texture.
Glib::PropertyProxy_ReadOnly< Glib::RefPtr< ColorState > > Gdk::DmabufTextureBuilder::property_color_state | ( | ) | const |
The color state of the texture.
Glib::PropertyProxy< Glib::RefPtr< Display > > Gdk::DmabufTextureBuilder::property_display | ( | ) |
The display that this texture will be used on.
Glib::PropertyProxy_ReadOnly< Glib::RefPtr< Display > > Gdk::DmabufTextureBuilder::property_display | ( | ) | const |
The display that this texture will be used on.
Glib::PropertyProxy< unsigned int > Gdk::DmabufTextureBuilder::property_fourcc | ( | ) |
The format of the texture, as a fourcc value.
Default value: 0
Glib::PropertyProxy_ReadOnly< unsigned int > Gdk::DmabufTextureBuilder::property_fourcc | ( | ) | const |
The format of the texture, as a fourcc value.
Default value: 0
Glib::PropertyProxy< unsigned int > Gdk::DmabufTextureBuilder::property_height | ( | ) |
The height of the texture.
Default value: 0
Glib::PropertyProxy_ReadOnly< unsigned int > Gdk::DmabufTextureBuilder::property_height | ( | ) | const |
The height of the texture.
Default value: 0
Glib::PropertyProxy< guint64 > Gdk::DmabufTextureBuilder::property_modifier | ( | ) |
The modifier.
Default value: 0
Glib::PropertyProxy_ReadOnly< guint64 > Gdk::DmabufTextureBuilder::property_modifier | ( | ) | const |
The modifier.
Default value: 0
Glib::PropertyProxy< unsigned int > Gdk::DmabufTextureBuilder::property_n_planes | ( | ) |
The number of planes of the texture.
Note that you can set properties for other planes, but they will be ignored when constructing the texture.
Default value: 1
Glib::PropertyProxy_ReadOnly< unsigned int > Gdk::DmabufTextureBuilder::property_n_planes | ( | ) | const |
The number of planes of the texture.
Note that you can set properties for other planes, but they will be ignored when constructing the texture.
Default value: 1
Glib::PropertyProxy< bool > Gdk::DmabufTextureBuilder::property_premultiplied | ( | ) |
Whether the alpha channel is premultiplied into the others.
Only relevant if the format has alpha.
Default value: true
Glib::PropertyProxy_ReadOnly< bool > Gdk::DmabufTextureBuilder::property_premultiplied | ( | ) | const |
Whether the alpha channel is premultiplied into the others.
Only relevant if the format has alpha.
Default value: true
Glib::PropertyProxy< ::Cairo::RefPtr< ::Cairo::Region > > Gdk::DmabufTextureBuilder::property_update_region | ( | ) |
The update region for Gdk::GLTextureBuilder::property_update_texture().
Glib::PropertyProxy_ReadOnly< ::Cairo::RefPtr< ::Cairo::Region > > Gdk::DmabufTextureBuilder::property_update_region | ( | ) | const |
The update region for Gdk::GLTextureBuilder::property_update_texture().
Glib::PropertyProxy< Glib::RefPtr< Texture > > Gdk::DmabufTextureBuilder::property_update_texture | ( | ) |
The texture property_update_region() is an update for.
Glib::PropertyProxy_ReadOnly< Glib::RefPtr< Texture > > Gdk::DmabufTextureBuilder::property_update_texture | ( | ) | const |
The texture property_update_region() is an update for.
Glib::PropertyProxy< unsigned int > Gdk::DmabufTextureBuilder::property_width | ( | ) |
The width of the texture.
Default value: 0
Glib::PropertyProxy_ReadOnly< unsigned int > Gdk::DmabufTextureBuilder::property_width | ( | ) | const |
The width of the texture.
Default value: 0
void Gdk::DmabufTextureBuilder::set_color_state | ( | const Glib::RefPtr< const ColorState > & | color_state | ) |
Sets the color state for the texture.
By default, the colorstate is nullptr
. In that case, GTK will choose the correct colorstate based on the format. If you don't know what colorstates are, this is probably the right thing.
color_state | A Gdk::ColorState or nullptr to unset the colorstate. |
void Gdk::DmabufTextureBuilder::set_display | ( | const Glib::RefPtr< Display > & | display | ) |
Sets the display that this texture builder is associated with.
The display is used to determine the supported dma-buf formats.
display | The display. |
void Gdk::DmabufTextureBuilder::set_fd | ( | unsigned int | plane, |
int | fd | ||
) |
Sets the file descriptor for a plane.
plane | The plane to set the fd for. |
fd | The file descriptor. |
void Gdk::DmabufTextureBuilder::set_fourcc | ( | guint32 | fourcc | ) |
Sets the format of the texture.
The format is specified as a fourcc code.
The format must be set before calling Gdk::GLTextureBuilder::build().
fourcc | The texture's format or 0 to unset. |
void Gdk::DmabufTextureBuilder::set_height | ( | unsigned int | height | ) |
Sets the height of the texture.
The height must be set before calling Gdk::GLTextureBuilder::build().
height | The texture's height or 0 to unset. |
void Gdk::DmabufTextureBuilder::set_modifier | ( | guint64 | modifier | ) |
void Gdk::DmabufTextureBuilder::set_n_planes | ( | unsigned int | n_planes | ) |
Sets the number of planes of the texture.
n_planes | The number of planes. |
void Gdk::DmabufTextureBuilder::set_offset | ( | unsigned int | plane, |
unsigned int | offset | ||
) |
Sets the offset for a plane.
plane | The plane to set the offset for. |
offset | The offset value. |
void Gdk::DmabufTextureBuilder::set_premultiplied | ( | bool | premultiplied = true | ) |
Sets whether the data is premultiplied.
Unless otherwise specified, all formats including alpha channels are assumed to be premultiplied.
premultiplied | Whether the data is premultiplied. |
void Gdk::DmabufTextureBuilder::set_stride | ( | unsigned int | plane, |
unsigned int | stride | ||
) |
Sets the stride for a plane.
The stride must be set for all planes before calling Gdk::GLTextureBuilder::build().
plane | The plane to set the stride for. |
stride | The stride value. |
void Gdk::DmabufTextureBuilder::set_update_region | ( | const ::Cairo::RefPtr< ::Cairo::Region > & | region | ) |
Sets the region to be updated by this texture.
Together with property_update_texture() this describes an update of a previous texture.
When rendering animations of large textures, it is possible that consecutive textures are only updating contents in parts of the texture. It is then possible to describe this update via these two properties, so that GTK can avoid rerendering parts that did not change.
An example would be a screen recording where only the mouse pointer moves.
region | The region to update. |
void Gdk::DmabufTextureBuilder::set_update_texture | ( | const Glib::RefPtr< Texture > & | texture | ) |
Sets the texture to be updated by this texture.
See set_update_region() for an explanation.
texture | The texture to update. |
void Gdk::DmabufTextureBuilder::set_width | ( | unsigned int | width | ) |
Sets the width of the texture.
The width must be set before calling Gdk::GLTextureBuilder::build().
width | The texture's width or 0 to unset. |
|
related |
A Glib::wrap() method for this object.
object | The C instance. |
take_copy | False if the result should take ownership of the C instance. True if it should take a new copy or ref. |