f03a87a132
* made changes in editor_canvas_events.cc to forward events to CanvasFlag (against pauls advice), but IMHO it doesnt add complexity to it since it only adds a few trivial lines which do the same which has already been done for CanvasNote and thus shouldnt complicate the merge in any way git-svn-id: svn://localhost/ardour2/branches/3.0@4314 d708f5d6-7413-0410-9779-e7cbd77b26cf
61 lines
1.3 KiB
C++
61 lines
1.3 KiB
C++
#include "canvas-flag.h"
|
|
#include <iostream>
|
|
#include "ardour_ui.h"
|
|
|
|
using namespace Gnome::Canvas;
|
|
using namespace std;
|
|
|
|
|
|
void
|
|
CanvasFlag::delete_allocated_objects()
|
|
{
|
|
if (_text) {
|
|
delete _text;
|
|
_text = 0;
|
|
}
|
|
|
|
if (_line) {
|
|
delete _line;
|
|
_line = 0;
|
|
}
|
|
|
|
if (_rect) {
|
|
delete _rect;
|
|
_rect = 0;
|
|
}
|
|
}
|
|
|
|
void
|
|
CanvasFlag::set_text(string& a_text)
|
|
{
|
|
delete_allocated_objects();
|
|
|
|
_text = new CanvasFlagText(*this, 0.0, 0.0, Glib::ustring(a_text));
|
|
_text->property_justification() = Gtk::JUSTIFY_CENTER;
|
|
_text->property_fill_color_rgba() = _outline_color_rgba;
|
|
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();
|
|
_line = new SimpleLine(*this, 0.0, 0.0, 0.0, _height);
|
|
_line->property_color_rgba() = _outline_color_rgba;
|
|
_rect = new CanvasFlagRect(*this, 0.0, 0.0, flagwidth, flagheight);
|
|
_rect->property_outline_color_rgba() = _outline_color_rgba;
|
|
_rect->property_fill_color_rgba() = _fill_color_rgba;
|
|
_text->lower_to_bottom();
|
|
_text->raise(2);
|
|
}
|
|
|
|
CanvasFlag::~CanvasFlag()
|
|
{
|
|
delete_allocated_objects();
|
|
}
|
|
|
|
bool
|
|
CanvasFlag::on_event(GdkEvent* ev)
|
|
{
|
|
cerr << "CanvasFlag::on_event(GdkEvent* ev)" << endl;
|
|
return false;
|
|
}
|