YAY! Colors are back!
[quassel.git] / src / qtui / chatitem.h
index b58dc03..2731a0c 100644 (file)
  *   59 Temple Place - Suite 330, Boston, MA  02111-1307, USA.             *
  ***************************************************************************/
 
-#ifndef _CHATITEM_H_
-#define _CHATITEM_H_
+#ifndef CHATITEM_H_
+#define CHATITEM_H_
 
 #include <QGraphicsItem>
-#include <QTextLayout>
-#include <QTextOption>
 
 #include "chatline.h"
 #include "chatlinemodel.h"
 #include "uistyle.h"
 
+class QTextLayout;
+
 class ChatItem : public QGraphicsItem {
 
   public:
@@ -39,7 +39,12 @@ class ChatItem : public QGraphicsItem {
     inline const MessageModel *model() const { return _index.isValid() ? qobject_cast<const MessageModel *>(_index.model()) : 0; }
     inline int row() const { return _index.isValid() ? _index.row() : 0; }
 
-    virtual QRectF boundingRect() const;
+    inline virtual QRectF boundingRect() const { return _boundingRect; }
+    inline qreal width() const { return _boundingRect.width(); }
+    inline qreal height() const { return _boundingRect.height(); }
+
+    inline bool haveLayout() const { return _layout != 0; }
+    void clearLayout();
     virtual void paint(QPainter *painter, const QStyleOptionGraphicsItem *option, QWidget *widget = 0);
 
     virtual QVariant data(int role) const;
@@ -49,17 +54,25 @@ class ChatItem : public QGraphicsItem {
     //QTextOption textOption() const;
     //void setTextOption(const QTextOption &option);
 
-    //void setWidth(int width);
+    // returns height
+    int setWidth(int width);
     //virtual void layout();
 
   protected:
     //void mouseMoveEvent ( QGraphicsSceneMouseEvent * event );
 
   private:
-    //int _width;
+    int heightForWidth(int width);
+    void layout();
+
+    int _lineHeight;
+    qreal _lineLeading;
+    QRectF _boundingRect;
     //QTextLayout _layout;
     //QTextOption _textOption;
     QPersistentModelIndex _index;
+
+    QTextLayout *_layout;
 };
 
 #endif