X-Git-Url: https://git.quassel-irc.org/?p=quassel.git;a=blobdiff_plain;f=src%2Fqtui%2Fcolumnhandleitem.h;h=f9d1f7ada0026cce541c46e1b7173a8ccc1ee997;hp=81c411ed3aa3beb6509442f8e0ee6590cc4a0d2d;hb=0072d69c3387cad4e393968647e0f2894aed6877;hpb=39e2a78383295f86c5aa2dadbeac6f02b53eb7a4 diff --git a/src/qtui/columnhandleitem.h b/src/qtui/columnhandleitem.h index 81c411ed..f9d1f7ad 100644 --- a/src/qtui/columnhandleitem.h +++ b/src/qtui/columnhandleitem.h @@ -21,31 +21,42 @@ #ifndef COLUMNHANDLEITEM_H_ #define COLUMNHANDLEITEM_H_ +#include #include +#include +#include -class ColumnHandleItem : public QGraphicsItem { +class ColumnHandleItem : public QObject, public QGraphicsItem { + Q_OBJECT - public: - ColumnHandleItem(qreal width, QGraphicsItem *parent = 0); +public: + ColumnHandleItem(qreal width, QGraphicsItem *parent = 0); - inline qreal width() const; - inline QRectF boundingRect() const; - void setXPos(qreal xpos); + inline qreal width() const { return _width; } + inline QRectF boundingRect() const { return QRectF(0, 0, _width, scene()->height()); } + void setXPos(qreal xpos); - virtual void paint(QPainter *painter, const QStyleOptionGraphicsItem *option, QWidget *widget = 0); + void paint(QPainter *painter, const QStyleOptionGraphicsItem *option, QWidget *widget = 0); - void sceneRectChanged(const QRectF &); + void sceneRectChanged(const QRectF &); + void setXLimits(qreal min, qreal max); - private: - qreal _width; -}; +protected: + void hoverEnterEvent(QGraphicsSceneHoverEvent *event); + void hoverLeaveEvent(QGraphicsSceneHoverEvent *event); + void mouseMoveEvent(QGraphicsSceneMouseEvent *event); + void mousePressEvent(QGraphicsSceneMouseEvent *event); + void mouseReleaseEvent(QGraphicsSceneMouseEvent *event); -qreal ColumnHandleItem::width() const { - return _width; -} +private slots: + void hoverChanged(qreal value); -QRectF ColumnHandleItem::boundingRect() const { - return QRectF(0, 0, _width, scene()->height()); -} +private: + qreal _width; + qreal _hover; + bool _moving; + qreal _minXPos, _maxXPos; + QTimeLine _timeLine; +}; #endif