X-Git-Url: https://git.quassel-irc.org/?p=quassel.git;a=blobdiff_plain;f=src%2Fqtui%2Fchatline.h;h=724be7dcec78fb3177cd99902aad923e4d770ec3;hp=792563e1a92830cc07d2f04b0ddf33ebcb0cd4e2;hb=94be5fb31afd8f3befa8cb2cf1b3c2e5ef3cdba5;hpb=dd90a17f0cbafb646e1916d9b8a1f048331f3111 diff --git a/src/qtui/chatline.h b/src/qtui/chatline.h index 792563e1..724be7dc 100644 --- a/src/qtui/chatline.h +++ b/src/qtui/chatline.h @@ -18,32 +18,43 @@ * 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. * ***************************************************************************/ -#ifndef _CHATLINE_H_ -#define _CHATLINE_H_ +#ifndef CHATLINE_H_ +#define CHATLINE_H_ #include -#include "message.h" +#include "chatlinemodel.h" +#include "chatitem.h" class ChatLine : public QGraphicsItem { public: - ChatLine(const QPersistentModelIndex &, QGraphicsItem *parent = 0); - virtual ~ChatLine(); + ChatLine(int row, QAbstractItemModel *model, QGraphicsItem *parent = 0); virtual QRectF boundingRect () const; - virtual void paint (QPainter * painter, const QStyleOptionGraphicsItem *option, QWidget *widget = 0); - //void layout(); - //void setColumnWidths(int tsColWidth, int senderColWidth, int textColWidth); + inline int row() { return _row; } + inline void setRow(int row) { _row = row; } + inline qreal width() const { return _width; } + inline qreal height() const { return _height; } + ChatItem &item(ChatLineModel::ColumnType); + + virtual void paint (QPainter * painter, const QStyleOptionGraphicsItem *option, QWidget *widget = 0); - //void myMousePressEvent ( QGraphicsSceneMouseEvent * event ) { qDebug() << "press"; mousePressEvent(event); } + // returns height + qreal setGeometry(qreal width, qreal firstColPos, qreal secondColPos); + void setSelected(bool selected, ChatLineModel::ColumnType minColumn = ChatLineModel::ContentsColumn); + void setHighlighted(bool highlighted); protected: - //bool sceneEvent ( QEvent * event ); private: - QPersistentModelIndex _index; + int _row; + ChatItem _timestampItem, _senderItem, _contentsItem; + qreal _width, _height; + + enum { Selected = 0x40, Highlighted = 0x80 }; + quint8 _selection; // save space, so we put both the col and the flags into one byte }; #endif