since widget can be deleted from the outside use a weak pointer
svn path=/trunk/KDE/kdelibs/; revision=1062742
This commit is contained in:
parent
5ae8cde6c2
commit
2165a85a9f
@ -45,7 +45,6 @@ class ScrollWidgetPrivate
|
|||||||
public:
|
public:
|
||||||
ScrollWidgetPrivate(ScrollWidget *parent)
|
ScrollWidgetPrivate(ScrollWidget *parent)
|
||||||
: q(parent),
|
: q(parent),
|
||||||
widget(0),
|
|
||||||
topBorder(0),
|
topBorder(0),
|
||||||
bottomBorder(0),
|
bottomBorder(0),
|
||||||
leftBorder(0),
|
leftBorder(0),
|
||||||
@ -61,7 +60,11 @@ public:
|
|||||||
|
|
||||||
void adjustScrollbars()
|
void adjustScrollbars()
|
||||||
{
|
{
|
||||||
verticalScrollBar->nativeWidget()->setMaximum(qMax(0, int((widget->size().height() - scrollingWidget->size().height())/10)));
|
if (!widget) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
verticalScrollBar->nativeWidget()->setMaximum(qMax(0, int((widget.data()->size().height() - scrollingWidget->size().height())/10)));
|
||||||
|
|
||||||
if (verticalScrollBarPolicy == Qt::ScrollBarAlwaysOff ||
|
if (verticalScrollBarPolicy == Qt::ScrollBarAlwaysOff ||
|
||||||
verticalScrollBar->nativeWidget()->maximum() == 0) {
|
verticalScrollBar->nativeWidget()->maximum() == 0) {
|
||||||
@ -76,7 +79,7 @@ public:
|
|||||||
verticalScrollBar->show();
|
verticalScrollBar->show();
|
||||||
}
|
}
|
||||||
|
|
||||||
horizontalScrollBar->nativeWidget()->setMaximum(qMax(0, int((widget->size().width() - scrollingWidget->size().width())/10)));
|
horizontalScrollBar->nativeWidget()->setMaximum(qMax(0, int((widget.data()->size().width() - scrollingWidget->size().width())/10)));
|
||||||
|
|
||||||
if (horizontalScrollBarPolicy == Qt::ScrollBarAlwaysOff ||
|
if (horizontalScrollBarPolicy == Qt::ScrollBarAlwaysOff ||
|
||||||
horizontalScrollBar->nativeWidget()->maximum() == 0) {
|
horizontalScrollBar->nativeWidget()->maximum() == 0) {
|
||||||
@ -91,7 +94,7 @@ public:
|
|||||||
horizontalScrollBar->show();
|
horizontalScrollBar->show();
|
||||||
}
|
}
|
||||||
|
|
||||||
if (widget && !topBorder && widget->size().height() > q->size().height()) {
|
if (widget && !topBorder && widget.data()->size().height() > q->size().height()) {
|
||||||
topBorder = new Plasma::SvgWidget(q);
|
topBorder = new Plasma::SvgWidget(q);
|
||||||
topBorder->setSvg(borderSvg);
|
topBorder->setSvg(borderSvg);
|
||||||
topBorder->setElementID("border-top");
|
topBorder->setElementID("border-top");
|
||||||
@ -104,7 +107,7 @@ public:
|
|||||||
bottomBorder->setZValue(900);
|
bottomBorder->setZValue(900);
|
||||||
bottomBorder->resize(bottomBorder->effectiveSizeHint(Qt::PreferredSize));
|
bottomBorder->resize(bottomBorder->effectiveSizeHint(Qt::PreferredSize));
|
||||||
bottomBorder->show();
|
bottomBorder->show();
|
||||||
} else if (topBorder && widget && widget->size().height() <= q->size().height()) {
|
} else if (topBorder && widget && widget.data()->size().height() <= q->size().height()) {
|
||||||
//FIXME: in some cases topBorder->deleteLater() is deleteNever(), why?
|
//FIXME: in some cases topBorder->deleteLater() is deleteNever(), why?
|
||||||
topBorder->hide();
|
topBorder->hide();
|
||||||
bottomBorder->hide();
|
bottomBorder->hide();
|
||||||
@ -115,7 +118,7 @@ public:
|
|||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
if (widget && !leftBorder && widget->size().width() > q->size().width()) {
|
if (widget && !leftBorder && widget.data()->size().width() > q->size().width()) {
|
||||||
leftBorder = new Plasma::SvgWidget(q);
|
leftBorder = new Plasma::SvgWidget(q);
|
||||||
leftBorder->setSvg(borderSvg);
|
leftBorder->setSvg(borderSvg);
|
||||||
leftBorder->setElementID("border-left");
|
leftBorder->setElementID("border-left");
|
||||||
@ -128,7 +131,7 @@ public:
|
|||||||
rightBorder->setZValue(900);
|
rightBorder->setZValue(900);
|
||||||
rightBorder->resize(rightBorder->effectiveSizeHint(Qt::PreferredSize));
|
rightBorder->resize(rightBorder->effectiveSizeHint(Qt::PreferredSize));
|
||||||
rightBorder->show();
|
rightBorder->show();
|
||||||
} else if (leftBorder && widget && widget->size().width() <= q->size().width()) {
|
} else if (leftBorder && widget && widget.data()->size().width() <= q->size().width()) {
|
||||||
leftBorder->hide();
|
leftBorder->hide();
|
||||||
rightBorder->hide();
|
rightBorder->hide();
|
||||||
leftBorder->deleteLater();
|
leftBorder->deleteLater();
|
||||||
@ -150,46 +153,62 @@ public:
|
|||||||
rightBorder->setPos(q->size().width() - rightBorder->size().width(), 0);
|
rightBorder->setPos(q->size().width() - rightBorder->size().width(), 0);
|
||||||
}
|
}
|
||||||
|
|
||||||
QSizeF widgetSize = widget->size();
|
QSizeF widgetSize = widget.data()->size();
|
||||||
if (widget->sizePolicy().expandingDirections() & Qt::Horizontal) {
|
if (widget.data()->sizePolicy().expandingDirections() & Qt::Horizontal) {
|
||||||
//keep a 1 pixel border
|
//keep a 1 pixel border
|
||||||
widgetSize.setWidth(scrollingWidget->size().width()-borderSize);
|
widgetSize.setWidth(scrollingWidget->size().width()-borderSize);
|
||||||
}
|
}
|
||||||
if (widget->sizePolicy().expandingDirections() & Qt::Vertical) {
|
if (widget.data()->sizePolicy().expandingDirections() & Qt::Vertical) {
|
||||||
widgetSize.setHeight(scrollingWidget->size().height()-borderSize);
|
widgetSize.setHeight(scrollingWidget->size().height()-borderSize);
|
||||||
}
|
}
|
||||||
widget->resize(widgetSize);
|
widget.data()->resize(widgetSize);
|
||||||
}
|
}
|
||||||
|
|
||||||
void verticalScroll(int value)
|
void verticalScroll(int value)
|
||||||
{
|
{
|
||||||
|
if (!widget) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
if (!dragging) {
|
if (!dragging) {
|
||||||
widget->setPos(QPoint(widget->pos().x(), -value*10));
|
widget.data()->setPos(QPoint(widget.data()->pos().x(), -value*10));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
void horizontalScroll(int value)
|
void horizontalScroll(int value)
|
||||||
{
|
{
|
||||||
|
if (!widget) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
if (!dragging) {
|
if (!dragging) {
|
||||||
widget->setPos(QPoint(-value*10, widget->pos().y()));
|
widget.data()->setPos(QPoint(-value*10, widget.data()->pos().y()));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
void adjustClipping()
|
void adjustClipping()
|
||||||
{
|
{
|
||||||
const bool clip = widget->size().width() > scrollingWidget->size().width() || widget->size().height() > scrollingWidget->size().height();
|
if (!widget) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
const bool clip = widget.data()->size().width() > scrollingWidget->size().width() || widget.data()->size().height() > scrollingWidget->size().height();
|
||||||
|
|
||||||
scrollingWidget->setFlag(QGraphicsItem::ItemClipsChildrenToShape, clip);
|
scrollingWidget->setFlag(QGraphicsItem::ItemClipsChildrenToShape, clip);
|
||||||
}
|
}
|
||||||
|
|
||||||
void makeRectVisible()
|
void makeRectVisible()
|
||||||
{
|
{
|
||||||
|
if (!widget) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
QRectF viewRect = scrollingWidget->boundingRect();
|
QRectF viewRect = scrollingWidget->boundingRect();
|
||||||
//ensure the rect is not outside the widget bounding rect
|
//ensure the rect is not outside the widget bounding rect
|
||||||
QRectF mappedRect = QRectF(QPointF(qBound((qreal)0.0, rectToBeVisible.x(), widget->size().width() - rectToBeVisible.width()),
|
QRectF mappedRect = QRectF(QPointF(qBound((qreal)0.0, rectToBeVisible.x(), widget.data()->size().width() - rectToBeVisible.width()),
|
||||||
qBound((qreal)0.0, rectToBeVisible.y(), widget->size().height() - rectToBeVisible.height())),
|
qBound((qreal)0.0, rectToBeVisible.y(), widget.data()->size().height() - rectToBeVisible.height())),
|
||||||
rectToBeVisible.size());
|
rectToBeVisible.size());
|
||||||
mappedRect = widget->mapToItem(scrollingWidget, mappedRect).boundingRect();
|
mappedRect = widget.data()->mapToItem(scrollingWidget, mappedRect).boundingRect();
|
||||||
|
|
||||||
if (viewRect.contains(mappedRect)) {
|
if (viewRect.contains(mappedRect)) {
|
||||||
return;
|
return;
|
||||||
@ -210,13 +229,17 @@ public:
|
|||||||
}
|
}
|
||||||
|
|
||||||
animId = Animator::self()->moveItem(
|
animId = Animator::self()->moveItem(
|
||||||
widget, Plasma::Animator::SlideOutMovement,
|
widget.data(), Plasma::Animator::SlideOutMovement,
|
||||||
(widget->pos() + delta).toPoint());
|
(widget.data()->pos() + delta).toPoint());
|
||||||
}
|
}
|
||||||
|
|
||||||
void makeItemVisible()
|
void makeItemVisible()
|
||||||
{
|
{
|
||||||
QRectF rect(widget->mapFromScene(itemToBeVisible->scenePos()), itemToBeVisible->boundingRect().size());
|
if (!widget) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
QRectF rect(widget.data()->mapFromScene(itemToBeVisible->scenePos()), itemToBeVisible->boundingRect().size());
|
||||||
rectToBeVisible = rect;
|
rectToBeVisible = rect;
|
||||||
|
|
||||||
makeRectVisible();
|
makeRectVisible();
|
||||||
@ -229,7 +252,7 @@ public:
|
|||||||
|
|
||||||
ScrollWidget *q;
|
ScrollWidget *q;
|
||||||
QGraphicsWidget *scrollingWidget;
|
QGraphicsWidget *scrollingWidget;
|
||||||
QGraphicsWidget *widget;
|
QWeakPointer<QGraphicsWidget> widget;
|
||||||
Plasma::Svg *borderSvg;
|
Plasma::Svg *borderSvg;
|
||||||
Plasma::SvgWidget *topBorder;
|
Plasma::SvgWidget *topBorder;
|
||||||
Plasma::SvgWidget *bottomBorder;
|
Plasma::SvgWidget *bottomBorder;
|
||||||
@ -289,9 +312,9 @@ ScrollWidget::~ScrollWidget()
|
|||||||
|
|
||||||
void ScrollWidget::setWidget(QGraphicsWidget *widget)
|
void ScrollWidget::setWidget(QGraphicsWidget *widget)
|
||||||
{
|
{
|
||||||
if (d->widget && d->widget != widget) {
|
if (d->widget && d->widget.data() != widget) {
|
||||||
d->widget->removeEventFilter(this);
|
d->widget.data()->removeEventFilter(this);
|
||||||
delete d->widget;
|
delete d->widget.data();
|
||||||
}
|
}
|
||||||
|
|
||||||
d->widget = widget;
|
d->widget = widget;
|
||||||
@ -309,7 +332,7 @@ void ScrollWidget::setWidget(QGraphicsWidget *widget)
|
|||||||
|
|
||||||
QGraphicsWidget *ScrollWidget::widget() const
|
QGraphicsWidget *ScrollWidget::widget() const
|
||||||
{
|
{
|
||||||
return d->widget;
|
return d->widget.data();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
@ -352,7 +375,7 @@ void ScrollWidget::ensureItemVisible(QGraphicsItem *item)
|
|||||||
}
|
}
|
||||||
|
|
||||||
QGraphicsItem *parentOfItem = item->parentItem();
|
QGraphicsItem *parentOfItem = item->parentItem();
|
||||||
while (parentOfItem != d->widget) {
|
while (parentOfItem != d->widget.data()) {
|
||||||
if (!parentOfItem) {
|
if (!parentOfItem) {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
@ -373,7 +396,7 @@ void ScrollWidget::registerAsDragHandle(QGraphicsWidget *item)
|
|||||||
}
|
}
|
||||||
|
|
||||||
QGraphicsItem *parentOfItem = item->parentItem();
|
QGraphicsItem *parentOfItem = item->parentItem();
|
||||||
while (parentOfItem != d->widget) {
|
while (parentOfItem != d->widget.data()) {
|
||||||
if (!parentOfItem) {
|
if (!parentOfItem) {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
@ -406,19 +429,19 @@ QRectF ScrollWidget::viewportGeometry() const
|
|||||||
|
|
||||||
QSizeF ScrollWidget::contentsSize() const
|
QSizeF ScrollWidget::contentsSize() const
|
||||||
{
|
{
|
||||||
return d->widget ? d->widget->size() : QSizeF();
|
return d->widget ? d->widget.data()->size() : QSizeF();
|
||||||
}
|
}
|
||||||
|
|
||||||
void ScrollWidget::setScrollPosition(const QPointF &position)
|
void ScrollWidget::setScrollPosition(const QPointF &position)
|
||||||
{
|
{
|
||||||
if (d->widget) {
|
if (d->widget) {
|
||||||
d->widget->setPos(-position.toPoint());
|
d->widget.data()->setPos(-position.toPoint());
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
QPointF ScrollWidget::scrollPosition() const
|
QPointF ScrollWidget::scrollPosition() const
|
||||||
{
|
{
|
||||||
return d->widget ? -d->widget->pos() : QPointF();
|
return d->widget ? -d->widget.data()->pos() : QPointF();
|
||||||
}
|
}
|
||||||
|
|
||||||
void ScrollWidget::setStyleSheet(const QString &styleSheet)
|
void ScrollWidget::setStyleSheet(const QString &styleSheet)
|
||||||
@ -443,7 +466,7 @@ void ScrollWidget::focusInEvent(QFocusEvent *event)
|
|||||||
Q_UNUSED(event)
|
Q_UNUSED(event)
|
||||||
|
|
||||||
if (d->widget) {
|
if (d->widget) {
|
||||||
d->widget->setFocus();
|
d->widget.data()->setFocus();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -517,16 +540,16 @@ bool ScrollWidget::eventFilter(QObject *watched, QEvent *event)
|
|||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (watched == d->widget && event->type() == QEvent::GraphicsSceneResize) {
|
if (watched == d->widget.data() && event->type() == QEvent::GraphicsSceneResize) {
|
||||||
d->adjustScrollbars();
|
d->adjustScrollbars();
|
||||||
d->adjustClipping();
|
d->adjustClipping();
|
||||||
//force to refresh the size hint
|
//force to refresh the size hint
|
||||||
layout()->invalidate();
|
layout()->invalidate();
|
||||||
} else if (watched == d->widget && event->type() == QEvent::GraphicsSceneMove) {
|
} else if (watched == d->widget.data() && event->type() == QEvent::GraphicsSceneMove) {
|
||||||
d->horizontalScrollBar->blockSignals(true);
|
d->horizontalScrollBar->blockSignals(true);
|
||||||
d->verticalScrollBar->blockSignals(true);
|
d->verticalScrollBar->blockSignals(true);
|
||||||
d->horizontalScrollBar->setValue(-d->widget->pos().x()/10);
|
d->horizontalScrollBar->setValue(-d->widget.data()->pos().x()/10);
|
||||||
d->verticalScrollBar->setValue(-d->widget->pos().y()/10);
|
d->verticalScrollBar->setValue(-d->widget.data()->pos().y()/10);
|
||||||
d->horizontalScrollBar->blockSignals(false);
|
d->horizontalScrollBar->blockSignals(false);
|
||||||
d->verticalScrollBar->blockSignals(false);
|
d->verticalScrollBar->blockSignals(false);
|
||||||
} else if (d->dragHandles.contains(static_cast<QGraphicsWidget *>(watched))) {
|
} else if (d->dragHandles.contains(static_cast<QGraphicsWidget *>(watched))) {
|
||||||
@ -555,7 +578,7 @@ QSizeF ScrollWidget::sizeHint(Qt::SizeHint which, const QSizeF & constraint) con
|
|||||||
QSizeF hint = QGraphicsWidget::sizeHint(which, constraint);
|
QSizeF hint = QGraphicsWidget::sizeHint(which, constraint);
|
||||||
|
|
||||||
if (which == Qt::PreferredSize && d->widget) {
|
if (which == Qt::PreferredSize && d->widget) {
|
||||||
return (d->widget->size()+QSize(d->borderSize, d->borderSize)).expandedTo(d->widget->effectiveSizeHint(Qt::PreferredSize));
|
return (d->widget.data()->size()+QSize(d->borderSize, d->borderSize)).expandedTo(d->widget.data()->effectiveSizeHint(Qt::PreferredSize));
|
||||||
}
|
}
|
||||||
|
|
||||||
return hint;
|
return hint;
|
||||||
|
Loading…
Reference in New Issue
Block a user