X-Git-Url: https://git.quassel-irc.org/?a=blobdiff_plain;ds=sidebyside;f=src%2Fqtui%2Fchatview.h;h=3f9e29c96e7c97ac8ace60074343943b1276288b;hb=e19eef8ec30a926e5a847a7570bb966bc86f602e;hp=5969f7282a45a534349ee299d073a64f2ccb5064;hpb=d7a7c6e5242fd0f500b2c1c75579c9db81a91d0c;p=quassel.git diff --git a/src/qtui/chatview.h b/src/qtui/chatview.h index 5969f728..3f9e29c9 100644 --- a/src/qtui/chatview.h +++ b/src/qtui/chatview.h @@ -42,32 +42,60 @@ public: ChatView(BufferId bufferId, QWidget *parent = 0); virtual MsgId lastMsgId() const; + virtual MsgId lastVisibleMsgId() const; inline AbstractBufferContainer *bufferContainer() const { return _bufferContainer; } inline void setBufferContainer(AbstractBufferContainer *c) { _bufferContainer = c; } inline ChatScene *scene() const { return _scene; } + //! Return a set of ChatLines currently visible in the view + /** \param mode How partially visible ChatLines are handled + * \return A set of visible ChatLines + */ + QSet visibleChatLines(Qt::ItemSelectionMode mode = Qt::ContainsItemBoundingRect) const; + + //! Return a sorted list of ChatLines currently visible in the view + /** \param mode How partially visible ChatLines are handled + * \return A list of visible ChatLines sorted by row + * \note If the order of ChatLines does not matter, use visibleChatLines() instead + */ + QList visibleChatLinesSorted(Qt::ItemSelectionMode mode = Qt::ContainsItemBoundingRect) const; + + //! Return the last fully visible ChatLine in this view + /** Using this method more efficient than calling visibleChatLinesSorted() and taking its last element. + * \return The last fully visible ChatLine in the view + */ + ChatLine *lastVisibleChatLine() const; + virtual void addActionsToMenu(QMenu *, const QPointF &pos); virtual bool event(QEvent *event); + inline bool isMarkerLineVisible() const { return _markerLineVisible; } + inline ChatLine *markedLine() const { return _markedLine; } + public slots: inline virtual void clear() {} void zoomIn(); void zoomOut(); void zoomOriginal(); + void setMarkerLineVisible(bool visible = true); + void setMarkedLine(ChatLine *line); + protected: virtual void resizeEvent(QResizeEvent *event); protected slots: - virtual inline void sceneRectChanged(const QRectF &rect) { setSceneRect(rect); } virtual void verticalScrollbarChanged(int); private slots: void lastLineChanged(QGraphicsItem *chatLine, qreal offset); + void adjustSceneRect(); void mouseMoveWhileSelecting(const QPointF &scenePos); void scrollTimerTimeout(); + void invalidateFilter(); + void markerLineSet(BufferId buffer, MsgId msg); private: void init(MessageFilter *filter); @@ -78,6 +106,9 @@ private: qreal _currentScaleFactor; QTimer _scrollTimer; int _scrollOffset; + bool _invalidateFilter; + bool _markerLineVisible; + ChatLine *_markedLine; };