gtkmm 4.14.0
Public Types | Public Member Functions | Static Public Member Functions | Static Public Attributes | Protected Member Functions | Related Functions | List of all members
Gdk::MemoryTexture Class Reference

A Gdk::Texture representing image data in memory. More...

#include <gdkmm/memorytexture.h>

Inheritance diagram for Gdk::MemoryTexture:
Inheritance graph
[legend]

Public Types

enum class  Format {
  Format::B8G8R8A8_PREMULTIPLIED ,
  Format::A8R8G8B8_PREMULTIPLIED ,
  Format::R8G8B8A8_PREMULTIPLIED ,
  Format::B8G8R8A8 ,
  Format::A8R8G8B8 ,
  Format::R8G8B8A8 ,
  Format::A8B8G8R8 ,
  Format::R8G8B8 ,
  Format::B8G8R8 ,
  Format::R16G16B16 ,
  Format::R16G16B16A16_PREMULTIPLIED ,
  Format::R16G16B16A16 ,
  Format::R16G16B16_FLOAT ,
  Format::R16G16B16A16_FLOAT_PREMULTIPLIED ,
  Format::R16G16B16A16_FLOAT ,
  Format::R32G32B32_FLOAT ,
  Format::R32G32B32A32_FLOAT_PREMULTIPLIED ,
  Format::R32G32B32A32_FLOAT ,
  Format::G8A8_PREMULTIPLIED ,
  Format::G8A8 ,
  Format::G8 ,
  Format::G16A16_PREMULTIPLIED ,
  Format::G16A16 ,
  Format::G16 ,
  Format::A8 ,
  Format::A16 ,
  Format::A16_FLOAT ,
  Format::A32_FLOAT ,
  Format::A8B8G8R8_PREMULTIPLIED ,
  Format::B8G8R8X8 ,
  Format::X8R8G8B8 ,
  Format::R8G8B8X8 ,
  Format::X8B8G8R8 ,
  Format::N_FORMATS
}
 Prefer Gdk::MemoryFormat to Gdk::MemoryTexture::Format where possible. More...
 
- Public Types inherited from Gdk::Paintable
enum class  Flags {
  Flags::STATIC_SIZE = 1 << 0 ,
  Flags::STATIC_CONTENTS = 1 << 1
}
 Flags about a paintable object. More...
 

Public Member Functions

 MemoryTexture (MemoryTexture && src) noexcept
 
MemoryTextureoperator= (MemoryTexture && src) noexcept
 
 ~MemoryTexture () noexcept override
 
GdkMemoryTexture * gobj ()
 Provides access to the underlying C GObject. More...
 
const GdkMemoryTexture * gobj () const
 Provides access to the underlying C GObject. More...
 
GdkMemoryTexture * gobj_copy ()
 Provides access to the underlying C instance. The caller is responsible for unrefing it. Use when directly setting fields in structs. More...
 
- Public Member Functions inherited from Gdk::Texture
 Texture (Texture && src) noexcept
 
Textureoperator= (Texture && src) noexcept
 
 ~Texture () noexcept override
 
GdkTexture * gobj ()
 Provides access to the underlying C GObject. More...
 
const GdkTexture * gobj () const
 Provides access to the underlying C GObject. More...
 
GdkTexture * gobj_copy ()
 Provides access to the underlying C instance. The caller is responsible for unrefing it. Use when directly setting fields in structs. More...
 
int get_width () const
 Returns the width of texture, in pixels. More...
 
int get_height () const
 Returns the height of the texture, in pixels. More...
 
MemoryFormat get_format () const
 Gets the memory format most closely associated with the data of the texture. More...
 
void download (guchar *data, gsize stride) const
 Downloads the texture into local memory. More...
 
bool save_to_png (const Glib::ustring & filename) const
 Store the given texture to the filename as a PNG file. More...
 
Glib::RefPtr< Glib::Bytes > save_to_png_bytes () const
 Store the given texture in memory as a PNG file. More...
 
bool save_to_tiff (const std::string & filename) const
 Store the given texture to the filename as a TIFF file. More...
 
Glib::RefPtr< Glib::Bytes > save_to_tiff_bytes () const
 Store the given texture in memory as a TIFF file. More...
 
Glib::PropertyProxy_ReadOnly< int > property_width () const
 The width of the texture, in pixels. More...
 
Glib::PropertyProxy_ReadOnly< int > property_height () const
 The height of the texture, in pixels. More...
 
- Public Member Functions inherited from Gdk::Paintable
 Paintable (Paintable && src) noexcept
 
Paintableoperator= (Paintable && src) noexcept
 
 ~Paintable () noexcept override
 
GdkPaintable * gobj ()
 Provides access to the underlying C GObject. More...
 
const GdkPaintable * gobj () const
 Provides access to the underlying C GObject. More...
 
void snapshot (const Glib::RefPtr< Gdk::Snapshot > & snapshot, double width, double height)
 Snapshots the given paintable with the given width and height. More...
 
Glib::RefPtr< const Paintableget_current_image () const
 Gets an immutable paintable for the current contents displayed by paintable. More...
 
Flags get_flags () const
 Get flags for the paintable. More...
 
int get_intrinsic_width () const
 Gets the preferred width the paintable would like to be displayed at. More...
 
int get_intrinsic_height () const
 Gets the preferred height the paintable would like to be displayed at. More...
 
double get_intrinsic_aspect_ratio () const
 Gets the preferred aspect ratio the paintable would like to be displayed at. More...
 
void compute_concrete_size (double specified_width, double specified_height, double default_width, double default_height, double & concrete_width, double & concrete_height) const
 Compute a concrete size for the Gdk::Paintable. More...
 
void invalidate_contents ()
 Called by implementations of Gdk::Paintable to invalidate their contents. More...
 
void invalidate_size ()
 Called by implementations of Gdk::Paintable to invalidate their size. More...
 
Glib::SignalProxy< void()> signal_invalidate_contents ()
 
Glib::SignalProxy< void()> signal_invalidate_size ()
 

Static Public Member Functions

static GType get_type ()
 Get the GType for this class, for use with the underlying GObject type system. More...
 
static Glib::RefPtr< Texturecreate (int width, int height, Format format, const Glib::RefPtr< const Glib::Bytes > & bytes, gsize stride)
 Creates a new texture for a blob of image data. More...
 
- Static Public Member Functions inherited from Gdk::Texture
static GType get_type ()
 Get the GType for this class, for use with the underlying GObject type system. More...
 
static Glib::RefPtr< Texturecreate_for_pixbuf (const Glib::RefPtr< Pixbuf > & pixbuf)
 Creates a new texture object representing the Gdk::Pixbuf. More...
 
static Glib::RefPtr< Texturecreate_from_resource (const std::string & resource_path)
 Creates a new texture by loading an image from a resource. More...
 
static Glib::RefPtr< Texturecreate_from_file (const Glib::RefPtr< Gio::File > & file)
 Creates a new texture by loading an image from a file. More...
 
static Glib::RefPtr< Texturecreate_from_filename (const std::string & path)
 Creates a new texture by loading an image from a file. More...
 
static Glib::RefPtr< Texturecreate_from_bytes (const Glib::RefPtr< const Glib::Bytes > & bytes)
 Creates a new texture by loading an image from memory,. More...
 
- Static Public Member Functions inherited from Gdk::Paintable
static void add_interface (GType gtype_implementer)
 
static GType get_type ()
 Get the GType for this class, for use with the underlying GObject type system. More...
 

Static Public Attributes

static const Format DEFAULT_FORMAT = static_cast<Format>(GDK_MEMORY_DEFAULT)
 Default memory format used by GTK. More...
 

Protected Member Functions

 MemoryTexture ()
 
- Protected Member Functions inherited from Gdk::Texture
 Texture ()
 
- Protected Member Functions inherited from Gdk::Paintable
 Paintable ()
 You should derive from this class to use it. More...
 
virtual void snapshot_vfunc (const Glib::RefPtr< Gdk::Snapshot > &snapshot, double width, double height)
 
virtual Glib::RefPtr< Paintableget_current_image_vfunc () const
 
virtual Flags get_flags_vfunc () const
 
virtual int get_intrinsic_width_vfunc () const
 
virtual int get_intrinsic_height_vfunc () const
 
virtual double get_intrinsic_aspect_ratio_vfunc () const
 

Related Functions

(Note that these are not member functions.)

Glib::RefPtr< Gdk::MemoryTexturewrap (GdkMemoryTexture * object, bool take_copy=false)
 A Glib::wrap() method for this object. More...
 

Detailed Description

A Gdk::Texture representing image data in memory.

Since gtkmm 3.98:

Constructor & Destructor Documentation

◆ MemoryTexture() [1/2]

Gdk::MemoryTexture::MemoryTexture ( MemoryTexture &&  src)
noexcept

◆ ~MemoryTexture()

Gdk::MemoryTexture::~MemoryTexture ( )
overridenoexcept

◆ MemoryTexture() [2/2]

Gdk::MemoryTexture::MemoryTexture ( )
protected

Member Function Documentation

◆ create()

static Glib::RefPtr< Texture > Gdk::MemoryTexture::create ( int  width,
int  height,
Format  format,
const Glib::RefPtr< const Glib::Bytes > &  bytes,
gsize  stride 
)
static

Creates a new texture for a blob of image data.

The Glib::Bytes must contain stride × height pixels in the given format.

Parameters
widthThe width of the texture.
heightThe height of the texture.
formatThe format of the data.
bytesThe Glib::Bytes containing the pixel data.
strideRowstride for the data.
Returns
A newly-created Gdk::Texture.

◆ get_type()

static GType Gdk::MemoryTexture::get_type ( )
static

Get the GType for this class, for use with the underlying GObject type system.

◆ gobj() [1/2]

GdkMemoryTexture * Gdk::MemoryTexture::gobj ( )
inline

Provides access to the underlying C GObject.

◆ gobj() [2/2]

const GdkMemoryTexture * Gdk::MemoryTexture::gobj ( ) const
inline

Provides access to the underlying C GObject.

◆ gobj_copy()

GdkMemoryTexture * Gdk::MemoryTexture::gobj_copy ( )

Provides access to the underlying C instance. The caller is responsible for unrefing it. Use when directly setting fields in structs.

◆ operator=()

MemoryTexture & Gdk::MemoryTexture::operator= ( MemoryTexture &&  src)
noexcept

Friends And Related Function Documentation

◆ wrap()

Glib::RefPtr< Gdk::MemoryTexture > wrap ( GdkMemoryTexture *  object,
bool  take_copy = false 
)
related

A Glib::wrap() method for this object.

Parameters
objectThe C instance.
take_copyFalse if the result should take ownership of the C instance. True if it should take a new copy or ref.
Returns
A C++ instance that wraps this C instance.

Member Data Documentation

◆ DEFAULT_FORMAT

const Format Gdk::MemoryTexture::DEFAULT_FORMAT = static_cast<Format>(GDK_MEMORY_DEFAULT)
static

Default memory format used by GTK.

It is the format provided by Gdk::Texture::download(). It is equal to Cairo::Surface::Format::ARGB32.

Be aware that unlike the Format values, this format is different for different endianness.