X-Git-Url: https://git.quassel-irc.org/?p=quassel.git;a=blobdiff_plain;f=src%2Fqtui%2Fchatview.h;h=51522d2355152920845b5e6c9306a2ee41618d4b;hp=5969f7282a45a534349ee299d073a64f2ccb5064;hb=b1d9c3ea56467245c910ac1de1252c2a91c234f0;hpb=d7a7c6e5242fd0f500b2c1c75579c9db81a91d0c diff --git a/src/qtui/chatview.h b/src/qtui/chatview.h index 5969f728..51522d23 100644 --- a/src/qtui/chatview.h +++ b/src/qtui/chatview.h @@ -42,14 +42,41 @@ 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(bool ignoreDayChange = false) const; + virtual void addActionsToMenu(QMenu *, const QPointF &pos); - virtual bool event(QEvent *event); + //! Tell the view that this ChatLine has cached data + /** ChatLines cache some layout data that should be cleared as soon as it's no + * longer visible. A ChatLine caching data registers itself with this method to + * tell the view about it. The view will call ChatLine::clearCache() when + * appropriate. + * \param line The ChatLine having cached data + */ + void setHasCache(ChatLine *line, bool hasCache = true); public slots: inline virtual void clear() {} @@ -57,17 +84,26 @@ public slots: void zoomOut(); void zoomOriginal(); + void setMarkerLineVisible(bool visible = true); + void setMarkerLine(MsgId msgId); + void jumpToMarkerLine(bool requestBacklog); + protected: + virtual bool event(QEvent *event); virtual void resizeEvent(QResizeEvent *event); + virtual void scrollContentsBy(int dx, int dy); 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 checkChatLineCaches(); void mouseMoveWhileSelecting(const QPointF &scenePos); void scrollTimerTimeout(); + void invalidateFilter(); + void markerLineSet(BufferId buffer, MsgId msg); private: void init(MessageFilter *filter); @@ -78,6 +114,8 @@ private: qreal _currentScaleFactor; QTimer _scrollTimer; int _scrollOffset; + bool _invalidateFilter; + QSet _linesWithCache; };