X-Git-Url: https://git.quassel-irc.org/?p=quassel.git;a=blobdiff_plain;f=src%2Fqtui%2Fchatscene.h;h=45ab0f40bfe62ff5c40801e73b5c9a7ce9b01f5b;hp=c69f0e12402509196b53a5a1bc06ed7793bc778f;hb=e920325766f65e66132c20e4cb1da8f8e3f5e030;hpb=9d52e49424afb60c2f28073051c1dbf25f47adec diff --git a/src/qtui/chatscene.h b/src/qtui/chatscene.h index c69f0e12..45ab0f40 100644 --- a/src/qtui/chatscene.h +++ b/src/qtui/chatscene.h @@ -18,21 +18,19 @@ * 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. * ***************************************************************************/ -#ifndef _CHATSCENE_H_ -#define _CHATSCENE_H_ +#ifndef CHATSCENE_H_ +#define CHATSCENE_H_ #include #include #include -#include "types.h" +#include "columnhandleitem.h" + class AbstractUiMsg; -class Buffer; -class BufferId; class ChatItem; class ChatLine; -class ColumnHandleItem; class QGraphicsSceneMouseEvent; @@ -46,11 +44,13 @@ class ChatScene : public QGraphicsScene { inline QAbstractItemModel *model() const { return _model; } inline QString idString() const { return _idString; } - inline bool isFetchingBacklog() const; - inline bool isBacklogFetchingEnabled() const; - inline BufferId bufferForBacklogFetching() const; int sectionByScenePos(int x); inline int sectionByScenePos(const QPoint &pos) { return sectionByScenePos(pos.x()); } + inline bool isSingleBufferScene() const { return _singleBufferScene; } + inline ChatLine *chatLine(int row) { return (row < _lines.count()) ? _lines[row] : 0; } + + inline QRectF firstColumnHandleRect() const { return firstColHandle->boundingRect().translated(firstColHandle->x(), 0); } + inline QRectF secondColumnHandleRect() const { return secondColHandle->boundingRect().translated(secondColHandle->x(), 0); } public slots: void setWidth(qreal); @@ -59,12 +59,13 @@ class ChatScene : public QGraphicsScene { void setSelectingItem(ChatItem *item); ChatItem *selectingItem() const { return _selectingItem; } void startGlobalSelection(ChatItem *item, const QPointF &itemPos); + void putToClipboard(const QString &); - void setIsFetchingBacklog(bool); - inline void setBufferForBacklogFetching(BufferId buffer); + void requestBacklog(); signals: void heightChanged(qreal height); + void heightChangedAt(qreal ypos, qreal hdiff); protected: virtual void mouseMoveEvent(QGraphicsSceneMouseEvent *mouseEvent); @@ -73,52 +74,34 @@ class ChatScene : public QGraphicsScene { protected slots: void rowsInserted(const QModelIndex &, int, int); - void modelReset(); + void rowsAboutToBeRemoved(const QModelIndex &, int, int); private slots: void rectChanged(const QRectF &); void handlePositionChanged(qreal xpos); private: + void setHandleXLimits(); void updateSelection(const QPointF &pos); QString selectionToString() const; - void requestBacklogIfNeeded(); QString _idString; qreal _width, _height; QAbstractItemModel *_model; QList _lines; + bool _singleBufferScene; ColumnHandleItem *firstColHandle, *secondColHandle; qreal firstColHandlePos, secondColHandlePos; - ChatItem *_selectingItem, *_lastItem; - QSet _selectedItems; + ChatItem *_selectingItem; int _selectionStartCol, _selectionMinCol; int _selectionStart; int _selectionEnd; + int _firstSelectionRow, _lastSelectionRow; bool _isSelecting; - bool _fetchingBacklog; - BufferId _backlogFetchingBuffer; - MsgId _lastBacklogOffset; int _lastBacklogSize; }; -bool ChatScene::isFetchingBacklog() const { - return _fetchingBacklog; -} - -bool ChatScene::isBacklogFetchingEnabled() const { - return _backlogFetchingBuffer.isValid(); -} - -BufferId ChatScene::bufferForBacklogFetching() const { - return _backlogFetchingBuffer; -} - -void ChatScene::setBufferForBacklogFetching(BufferId buf) { - _backlogFetchingBuffer = buf; -} - #endif