X-Git-Url: https://git.quassel-irc.org/?a=blobdiff_plain;f=src%2Fqtui%2Fchatscene.h;h=cd71aac833aa2f8fc3bacbd956891d2bd9b942ba;hb=b8393cf7150270830deb26e9621f642ffff77d4c;hp=a1a32d101e676a2ac9bd8b9b51161ef785672050;hpb=5b0af9082dcf0672a98391ac12c6e6bbaaff7a64;p=quassel.git diff --git a/src/qtui/chatscene.h b/src/qtui/chatscene.h index a1a32d10..cd71aac8 100644 --- a/src/qtui/chatscene.h +++ b/src/qtui/chatscene.h @@ -23,6 +23,7 @@ #include #include +#include class AbstractUiMsg; class Buffer; @@ -36,32 +37,54 @@ class ChatScene : public QGraphicsScene { Q_OBJECT public: - ChatScene(QAbstractItemModel *model, QObject *parent); + ChatScene(QAbstractItemModel *model, const QString &idString, QObject *parent); virtual ~ChatScene(); Buffer *buffer() const; inline QAbstractItemModel *model() const { return _model; } + inline QString idString() const { return _idString; } public slots: void setWidth(qreal); - private slots: - void rectChanged(const QRectF &); - void handlePositionChanged(qreal xpos); + // these are used by the chatitems to notify the scene and manage selections + void setSelectingItem(ChatItem *item); + ChatItem *selectingItem() const { return _selectingItem; } + void startGlobalSelection(ChatItem *item, const QPointF &itemPos); signals: void heightChanged(qreal height); + protected: + virtual void mouseMoveEvent(QGraphicsSceneMouseEvent *mouseEvent); + virtual void mousePressEvent(QGraphicsSceneMouseEvent *mouseEvent); + virtual void mouseReleaseEvent(QGraphicsSceneMouseEvent *mouseEvent); + protected slots: void rowsInserted(const QModelIndex &, int, int); + private slots: + void rectChanged(const QRectF &); + void handlePositionChanged(qreal xpos); + private: + void updateSelection(const QPointF &pos); + QString selectionToString() const; + + QString _idString; qreal _width, _height; QAbstractItemModel *_model; QList _lines; ColumnHandleItem *firstColHandle, *secondColHandle; qreal firstColHandlePos, secondColHandlePos; + + ChatItem *_selectingItem, *_lastItem; + QSet _selectedItems; + int _selectionStartCol, _selectionMinCol; + int _selectionStart; + int _selectionEnd; + bool _isSelecting; }; #endif