X-Git-Url: https://git.quassel-irc.org/?p=quassel.git;a=blobdiff_plain;f=src%2Fqtui%2Fchatscene.h;h=41fb51a97c2f6c43a8f177f8a406a3a902365713;hp=7ef50d92119d6cd9655130718adaf54d8fea0729;hb=db511df7b183771ae444f14d0aca42381ee0ae37;hpb=f64ded9b73ed4eb09d3e2c14cddc0ead1e269185 diff --git a/src/qtui/chatscene.h b/src/qtui/chatscene.h index 7ef50d92..41fb51a9 100644 --- a/src/qtui/chatscene.h +++ b/src/qtui/chatscene.h @@ -22,6 +22,7 @@ #define CHATSCENE_H_ #include +#include #include #include #include @@ -61,10 +62,10 @@ public: enum ClickMode { NoClick, + DragStartClick, SingleClick, DoubleClick, - TripleClick, - DragStartClick + TripleClick }; ChatScene(QAbstractItemModel *model, const QString &idString, qreal width, ChatView *parent); @@ -73,17 +74,18 @@ public: inline QAbstractItemModel *model() const { return _model; } inline QString idString() const { return _idString; } - int rowByScenePos(qreal y); - inline int rowByScenePos(const QPointF &pos) { return rowByScenePos(pos.y()); } - ChatLineModel::ColumnType columnByScenePos(qreal x); - inline ChatLineModel::ColumnType columnByScenePos(const QPointF &pos) { return columnByScenePos(pos.x()); } + int rowByScenePos(qreal y) const; + inline int rowByScenePos(const QPointF &pos) const { return rowByScenePos(pos.y()); } + ChatLineModel::ColumnType columnByScenePos(qreal x) const ; + inline ChatLineModel::ColumnType columnByScenePos(const QPointF &pos) const { return columnByScenePos(pos.x()); } ChatView *chatView() const; ChatItem *chatItemAt(const QPointF &pos) const; + inline ChatLine *chatLine(int row) { return (row < _lines.count()) ? _lines[row] : 0; } - inline bool isSingleBufferScene() const { return _singleBufferScene; } + inline bool isSingleBufferScene() const { return _singleBufferId.isValid(); } + inline BufferId singleBufferId() const { return _singleBufferId; } bool containsBuffer(const BufferId &id) const; - inline ChatLine *chatLine(int row) { return (row < _lines.count()) ? _lines[row] : 0; } ColumnHandleItem *firstColumnHandle() const; ColumnHandleItem *secondColumnHandle() const; @@ -92,9 +94,10 @@ public: inline void setSenderCutoffMode(CutoffMode mode) { _cutoffMode = mode; } QString selection() const; - inline bool hasGlobalSelection() const { return _selectionStart >= 0; } - inline bool isGloballySelecting() const { return _isSelecting; } + bool hasSelection() const; + bool hasGlobalSelection() const; bool isPosOverSelection(const QPointF &) const; + bool isGloballySelecting() const; void initiateDrag(QWidget *source); bool isScrollingAllowed() const; @@ -111,8 +114,8 @@ public: void startGlobalSelection(ChatItem *item, const QPointF &itemPos); void clearGlobalSelection(); void clearSelection(); - - void putToClipboard(const QString &); + void selectionToClipboard(QClipboard::Mode = QClipboard::Clipboard); + void stringToClipboard(const QString &str, QClipboard::Mode = QClipboard::Clipboard); void requestBacklog(); @@ -125,6 +128,7 @@ signals: void mouseMoveWhileSelecting(const QPointF &scenePos); protected: + virtual void contextMenuEvent(QGraphicsSceneContextMenuEvent *contextMenuEvent); virtual void mouseMoveEvent(QGraphicsSceneMouseEvent *mouseEvent); virtual void mousePressEvent(QGraphicsSceneMouseEvent *mouseEvent); virtual void mouseReleaseEvent(QGraphicsSceneMouseEvent *mouseEvent); @@ -152,7 +156,7 @@ private: QString _idString; QAbstractItemModel *_model; QList _lines; - bool _singleBufferScene; + BufferId _singleBufferId; // calls to QChatScene::sceneRect() are very expensive. As we manage the scenerect ourselves // we store the size in a member variable. @@ -174,14 +178,14 @@ private: int _firstSelectionRow; bool _isSelecting; - bool _showWebPreview; - QTimer _clickTimer; ClickMode _clickMode; QPointF _clickPos; bool _clickHandled; bool _leftButtonPressed; + bool _showWebPreview; + struct WebPreview { ChatItem *parentItem; QGraphicsItem *previewItem;