summaryrefslogtreecommitdiff
path: root/gtk2_ardour/canvas-flag.cc
diff options
context:
space:
mode:
authorPaul Davis <paul@linuxaudiosystems.com>2012-06-12 17:16:43 +0000
committerPaul Davis <paul@linuxaudiosystems.com>2012-06-12 17:16:43 +0000
commitaadd594bd8c9226b087ab477e98c8d0c9c4072aa (patch)
treeca06a6a296cebb26f751b57b097018b864beab6b /gtk2_ardour/canvas-flag.cc
parent92432f3e80d621816ac0b05484eb59fb9348ac34 (diff)
change CanvasFlag to use a pixbuf for text rather than Canvas::Text, because we know the performance improvements are good
git-svn-id: svn://localhost/ardour2/branches/3.0@12676 d708f5d6-7413-0410-9779-e7cbd77b26cf
Diffstat (limited to 'gtk2_ardour/canvas-flag.cc')
-rw-r--r--gtk2_ardour/canvas-flag.cc40
1 files changed, 22 insertions, 18 deletions
diff --git a/gtk2_ardour/canvas-flag.cc b/gtk2_ardour/canvas-flag.cc
index 17fe6cabd9..d77de07359 100644
--- a/gtk2_ardour/canvas-flag.cc
+++ b/gtk2_ardour/canvas-flag.cc
@@ -1,8 +1,12 @@
#include <iostream>
+#include "gtkmm2ext/utils.h"
+#include "gtkmm2ext/rgb_macros.h"
+
#include "ardour_ui.h"
#include "canvas-flag.h"
#include "time_axis_view_item.h"
+#include "utils.h"
using namespace Gnome::Canvas;
using namespace std;
@@ -15,23 +19,23 @@ CanvasFlag::CanvasFlag (MidiRegionView& region,
double x,
double y)
: Group(parent, x, y)
- , _text(0)
+ , _name_pixbuf(0)
, _height(height)
, _outline_color_rgba(outline_color_rgba)
, _fill_color_rgba(fill_color_rgba)
, _region(region)
+ , name_pixbuf_width (0)
, _line(0)
, _rect(0)
{
- /* XXX this connection is needed if ::on_event() is changed to actually do anything */
signal_event().connect (sigc::mem_fun (*this, &CanvasFlag::on_event));
}
void
CanvasFlag::delete_allocated_objects()
{
- delete _text;
- _text = 0;
+ delete _name_pixbuf;
+ _name_pixbuf = 0;
delete _line;
_line = 0;
@@ -41,29 +45,29 @@ CanvasFlag::delete_allocated_objects()
}
void
-CanvasFlag::set_text(const string& a_text)
+CanvasFlag::set_text (const string& text)
{
delete_allocated_objects();
- _text = new NoEventText (*this, 0.0, 0.0, a_text);
- _text->property_justification() = Gtk::JUSTIFY_CENTER;
- _text->property_fill_color_rgba() = _outline_color_rgba;
- _text->property_font_desc() = TimeAxisViewItem::NAME_FONT;
- double flagwidth = _text->property_text_width() + 10.0;
- double flagheight = _text->property_text_height() + 3.0;
- _text->property_x() = flagwidth / 2.0;
- _text->property_y() = flagheight / 2.0;
- _text->show();
+ _name_pixbuf = new ArdourCanvas::Pixbuf (*this);
+ name_pixbuf_width = Gtkmm2ext::pixel_width (text, TimeAxisViewItem::NAME_FONT) + 2;
+ Gdk::Color c;
+ set_color (c, _outline_color_rgba);
+ _name_pixbuf->property_pixbuf() = Gtkmm2ext::pixbuf_from_string (text, TimeAxisViewItem::NAME_FONT, name_pixbuf_width,
+ TimeAxisViewItem::NAME_HEIGHT, c);
+ _name_pixbuf->property_x() = 10.0;
+ _name_pixbuf->property_y() = 2.0;
+ _name_pixbuf->show();
+
+ double flagwidth = name_pixbuf_width + 8.0;
+ double flagheight = TimeAxisViewItem::NAME_HEIGHT + 3.0;
_line = new SimpleLine(*this, 0.0, 0.0, 0.0, _height);
_line->property_color_rgba() = _outline_color_rgba;
_rect = new SimpleRect(*this, 0.0, 0.0, flagwidth, flagheight);
_rect->property_outline_color_rgba() = _outline_color_rgba;
_rect->property_fill_color_rgba() = _fill_color_rgba;
- _text->raise_to_top();
- /* XXX these two connections are needed if ::on_event() is changed to actually do anything */
- //_rect->signal_event().connect (sigc::mem_fun (*this, &CanvasFlag::on_event));
- //_text->signal_event().connect (sigc::mem_fun (*this, &CanvasFlag::on_event));
+ _name_pixbuf->raise_to_top();
}
CanvasFlag::~CanvasFlag()