FLTK 1.4.0
|
Classes | |
class | Fl_Cairo_State |
Contains all the necessary info on the current cairo context. More... | |
class | Fl_Cairo_Window |
This defines an FLTK window with Cairo support. More... | |
Functions | |
static bool | Fl::cairo_autolink_context () |
Gets the current autolink mode for Cairo support. More... | |
static void | Fl::cairo_autolink_context (bool alink) |
When FLTK_HAVE_CAIRO is defined and cairo_autolink_context() is true, any current window dc is linked to a current Cairo context. More... | |
static cairo_t * | Fl::cairo_cc () |
Gets the current Cairo context linked with a fltk window. | |
static void | Fl::cairo_cc (cairo_t *c, bool own=false) |
Sets the current Cairo context to c . More... | |
static void | Fl::cairo_flush (cairo_t *c) |
Flush Cairo drawings on Cairo context c . More... | |
static cairo_t * | Fl::cairo_make_current (Fl_Window *w) |
Provides a Cairo context for window wi. More... | |
|
inlinestatic |
Gets the current autolink mode for Cairo support.
false | if no Cairo context autolink is made for each window. |
true | if any fltk window is attached a Cairo context when it is current. |
|
inlinestatic |
When FLTK_HAVE_CAIRO is defined and cairo_autolink_context() is true, any current window dc is linked to a current Cairo context.
This is not the default, because it may not be necessary to add Cairo support to all fltk supported windows. When you wish to associate a Cairo context in this mode, you need to call explicitly in your draw() overridden method, Fl::cairo_make_current(Fl_Window*). This will create a Cairo context only for this Window. Still in custom Cairo application it is possible to handle completely this process automatically by setting alink
to true. In this last case, you don't need anymore to call Fl::cairo_make_current(). You can use Fl::cairo_cc() to get the current Cairo context anytime.
|
inlinestatic |
Sets the current Cairo context to c
.
Set own
to true if you want fltk to handle this cc deletion.
|
inlinestatic |
Flush Cairo drawings on Cairo context c
.
This is required on Windows if you use the Cairo context provided by the "Cairo autolink" option. Call this when all your drawings on the Cairo context are finished. This is maybe not necessary on other platforms than Windows but it does no harm if you call it always.
You don't need to use this if you use an Fl_Cairo_Window which does this automatically after the draw callback returns.
Code example for "Cairo autolink" mode:
In the overridden draw() method of your subclass of Fl_Window or any widget:
If you configure FLTK with '--enable-cairo'
or CMake option 'FLTK_OPTION_CAIRO_WINDOW'
(i.e. without '--enable-cairoext'
or CMake option 'FLTK_OPTION_CAIRO_EXT'
) or if you don't enable the 'autolink'
Cairo context you may do the equivalent to use Cairo drawings in an overridden draw() method of derived classes by using
|
static |
Provides a Cairo context for window wi.
This is needed in a draw() override if Fl::cairo_autolink_context() returns false, which is the default. The cairo_context() does not need to be freed as it is freed every time a new Cairo context is created. When the program terminates, a call to Fl::cairo_make_current(0) will destroy any residual context.
NULL | if wi is NULL or maybe with GL windows under Wayland |