1 /***************************************************************************
2 * Copyright (C) 2005-09 by the Quassel Project *
3 * devel@quassel-irc.org *
5 * This program is free software; you can redistribute it and/or modify *
6 * it under the terms of the GNU General Public License as published by *
7 * the Free Software Foundation; either version 2 of the License, or *
8 * (at your option) version 3. *
10 * This program is distributed in the hope that it will be useful, *
11 * but WITHOUT ANY WARRANTY; without even the implied warranty of *
12 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the *
13 * GNU General Public License for more details. *
15 * You should have received a copy of the GNU General Public License *
16 * along with this program; if not, write to the *
17 * Free Software Foundation, Inc., *
18 * 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. *
19 ***************************************************************************/
24 #include <QGraphicsView>
27 #include "abstractbuffercontainer.h"
29 class AbstractBufferContainer;
37 class ChatView : public QGraphicsView, public AbstractChatView {
41 ChatView(MessageFilter *, QWidget *parent = 0);
42 ChatView(BufferId bufferId, QWidget *parent = 0);
44 virtual MsgId lastMsgId() const;
45 virtual MsgId lastVisibleMsgId() const;
46 inline AbstractBufferContainer *bufferContainer() const { return _bufferContainer; }
47 inline void setBufferContainer(AbstractBufferContainer *c) { _bufferContainer = c; }
49 inline ChatScene *scene() const { return _scene; }
51 //! Return a set of ChatLines currently visible in the view
52 /** \param mode How partially visible ChatLines are handled
53 * \return A set of visible ChatLines
55 QSet<ChatLine *> visibleChatLines(Qt::ItemSelectionMode mode = Qt::ContainsItemBoundingRect) const;
57 //! Return a sorted list of ChatLines currently visible in the view
58 /** \param mode How partially visible ChatLines are handled
59 * \return A list of visible ChatLines sorted by row
60 * \note If the order of ChatLines does not matter, use visibleChatLines() instead
62 QList<ChatLine *> visibleChatLinesSorted(Qt::ItemSelectionMode mode = Qt::ContainsItemBoundingRect) const;
64 //! Return the last fully visible ChatLine in this view
65 /** Using this method more efficient than calling visibleChatLinesSorted() and taking its last element.
66 * \return The last fully visible ChatLine in the view
68 ChatLine *lastVisibleChatLine(bool ignoreDayChange = false) const;
70 virtual void addActionsToMenu(QMenu *, const QPointF &pos);
72 //! Tell the view that this ChatLine has cached data
73 /** ChatLines cache some layout data that should be cleared as soon as it's no
74 * longer visible. A ChatLine caching data registers itself with this method to
75 * tell the view about it. The view will call ChatLine::clearCache() when
77 * \param line The ChatLine having cached data
79 void setHasCache(ChatLine *line, bool hasCache = true);
82 inline virtual void clear() {}
87 void setMarkerLineVisible(bool visible = true);
88 void setMarkerLine(MsgId msgId);
89 void jumpToMarkerLine(bool requestBacklog);
92 virtual bool event(QEvent *event);
93 virtual void resizeEvent(QResizeEvent *event);
94 virtual void scrollContentsBy(int dx, int dy);
97 virtual void verticalScrollbarChanged(int);
100 void lastLineChanged(QGraphicsItem *chatLine, qreal offset);
101 void adjustSceneRect();
102 void checkChatLineCaches();
103 void mouseMoveWhileSelecting(const QPointF &scenePos);
104 void scrollTimerTimeout();
105 void invalidateFilter();
106 void markerLineSet(BufferId buffer, MsgId msg);
109 void init(MessageFilter *filter);
111 AbstractBufferContainer *_bufferContainer;
113 int _lastScrollbarPos;
114 qreal _currentScaleFactor;
117 bool _invalidateFilter;
118 QSet<ChatLine *> _linesWithCache;