X-Git-Url: https://git.quassel-irc.org/?p=quassel.git;a=blobdiff_plain;f=src%2Fqtui%2Fchatitem.h;h=3cf5a9b3e6465f1189c37a237cf8bbaf2e8b1ce0;hp=713d808d33be23812bd3953c915e2e32f5518176;hb=ae374ec02b44f508d207d2e69d800f26b34e0d9d;hpb=1183bd403b16d86ef59503185b9ab4d35eb8c93f diff --git a/src/qtui/chatitem.h b/src/qtui/chatitem.h index 713d808d..3cf5a9b3 100644 --- a/src/qtui/chatitem.h +++ b/src/qtui/chatitem.h @@ -55,11 +55,12 @@ class ChatItem : public QGraphicsItem { virtual QVariant data(int role) const; // returns height - int setWidth(int width); + qreal setWidth(qreal width); // selection stuff, to be called by the scene void clearSelection(); void setFullSelection(); + void continueSelecting(); protected: virtual void mouseMoveEvent(QGraphicsSceneMouseEvent *event); @@ -67,18 +68,24 @@ class ChatItem : public QGraphicsItem { virtual void mouseReleaseEvent(QGraphicsSceneMouseEvent *event); private: - int posToCursor(const QPointF &pos); - int heightForWidth(int width); + 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; quint8 _lines; QPersistentModelIndex _index; - QTextLayout *_layout; + QTextLayout * _layout; QList _wrapPositions; - int _selectionStart; + + enum SelectionMode { NoSelection, PartialSelection, FullSelection }; + SelectionMode _selectionMode; + qint16 _selectionStart, _selectionEnd; class WrapColumnFinder; }; @@ -88,15 +95,15 @@ 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; };