summaryrefslogtreecommitdiff
path: root/gtk2_ardour/cairo_widget.h
blob: e368a21a03454bd6d23bae5c2eca538a2ebac40f (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
/*
    Copyright (C) 2009 Paul Davis

    This program is free software; you can redistribute it and/or modify
    it under the terms of the GNU General Public License as published by
    the Free Software Foundation; either version 2 of the License, or
    (at your option) any later version.

    This program is distributed in the hope that it will be useful,
    but WITHOUT ANY WARRANTY; without even the implied warranty of
    MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
    GNU General Public License for more details.

    You should have received a copy of the GNU General Public License
    along with this program; if not, write to the Free Software
    Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.

*/

#ifndef __gtk2_ardour_cairo_widget_h__
#define __gtk2_ardour_cairo_widget_h__

#include <gtkmm/eventbox.h>

/** A parent class for widgets that are made up of a pixmap rendered using Cairo.
 *  The pixmap is painted to screen on GTK expose events, but the rendering
 *  is only done after set_dirty() has been called.
 */

class CairoWidget : public Gtk::EventBox
{
public:
	CairoWidget ();
	virtual ~CairoWidget ();

	void set_dirty ();

	/* widget states: unlike GTK, these OR-together so that
	   a widget can be both Active *and* Selected, rather than
	   each one being orthogonal.
	*/

	enum State {
		Active = 0x1,
		Mid = 0x2,
		Selected = 0x4,
		Prelight = 0x8,
		Insensitive = 0x10,
	};

	State state() const { return _state; }
	virtual void set_state (State, bool);
	sigc::signal<void> StateChanged;

protected:
	/** Render the widget to the given Cairo context */
	virtual void render (cairo_t *) = 0;
	virtual bool on_expose_event (GdkEventExpose *);
	void on_size_allocate (Gtk::Allocation &);
	Gdk::Color get_parent_bg ();

	int _width; ///< pixmap width
	int _height; ///< pixmap height
	State _state;

private:
	bool _dirty; ///< true if the pixmap requires re-rendering
	GdkPixmap* _pixmap; ///< our pixmap
};

#endif