CellRenderers are used by Gtk::TreeView columns to render the Gtk::TreeModel column data appropriately. More...
Inherits Gtk::Object.
Inherited by Gtk::CellRendererPixbuf, Gtk::CellRendererProgress, Gtk::CellRendererSpinner, Gtk::CellRendererText, and Gtk::CellRendererToggle.
Public Member Functions | |
virtual | ~CellRenderer () |
GtkCellRenderer* | gobj () |
Provides access to the underlying C GtkObject. | |
const GtkCellRenderer* | gobj () const |
Provides access to the underlying C GtkObject. | |
void | get_size (Widget& widget, const Gdk::Rectangle& cell_area, int& x_offset, int& y_offset, int& width, int& height) const |
Obtains the width and height needed to render the cell. | |
void | get_size (Widget& widget, int& x_offset, int& y_offset, int& width, int& height) const |
Obtains the width and height needed to render the cell. | |
void | render (const Glib::RefPtr< Gdk::Window >& window, Widget& widget, const Gdk::Rectangle& background_area, const Gdk::Rectangle& cell_area, const Gdk::Rectangle& expose_area, CellRendererState flags) |
Invokes the virtual render function of the Gtk::CellRenderer. | |
bool | activate (GdkEvent* event, Widget& widget, const Glib::ustring& path, const Gdk::Rectangle& background_area, const Gdk::Rectangle& cell_area, CellRendererState flags) |
Passes an activate event to the cell renderer for possible processing. | |
CellEditable* | start_editing (GdkEvent* event, Widget& widget, const Glib::ustring& path, const Gdk::Rectangle& background_area, const Gdk::Rectangle& cell_area, CellRendererState flags=CellRendererState(0)) |
Passes an activate event to the cell renderer for possible processing. | |
void | set_fixed_size (int width, int height) |
Sets the renderer size to be explicit, independent of the properties set. | |
void | get_fixed_size (int& width, int& height) const |
Fills in width and height with the appropriate size of cell. | |
void | set_alignment (float align, float yalign) |
Sets the renderer's alignment within its available space. | |
void | get_alignment (float& xalign, float& yalign) const |
Fills in xalign and yalign with the appropriate values of cell. | |
void | set_padding (int xpad, int ypad) |
Sets the renderer's padding. | |
void | get_padding (int& xpad, int& ypad) const |
Fills in xpad and ypad with the appropriate values of cell. | |
void | set_visible (bool visible=true) |
Sets the cell renderer's visibility. | |
bool | get_visible () const |
Returns the cell renderer's visibility. | |
void | set_sensitive (bool sensitive=true) |
Sets the cell renderer's sensitivity. | |
bool | get_sensitive () const |
Returns the cell renderer's sensitivity. | |
void | editing_canceled () |
Causes the cell renderer to emit the Gtk::CellRenderer::editing-canceled signal. | |
void | stop_editing (bool canceled=false) |
Informs the cell renderer that the editing is stopped. | |
Glib::SignalProxy0< void > | signal_editing_canceled () |
This signal is emitted when the user cancels the process of editing a cell. | |
Glib::SignalProxy2< void, CellEditable*, const Glib::ustring& > | signal_editing_started () |
This signal gets emitted when a cell starts to be edited. | |
Glib::PropertyProxy < CellRendererMode > | property_mode () |
Editable mode of the CellRenderer. | |
Glib::PropertyProxy_ReadOnly < CellRendererMode > | property_mode () const |
Editable mode of the CellRenderer. | |
Glib::PropertyProxy< bool > | property_visible () |
Display the cell. | |
Glib::PropertyProxy_ReadOnly < bool > | property_visible () const |
Display the cell. | |
Glib::PropertyProxy< bool > | property_sensitive () |
Display the cell sensitive. | |
Glib::PropertyProxy_ReadOnly < bool > | property_sensitive () const |
Display the cell sensitive. | |
Glib::PropertyProxy< float > | property_xalign () |
The x-align. | |
Glib::PropertyProxy_ReadOnly < float > | property_xalign () const |
The x-align. | |
Glib::PropertyProxy< float > | property_yalign () |
The y-align. | |
Glib::PropertyProxy_ReadOnly < float > | property_yalign () const |
The y-align. | |
Glib::PropertyProxy< unsigned int > | property_xpad () |
The xpad. | |
Glib::PropertyProxy_ReadOnly < unsigned int > | property_xpad () const |
The xpad. | |
Glib::PropertyProxy< unsigned int > | property_ypad () |
The ypad. | |
Glib::PropertyProxy_ReadOnly < unsigned int > | property_ypad () const |
The ypad. | |
Glib::PropertyProxy< int > | property_width () |
The fixed width. | |
Glib::PropertyProxy_ReadOnly< int > | property_width () const |
The fixed width. | |
Glib::PropertyProxy< int > | property_height () |
The fixed height. | |
Glib::PropertyProxy_ReadOnly< int > | property_height () const |
The fixed height. | |
Glib::PropertyProxy< bool > | property_is_expander () |
Row has children. | |
Glib::PropertyProxy_ReadOnly < bool > | property_is_expander () const |
Row has children. | |
Glib::PropertyProxy< bool > | property_is_expanded () |
Row is an expander row. | |
Glib::PropertyProxy_ReadOnly < bool > | property_is_expanded () const |
Row is an expander row. | |
Glib::PropertyProxy_WriteOnly < Glib::ustring > | property_cell_background () |
Cell background color as a string. | |
Glib::PropertyProxy< Gdk::Color > | property_cell_background_gdk () |
Cell background color as a GdkColor. | |
Glib::PropertyProxy_ReadOnly < Gdk::Color > | property_cell_background_gdk () const |
Cell background color as a GdkColor. | |
Glib::PropertyProxy< bool > | property_cell_background_set () |
Whether this tag affects the cell background color. | |
Glib::PropertyProxy_ReadOnly < bool > | property_cell_background_set () const |
Whether this tag affects the cell background color. | |
Protected Member Functions | |
virtual void | on_editing_canceled () |
CellRenderer () | |
virtual void | get_size_vfunc (Widget& widget, const Gdk::Rectangle* cell_area, int* x_offset, int* y_offset, int* width, int* height) const |
Override this in derived CellRenderers. | |
virtual void | render_vfunc (const Glib::RefPtr< Gdk::Drawable >& window, Widget& widget, const Gdk::Rectangle& background_area, const Gdk::Rectangle& cell_area, const Gdk::Rectangle& expose_area, CellRendererState flags) |
virtual bool | activate_vfunc (GdkEvent* event, Widget& widget, const Glib::ustring& path, const Gdk::Rectangle& background_area, const Gdk::Rectangle& cell_area, CellRendererState flags) |
virtual CellEditable* | start_editing_vfunc (GdkEvent* event, Widget& widget, const Glib::ustring& path, const Gdk::Rectangle& background_area, const Gdk::Rectangle& cell_area, CellRendererState flags) |
Related Functions | |
(Note that these are not member functions.) | |
Gtk::CellRenderer* | wrap (GtkCellRenderer* object, bool take_copy=false) |
A Glib::wrap() method for this object. |
CellRenderers are used by Gtk::TreeView columns to render the Gtk::TreeModel column data appropriately.
They display, and allow editing of, the values of their properties. In most cases, Gtk::TreeView::append_column() will automatically choose the appropriate renderer for the mode column's data type, so you will rarely need to worry about these classes.
virtual Gtk::CellRenderer::~CellRenderer | ( | ) | [virtual] |
Gtk::CellRenderer::CellRenderer | ( | ) | [protected] |
bool Gtk::CellRenderer::activate | ( | GdkEvent * | event, | |
Widget& | widget, | |||
const Glib::ustring & | path, | |||
const Gdk::Rectangle& | background_area, | |||
const Gdk::Rectangle& | cell_area, | |||
CellRendererState | flags | |||
) |
Passes an activate event to the cell renderer for possible processing.
Some cell renderers may use events; for example, Gtk::CellRendererToggle toggles when it gets a mouse click.
event | A Gdk::Event. | |
widget | Widget that received the event. | |
path | Widget-dependent string representation of the event location; e.g. for Gtk::TreeView, a string representation of Gtk::TreePath. | |
background_area | Background area as passed to render(). | |
cell_area | Cell area as passed to render(). | |
flags | Render flags. |
true
if the event was consumed/handled. virtual bool Gtk::CellRenderer::activate_vfunc | ( | GdkEvent * | event, | |
Widget& | widget, | |||
const Glib::ustring & | path, | |||
const Gdk::Rectangle& | background_area, | |||
const Gdk::Rectangle& | cell_area, | |||
CellRendererState | flags | |||
) | [protected, virtual] |
void Gtk::CellRenderer::editing_canceled | ( | ) |
Causes the cell renderer to emit the Gtk::CellRenderer::editing-canceled signal.
This function is for use only by implementations of cell renderers that need to notify the client program that an editing process was canceled and the changes were not committed.
void Gtk::CellRenderer::get_alignment | ( | float & | xalign, | |
float & | yalign | |||
) | const |
Fills in xalign and yalign with the appropriate values of cell.
xalign | Location to fill in with the x alignment of the cell, or 0 . | |
yalign | Location to fill in with the y alignment of the cell, or 0 . |
void Gtk::CellRenderer::get_fixed_size | ( | int & | width, | |
int & | height | |||
) | const |
Fills in width and height with the appropriate size of cell.
width | Location to fill in with the fixed width of the widget. | |
height | Location to fill in with the fixed height of the widget. |
void Gtk::CellRenderer::get_padding | ( | int & | xpad, | |
int & | ypad | |||
) | const |
Fills in xpad and ypad with the appropriate values of cell.
xpad | Location to fill in with the x padding of the cell, or 0 . | |
ypad | Location to fill in with the y padding of the cell, or 0 . |
bool Gtk::CellRenderer::get_sensitive | ( | ) | const |
Returns the cell renderer's sensitivity.
true
if the cell renderer is sensitive. void Gtk::CellRenderer::get_size | ( | Widget& | widget, | |
int & | x_offset, | |||
int & | y_offset, | |||
int & | width, | |||
int & | height | |||
) | const |
Obtains the width and height needed to render the cell.
Used by view widgets to determine the appropriate size for the cell_area passed to render(). Fills in the x and y offsets of the cell relative to this location. Please note that the values set in width and height , as well as those in x_offset and y_offset are inclusive of the xpad and ypad properties.
widget | The widget the renderer is rendering to. | |
x_offset | Location to return x offset of cell relative to cell_area. | |
y_offset | Location to return y offset of cell relative to cell_area. | |
width | Location to return width needed to render a cell. | |
height | Location to return height needed to render a cell. |
void Gtk::CellRenderer::get_size | ( | Widget& | widget, | |
const Gdk::Rectangle& | cell_area, | |||
int & | x_offset, | |||
int & | y_offset, | |||
int & | width, | |||
int & | height | |||
) | const |
Obtains the width and height needed to render the cell.
Used by view widgets to determine the appropriate size for the cell_area passed to render(). Fills in the x and y offsets of the cell relative to this location. Please note that the values set in width and height, as well as those in x_offset and y_offset are inclusive of the xpad and ypad properties.
widget | The widget the renderer is rendering to. | |
cell_area | The area a cell will be allocated. | |
x_offset | Location to return x offset of cell relative to cell_area. | |
y_offset | Location to return y offset of cell relative to cell_area. | |
width | Location to return width needed to render a cell. | |
height | Location to return height needed to render a cell. |
virtual void Gtk::CellRenderer::get_size_vfunc | ( | Widget& | widget, | |
const Gdk::Rectangle* | cell_area, | |||
int * | x_offset, | |||
int * | y_offset, | |||
int * | width, | |||
int * | height | |||
) | const [protected, virtual] |
Override this in derived CellRenderers.
Obtains the width and height needed to render the cell. Used by view widgets to determine the appropriate size for the cell_area passed to render(). If cell_area is not 0, fills in the x and y offsets (if set) of the cell relative to this location. Please note that the values set in width and height, as well as those in x_offset and y_offset are inclusive of the xpad and ypad properties.
widget | The widget the renderer is rendering to. | |
cell_area | The area a cell will be allocated, or 0. | |
x_offset | x offset of cell relative to cell_area. | |
y_offset | y offset of cell relative to cell_area. | |
width | Width needed to render a cell. | |
height | Height needed to render a cell. |
bool Gtk::CellRenderer::get_visible | ( | ) | const |
Returns the cell renderer's visibility.
true
if the cell renderer is visible. const GtkCellRenderer* Gtk::CellRenderer::gobj | ( | ) | const [inline] |
Provides access to the underlying C GtkObject.
Reimplemented from Gtk::Object.
Reimplemented in Gtk::CellRendererAccel, Gtk::CellRendererCombo, Gtk::CellRendererPixbuf, Gtk::CellRendererProgress, Gtk::CellRendererSpin, Gtk::CellRendererSpinner, Gtk::CellRendererText, and Gtk::CellRendererToggle.
GtkCellRenderer* Gtk::CellRenderer::gobj | ( | ) | [inline] |
Provides access to the underlying C GtkObject.
Reimplemented from Gtk::Object.
Reimplemented in Gtk::CellRendererAccel, Gtk::CellRendererCombo, Gtk::CellRendererPixbuf, Gtk::CellRendererProgress, Gtk::CellRendererSpin, Gtk::CellRendererSpinner, Gtk::CellRendererText, and Gtk::CellRendererToggle.
virtual void Gtk::CellRenderer::on_editing_canceled | ( | ) | [protected, virtual] |
Glib::PropertyProxy_WriteOnly<Glib::ustring> Gtk::CellRenderer::property_cell_background | ( | ) |
Cell background color as a string.
You rarely need to use properties because there are get_ and set_ methods for almost all of them.
Glib::PropertyProxy_ReadOnly<Gdk::Color> Gtk::CellRenderer::property_cell_background_gdk | ( | ) | const |
Cell background color as a GdkColor.
You rarely need to use properties because there are get_ and set_ methods for almost all of them.
Glib::PropertyProxy<Gdk::Color> Gtk::CellRenderer::property_cell_background_gdk | ( | ) |
Cell background color as a GdkColor.
You rarely need to use properties because there are get_ and set_ methods for almost all of them.
Glib::PropertyProxy_ReadOnly<bool> Gtk::CellRenderer::property_cell_background_set | ( | ) | const |
Whether this tag affects the cell background color.
You rarely need to use properties because there are get_ and set_ methods for almost all of them.
Glib::PropertyProxy<bool> Gtk::CellRenderer::property_cell_background_set | ( | ) |
Whether this tag affects the cell background color.
You rarely need to use properties because there are get_ and set_ methods for almost all of them.
Glib::PropertyProxy_ReadOnly<int> Gtk::CellRenderer::property_height | ( | ) | const |
The fixed height.
You rarely need to use properties because there are get_ and set_ methods for almost all of them.
Glib::PropertyProxy<int> Gtk::CellRenderer::property_height | ( | ) |
The fixed height.
You rarely need to use properties because there are get_ and set_ methods for almost all of them.
Glib::PropertyProxy_ReadOnly<bool> Gtk::CellRenderer::property_is_expanded | ( | ) | const |
Row is an expander row.
You rarely need to use properties because there are get_ and set_ methods for almost all of them.
Glib::PropertyProxy<bool> Gtk::CellRenderer::property_is_expanded | ( | ) |
Row is an expander row.
You rarely need to use properties because there are get_ and set_ methods for almost all of them.
Glib::PropertyProxy_ReadOnly<bool> Gtk::CellRenderer::property_is_expander | ( | ) | const |
Row has children.
You rarely need to use properties because there are get_ and set_ methods for almost all of them.
Glib::PropertyProxy<bool> Gtk::CellRenderer::property_is_expander | ( | ) |
Row has children.
You rarely need to use properties because there are get_ and set_ methods for almost all of them.
Glib::PropertyProxy_ReadOnly<CellRendererMode> Gtk::CellRenderer::property_mode | ( | ) | const |
Editable mode of the CellRenderer.
You rarely need to use properties because there are get_ and set_ methods for almost all of them.
Glib::PropertyProxy<CellRendererMode> Gtk::CellRenderer::property_mode | ( | ) |
Editable mode of the CellRenderer.
You rarely need to use properties because there are get_ and set_ methods for almost all of them.
Glib::PropertyProxy_ReadOnly<bool> Gtk::CellRenderer::property_sensitive | ( | ) | const |
Display the cell sensitive.
You rarely need to use properties because there are get_ and set_ methods for almost all of them.
Glib::PropertyProxy<bool> Gtk::CellRenderer::property_sensitive | ( | ) |
Display the cell sensitive.
You rarely need to use properties because there are get_ and set_ methods for almost all of them.
Glib::PropertyProxy_ReadOnly<bool> Gtk::CellRenderer::property_visible | ( | ) | const |
Display the cell.
You rarely need to use properties because there are get_ and set_ methods for almost all of them.
Glib::PropertyProxy<bool> Gtk::CellRenderer::property_visible | ( | ) |
Display the cell.
You rarely need to use properties because there are get_ and set_ methods for almost all of them.
Glib::PropertyProxy_ReadOnly<int> Gtk::CellRenderer::property_width | ( | ) | const |
The fixed width.
You rarely need to use properties because there are get_ and set_ methods for almost all of them.
Glib::PropertyProxy<int> Gtk::CellRenderer::property_width | ( | ) |
The fixed width.
You rarely need to use properties because there are get_ and set_ methods for almost all of them.
Glib::PropertyProxy_ReadOnly<float> Gtk::CellRenderer::property_xalign | ( | ) | const |
The x-align.
You rarely need to use properties because there are get_ and set_ methods for almost all of them.
Glib::PropertyProxy<float> Gtk::CellRenderer::property_xalign | ( | ) |
The x-align.
You rarely need to use properties because there are get_ and set_ methods for almost all of them.
Glib::PropertyProxy_ReadOnly<unsigned int> Gtk::CellRenderer::property_xpad | ( | ) | const |
The xpad.
You rarely need to use properties because there are get_ and set_ methods for almost all of them.
Glib::PropertyProxy<unsigned int> Gtk::CellRenderer::property_xpad | ( | ) |
The xpad.
You rarely need to use properties because there are get_ and set_ methods for almost all of them.
Glib::PropertyProxy_ReadOnly<float> Gtk::CellRenderer::property_yalign | ( | ) | const |
The y-align.
You rarely need to use properties because there are get_ and set_ methods for almost all of them.
Glib::PropertyProxy<float> Gtk::CellRenderer::property_yalign | ( | ) |
The y-align.
You rarely need to use properties because there are get_ and set_ methods for almost all of them.
Glib::PropertyProxy_ReadOnly<unsigned int> Gtk::CellRenderer::property_ypad | ( | ) | const |
The ypad.
You rarely need to use properties because there are get_ and set_ methods for almost all of them.
Glib::PropertyProxy<unsigned int> Gtk::CellRenderer::property_ypad | ( | ) |
The ypad.
You rarely need to use properties because there are get_ and set_ methods for almost all of them.
void Gtk::CellRenderer::render | ( | const Glib::RefPtr< Gdk::Window >& | window, | |
Widget& | widget, | |||
const Gdk::Rectangle& | background_area, | |||
const Gdk::Rectangle& | cell_area, | |||
const Gdk::Rectangle& | expose_area, | |||
CellRendererState | flags | |||
) |
Invokes the virtual render function of the Gtk::CellRenderer.
The three passed-in rectangles are areas of window. Most renderers will draw within cell_area; the xalign, yalign, xpad, and ypad fields of the Gtk::CellRenderer should be honored with respect to cell_area. background_area includes the blank space around the cell, and also the area containing the tree expander; so the background_area rectangles for all cells tile to cover the entire window. expose_area is a clip rectangle.
window | A Gdk::Drawable to draw to. | |
widget | The widget owning window. | |
background_area | Entire cell area (including tree expanders and maybe padding on the sides). | |
cell_area | Area normally rendered by a cell renderer. | |
expose_area | Area that actually needs updating. | |
flags | Flags that affect rendering. |
virtual void Gtk::CellRenderer::render_vfunc | ( | const Glib::RefPtr< Gdk::Drawable >& | window, | |
Widget& | widget, | |||
const Gdk::Rectangle& | background_area, | |||
const Gdk::Rectangle& | cell_area, | |||
const Gdk::Rectangle& | expose_area, | |||
CellRendererState | flags | |||
) | [protected, virtual] |
void Gtk::CellRenderer::set_alignment | ( | float | align, | |
float | yalign | |||
) |
Sets the renderer's alignment within its available space.
xalign | The x alignment of the cell renderer. | |
yalign | The y alignment of the cell renderer. |
void Gtk::CellRenderer::set_fixed_size | ( | int | width, | |
int | height | |||
) |
Sets the renderer size to be explicit, independent of the properties set.
width | The width of the cell renderer, or -1. | |
height | The height of the cell renderer, or -1. |
void Gtk::CellRenderer::set_padding | ( | int | xpad, | |
int | ypad | |||
) |
Sets the renderer's padding.
xpad | The x padding of the cell renderer. | |
ypad | The y padding of the cell renderer. |
void Gtk::CellRenderer::set_sensitive | ( | bool | sensitive = true |
) |
Sets the cell renderer's sensitivity.
sensitive | The sensitivity of the cell. |
void Gtk::CellRenderer::set_visible | ( | bool | visible = true |
) |
Sets the cell renderer's visibility.
visible | The visibility of the cell. |
Glib::SignalProxy0< void > Gtk::CellRenderer::signal_editing_canceled | ( | ) |
This signal is emitted when the user cancels the process of editing a cell.
For example, an editable cell renderer could be written to cancel editing when the user presses Escape.
void on_my_editing_canceled()
Glib::SignalProxy2< void,CellEditable*,const Glib::ustring& > Gtk::CellRenderer::signal_editing_started | ( | ) |
This signal gets emitted when a cell starts to be edited.
The indended use of this signal is to do special setup on editable, e.g. adding an EntryCompletion or setting up additional columns in a ComboBox.
Note that GTK+ doesn't guarantee that cell renderers will continue to use the same kind of widget for editing in future releases, therefore you should check the type of editable before doing any specific setup.
Note that this signal does not work yet in gtkmm. See http://bugzilla.gnome.org/show_bug.cgi?id=301597
editable | the CellEditable. | |
path | the path identifying the edited cell. |
void on_my_editing_started(CellEditable* editable, const Glib::ustring& path)
CellEditable* Gtk::CellRenderer::start_editing | ( | GdkEvent * | event, | |
Widget& | widget, | |||
const Glib::ustring & | path, | |||
const Gdk::Rectangle& | background_area, | |||
const Gdk::Rectangle& | cell_area, | |||
CellRendererState | flags = CellRendererState(0) | |||
) |
Passes an activate event to the cell renderer for possible processing.
event | A Gdk::Event. | |
widget | Widget that received the event. | |
path | Widget-dependent string representation of the event location; e.g. for Gtk::TreeView, a string representation of Gtk::TreePath. | |
background_area | Background area as passed to render(). | |
cell_area | Cell area as passed to render(). | |
flags | Render flags. |
0
. virtual CellEditable* Gtk::CellRenderer::start_editing_vfunc | ( | GdkEvent * | event, | |
Widget& | widget, | |||
const Glib::ustring & | path, | |||
const Gdk::Rectangle& | background_area, | |||
const Gdk::Rectangle& | cell_area, | |||
CellRendererState | flags | |||
) | [protected, virtual] |
void Gtk::CellRenderer::stop_editing | ( | bool | canceled = false |
) |
Informs the cell renderer that the editing is stopped.
If canceled is true
, the cell renderer will emit the Gtk::CellRenderer::editing-canceled signal.
This function should be called by cell renderer implementations in response to the Gtk::CellEditable::editing-done signal of Gtk::CellEditable.
canceled | true if the editing has been canceled. |
Gtk::CellRenderer* wrap | ( | GtkCellRenderer * | object, | |
bool | take_copy = false | |||
) | [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. |