Merge branch 'master' into cairocanvas
[ardour.git] / libs / canvas / canvas / text.h
index 6ae6d58a37297b818f7276c3e8eb56c416a8e8ee..59d2007ceba17d30828d9f2874eaac3318b70e2d 100644 (file)
 #include <pangomm/fontdescription.h>
 #include <pangomm/layout.h>
 
+#include "canvas/visibility.h"
 #include "canvas/item.h"
 
 namespace ArdourCanvas {
 
-class Text : public Item
+class LIBCANVAS_API Text : public Item
 {
 public:
        Text (Group *);
@@ -46,6 +47,8 @@ public:
         void set_size_chars (int nchars);
         void dump (std::ostream&) const;
 
+       std::string text() const { return _text; }
+
 private:
        std::string      _text;
        uint32_t         _color;
@@ -59,6 +62,8 @@ private:
         double _clamped_width;
 
         void redraw (Cairo::RefPtr<Cairo::Context>) const;
+        void redraw (Glib::RefPtr<Pango::Context>) const;
+        void _redraw (Glib::RefPtr<Pango::Layout>) const;
 };
 
 }