X-Git-Url: https://git.quassel-irc.org/?p=quassel.git;a=blobdiff_plain;f=src%2Fqtui%2Fcolumnhandleitem.cpp;h=e8dd97e2e91dc6acab465b771075441228f1d8eb;hp=8ab7331b7ed05e99cc2bb96a40b6da6943ef3b25;hb=0072d69c3387cad4e393968647e0f2894aed6877;hpb=9806418efa4c59dae71fd628ea9c57453ca81434 diff --git a/src/qtui/columnhandleitem.cpp b/src/qtui/columnhandleitem.cpp index 8ab7331b..e8dd97e2 100644 --- a/src/qtui/columnhandleitem.cpp +++ b/src/qtui/columnhandleitem.cpp @@ -31,18 +31,27 @@ ColumnHandleItem::ColumnHandleItem(qreal w, QGraphicsItem *parent) : QGraphicsItem(parent), _width(w), _hover(0), - _timeLine(150) + _timeLine(150), + _moving(false), + _minXPos(0), + _maxXPos(0) { setAcceptsHoverEvents(true); setZValue(10); setCursor(QCursor(Qt::OpenHandCursor)); - setFlag(ItemIsMovable); connect(&_timeLine, SIGNAL(valueChanged(qreal)), this, SLOT(hoverChanged(qreal))); } void ColumnHandleItem::setXPos(qreal xpos) { - setPos(xpos - width()/2, (qreal)0); + setPos(xpos - width()/2, 0); +} + +void ColumnHandleItem::setXLimits(qreal min, qreal max) { + _minXPos = min; + _maxXPos = max; + //if(x() < min) setPos(min, 0); + //else if(x() > max) setPos(max - width(), 0); } void ColumnHandleItem::sceneRectChanged(const QRectF &rect) { @@ -51,28 +60,37 @@ void ColumnHandleItem::sceneRectChanged(const QRectF &rect) { } void ColumnHandleItem::mouseMoveEvent(QGraphicsSceneMouseEvent *event) { - QGraphicsItem::mouseMoveEvent(event); + if(event->buttons() & Qt::LeftButton && _moving) { + if(contains(event->lastPos())) { + qreal newx = x() + (event->scenePos() - event->lastScenePos()).x(); + if(newx < _minXPos) newx = _minXPos; + else if(newx + width() > _maxXPos) newx = _maxXPos - width(); + setPos(newx, 0); + } + event->accept(); + } else { + event->ignore(); + } } -void ColumnHandleItem::mousePressEvent(QGraphicsSceneMouseEvent *event) { qDebug() << "pressed!"; - setCursor(QCursor(Qt::ClosedHandCursor)); - QGraphicsItem::mousePressEvent(event); +void ColumnHandleItem::mousePressEvent(QGraphicsSceneMouseEvent *event) { + if(event->buttons() & Qt::LeftButton) { + setCursor(QCursor(Qt::ClosedHandCursor)); + _moving = true; + event->accept(); + } else { + event->ignore(); + } } void ColumnHandleItem::mouseReleaseEvent(QGraphicsSceneMouseEvent *event) { - setCursor(QCursor(Qt::OpenHandCursor)); - QGraphicsItem::mouseReleaseEvent(event); -} - -void ColumnHandleItem::paint(QPainter *painter, const QStyleOptionGraphicsItem *option, QWidget *widget) { - Q_UNUSED(option); - Q_UNUSED(widget); - - QLinearGradient gradient(0, 0, width(), 0); - gradient.setColorAt(0.25, Qt::transparent); - gradient.setColorAt(0.5, QColor(0, 0, 0, _hover * 200)); - gradient.setColorAt(0.75, Qt::transparent); - painter->fillRect(boundingRect(), gradient); + if(_moving) { + _moving = false; + setCursor(QCursor(Qt::OpenHandCursor)); + event->accept(); + } else { + event->ignore(); + } } void ColumnHandleItem::hoverEnterEvent(QGraphicsSceneHoverEvent *event) { @@ -96,3 +114,14 @@ void ColumnHandleItem::hoverChanged(qreal value) { update(); } +void ColumnHandleItem::paint(QPainter *painter, const QStyleOptionGraphicsItem *option, QWidget *widget) { + Q_UNUSED(option); + Q_UNUSED(widget); + + QLinearGradient gradient(0, 0, width(), 0); + gradient.setColorAt(0.25, Qt::transparent); + gradient.setColorAt(0.5, QColor(0, 0, 0, _hover * 200)); + gradient.setColorAt(0.75, Qt::transparent); + painter->fillRect(boundingRect(), gradient); +} +