setup (height, position);
}
-void
+void
Flag::setup (Distance height, Duple position)
{
_text = new Text (this);
void
Flag::set_text (string const & text)
{
- _text->set (text);
- boost::optional<Rect> bbox = _text->bounding_box ();
+ if (text == _text->text()) {
+ return;
+ } else if (text.empty ()) {
+ _text->set (" ");
+ } else {
+ _text->set (text);
+ }
+
+ Rect bbox = _text->bounding_box ();
assert (bbox);
- Duple flag_size (bbox.get().width() + 10, bbox.get().height() + 4);
-
+ Duple flag_size (bbox.width() + 10, bbox.height() + 4);
+
if (_invert) {
const Distance h = fabs(_line->y1() - _line->y0());
_text->set_position (Duple (5, h - flag_size.y + 2));
_line->set (Duple (0, 0), Duple (0, h));
if (_invert) {
- boost::optional<Rect> bbox = _text->bounding_box ();
+ Rect bbox = _text->bounding_box ();
if (bbox) {
- Duple flag_size (bbox.get().width() + 10, bbox.get().height() + 4);
+ Duple flag_size (bbox.width() + 10, bbox.height() + 4);
_rectangle->set (Rect (0, h - flag_size.y, flag_size.x, h));
_text->set_position (Duple (5, h - flag_size.y + 2));
}
{
if (_rectangle) {
return _rectangle->covers (point);
- }
+ }
return false;
}
+
+double
+Flag::width () const
+{
+ Rect bbox = _text->bounding_box ();
+ assert (bbox);
+
+ return bbox.width() + 10;
+}