| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384 |
- //
- // "$Id: Fl_Cairo_Window.H 8864 2011-07-19 04:49:30Z greg.ercolano $"
- //
- // Main header file for the Fast Light Tool Kit (FLTK).
- //
- // Copyright 1998-2010 by Bill Spitzak and others.
- //
- // This library is free software. Distribution and use rights are outlined in
- // the file "COPYING" which should have been included with this file. If this
- // file is missing or damaged, see the license at:
- //
- // http://www.fltk.org/COPYING.php
- //
- // Please report all bugs and problems on the following page:
- //
- // http://www.fltk.org/str.php
- //
- /* \file
- Fl_Cairo_Window Handling transparently a fltk window incorporte a cairo draw callback.
- */
- #ifndef FL_CAIRO_WINDOW_H
- # define FL_CAIRO_WINDOW_H
- # ifdef FLTK_HAVE_CAIRO
- // Cairo is currently supported for the following platforms:
- // Win32, Apple Quartz, X11
- # include <FL/Fl.H>
- # include <FL/Fl_Double_Window.H>
- /**
- \addtogroup group_cairo
- @{
- */
- /**
- This defines a pre-configured cairo fltk window.
- This class overloads the virtual draw() method for you,
- so that the only thing you have to do is to provide your cairo code.
- All cairo context handling is achieved transparently.
- \note You can alternatively define your custom cairo fltk window,
- and thus at least override the draw() method to provide custom cairo
- support. In this case you will probably use Fl::cairo_make_current(Fl_Window*)
- to attach a context to your window. You should do it only when your window is
- the current window. \see Fl_Window::current()
- */
- class FL_EXPORT Fl_Cairo_Window : public Fl_Double_Window {
- public:
- Fl_Cairo_Window(int w, int h) : Fl_Double_Window(w,h),draw_cb_(0) {}
- protected:
- /** Overloaded to provide cairo callback support */
- void draw() {
- Fl_Double_Window::draw();
- // manual method ? if yes explicitly get a cairo_context here
- if (!Fl::cairo_autolink_context())
- Fl::cairo_make_current(this);
- if (draw_cb_) draw_cb_(this, Fl::cairo_cc());
- }
- public:
- /** This defines the cairo draw callback prototype that you must further */
- typedef void (*cairo_draw_cb) (Fl_Cairo_Window* self, cairo_t* def);
- /**
- You must provide a draw callback which will implement your cairo rendering.
- This method will permit you to set your cairo callback to \p cb.
- */
- void set_draw_cb(cairo_draw_cb cb){draw_cb_=cb;}
- private:
- cairo_draw_cb draw_cb_;
- DECLARE_CLASS_CHEAP_RTTI_2(Fl_Cairo_Window, public Fl_Double_Window)
- };
- /** @} */
- # endif // FLTK_HAVE_CAIRO
- #endif // FL_CAIRO_WINDOW_H
- //
- // End of "$Id: Fl_Cairo_Window.H 8864 2011-07-19 04:49:30Z greg.ercolano $" .
- //
|