X-Git-Url: https://git.quassel-irc.org/?p=quassel.git;a=blobdiff_plain;f=src%2Fqtui%2Fchatitem.h;h=678c3c6fefe97f796f84a03a1d88c4fc3ff3da6f;hp=73e180670d1fcf231dfa7be393d2297c7dd30d47;hb=64735bfd46695ec6980195e50a4f167a64a9d3ab;hpb=275c435910183d8a0755fd360a8a4e2a045cbca2 diff --git a/src/qtui/chatitem.h b/src/qtui/chatitem.h index 73e18067..678c3c6f 100644 --- a/src/qtui/chatitem.h +++ b/src/qtui/chatitem.h @@ -22,54 +22,88 @@ #define CHATITEM_H_ #include +#include -#include "chatline.h" #include "chatlinemodel.h" +#include "chatscene.h" #include "uistyle.h" +#include "qtui.h" class QTextLayout; class ChatItem : public QGraphicsItem { public: - ChatItem(const QPersistentModelIndex &index, QGraphicsItem *parent); + ChatItem(int col, QAbstractItemModel *, QGraphicsItem *parent); virtual ~ChatItem(); - inline QPersistentModelIndex index() const { return _index; } - inline const MessageModel *model() const { return _index.isValid() ? qobject_cast(_index.model()) : 0; } - inline int row() const { return _index.isValid() ? _index.row() : 0; } + inline const QAbstractItemModel *model() const { return chatScene() ? chatScene()->model() : 0; } + int row() const; + inline int column() const { return _col; } + inline ChatScene *chatScene() const { return qobject_cast(scene()); } inline QFontMetricsF *fontMetrics() const { return _fontMetrics; } 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(); + inline bool haveLayout() const { return _layoutData != 0 && layout() != 0; } + void clearLayoutData(); void updateLayout(); virtual void paint(QPainter *painter, const QStyleOptionGraphicsItem *option, QWidget *widget = 0); virtual QVariant data(int role) const; // returns height - int setWidth(int width); + qreal setGeometry(qreal width, qreal height = -1); + + // selection stuff, to be called by the scene + void clearSelection(); + void setFullSelection(); + void continueSelecting(const QPointF &pos); protected: - //void mouseMoveEvent ( QGraphicsSceneMouseEvent * event ); + virtual void mouseMoveEvent(QGraphicsSceneMouseEvent *event); + virtual void mousePressEvent(QGraphicsSceneMouseEvent *event); + virtual void mouseReleaseEvent(QGraphicsSceneMouseEvent *event); + virtual void mouseDoubleClickEvent(QGraphicsSceneMouseEvent *event); + + virtual void hoverEnterEvent(QGraphicsSceneHoverEvent *event); + virtual void hoverLeaveEvent(QGraphicsSceneHoverEvent *event); + virtual void hoverMoveEvent(QGraphicsSceneHoverEvent *event); private: - int heightForWidth(int width); + struct LayoutData; + class WrapColumnFinder; + + inline QTextLayout *layout() const; + void setLayout(QTextLayout *); + qint16 posToCursor(const QPointF &pos); + qreal computeHeight(); QTextLayout *createLayout(QTextOption::WrapMode, Qt::Alignment = Qt::AlignLeft); + // internal selection stuff + void setSelection(int start, int length); + QRectF _boundingRect; QFontMetricsF *_fontMetrics; + int _col; quint8 _lines; - QPersistentModelIndex _index; - QTextLayout *_layout; QList _wrapPositions; - class WrapColumnFinder; + enum SelectionMode { NoSelection, PartialSelection, FullSelection }; + SelectionMode _selectionMode; + qint16 _selectionStart, _selectionEnd; + + LayoutData *_layoutData; +}; + +struct ChatItem::LayoutData { + QTextLayout *layout; + + LayoutData() { layout = 0; } + ~LayoutData() { delete layout; } }; class ChatItem::WrapColumnFinder { @@ -77,17 +111,21 @@ class ChatItem::WrapColumnFinder { WrapColumnFinder(ChatItem *parent); ~WrapColumnFinder(); - int nextWrapColumn(); + qint16 nextWrapColumn(); private: ChatItem *item; QTextLayout *layout; QTextLine line; ChatLineModel::WrapList wrapList; - int wordidx; - int lastwrapcol; + qint16 wordidx; + qint16 lastwrapcol; qreal lastwrappos; qreal w; }; +#include "chatline.h" +inline int ChatItem::row() const { return static_cast(parentItem())->row(); } +inline QTextLayout *ChatItem::layout() const { return _layoutData->layout; } + #endif