mess around with widget sizing

This commit is contained in:
laserpants 2016-03-28 11:51:24 +03:00
parent 19a090fd15
commit 82865e9e0f
2 changed files with 78 additions and 23 deletions

View File

@ -12,7 +12,7 @@ Thumb::Thumb(Toggle *parent)
: QWidget(parent), : QWidget(parent),
_toggle(parent), _toggle(parent),
_animation(new QPropertyAnimation(this)), _animation(new QPropertyAnimation(this)),
_progress(0), _progress(1),
_offset(0) _offset(0)
{ {
parent->installEventFilter(this); parent->installEventFilter(this);
@ -20,23 +20,24 @@ Thumb::Thumb(Toggle *parent)
_animation->setPropertyName("progress"); _animation->setPropertyName("progress");
_animation->setTargetObject(this); _animation->setTargetObject(this);
_animation->setDuration(350); _animation->setDuration(350);
_animation->setStartValue(0); _animation->setStartValue(1);
_animation->setEndValue(1); _animation->setEndValue(0);
} }
Thumb::~Thumb() Thumb::~Thumb()
{ {
} }
void Thumb::setProgress(qreal p) void Thumb::setProgress(qreal progress)
{ {
if (_progress == p) if (_progress == progress)
return; return;
_progress = p; _progress = progress;
_offset = p*(static_cast<qreal>(width()-qMin(width(), height()))); //_offset = progress*(static_cast<qreal>(width()-qMin(width(), height())));
_offset = progress*(static_cast<qreal>(width()-height()));
emit progressChanged(p); emit progressChanged(progress);
update(); update();
} }
@ -45,15 +46,24 @@ bool Thumb::eventFilter(QObject *obj, QEvent *event)
{ {
const QEvent::Type type = event->type(); const QEvent::Type type = event->type();
if (QEvent::Resize == type || QEvent::Move == type) { if (QEvent::Resize == type || QEvent::Move == type) {
setGeometry(parentWidget()->rect().adjusted(9, 9, -9, -9));
// QRect r(parentWidget()->rect());
//
// const QSize s = sizeHint();
// QRect q(0, 0, 50, 50);
// q.moveCenter(r.center());
//
// setGeometry(q);
setGeometry(parentWidget()->rect().adjusted(8, 8, -8, -8));
} }
return QWidget::eventFilter(obj, event); return QWidget::eventFilter(obj, event);
} }
void Thumb::mousePressEvent(QMouseEvent *event) //void Thumb::mousePressEvent(QMouseEvent *event)
{ //{
Q_UNUSED(event) // Q_UNUSED(event)
} //}
void Thumb::mouseReleaseEvent(QMouseEvent *event) void Thumb::mouseReleaseEvent(QMouseEvent *event)
{ {
@ -80,6 +90,8 @@ void Thumb::paintEvent(QPaintEvent *event)
QPainter painter(this); QPainter painter(this);
painter.setRenderHint(QPainter::Antialiasing); painter.setRenderHint(QPainter::Antialiasing);
painter.drawRect(rect());
/* /*
painter.save(); painter.save();
QPen pen; QPen pen;
@ -98,18 +110,24 @@ void Thumb::paintEvent(QPaintEvent *event)
// painter.drawEllipse(5 + _progress*(static_cast<qreal>(width()-d)), 5, d-10, d-10); // painter.drawEllipse(5 + _progress*(static_cast<qreal>(width()-d)), 5, d-10, d-10);
const int d = qMin(width(), height()); //const int d = qMin(width(), height());
painter.drawEllipse(5 + _offset, 5, d-10, d-10);
const int s = height()-10;
painter.drawEllipse(5+_offset, 5, s, s);
} }
Toggle::Toggle(QWidget *parent) Toggle::Toggle(QWidget *parent)
: QAbstractButton(parent), : QAbstractButton(parent),
_thumb(new Thumb(this)), _thumb(new Thumb(this)),
_overlay(new RippleOverlay(parent)) _overlay(new RippleOverlay(parent)),
_orientation(Qt::Horizontal)
{ {
setFixedSize(64, 48); // setFixedSize(64, 48);
setCheckable(true); setCheckable(true);
_thumb->hide();
CustomShadowEffect *effect = new CustomShadowEffect; CustomShadowEffect *effect = new CustomShadowEffect;
effect->setDistance(0); effect->setDistance(0);
effect->setBlurRadius(6); effect->setBlurRadius(6);
@ -127,6 +145,25 @@ Toggle::~Toggle()
{ {
} }
QSize Toggle::sizeHint() const
{
return Qt::Horizontal == _orientation
? QSize(64, 48)
: QSize(48, 64);
}
void Toggle::setOrientation(Qt::Orientation orientation)
{
if (_orientation == orientation)
return;
_orientation = orientation;
// QSize s = size();
// if (Qt::Horizontal == orientation ? s.height() > s.width() : s.width() > s.height())
// setFixedSize(s.transposed());
}
void Toggle::xx() void Toggle::xx()
{ {
const int d = height()/2; // ??? const int d = height()/2; // ???
@ -163,7 +200,6 @@ void Toggle::paintEvent(QPaintEvent *event)
painter.drawRect(rect()); painter.drawRect(rect());
const int h = height()/2;
QBrush brush; QBrush brush;
brush.setColor(QColor(180, 180, 180)); brush.setColor(QColor(180, 180, 180));
@ -172,6 +208,21 @@ void Toggle::paintEvent(QPaintEvent *event)
painter.setPen(Qt::NoPen); painter.setPen(Qt::NoPen);
const QRect r(0, h-h/2, width(), h); if (Qt::Horizontal == _orientation) {
painter.drawRoundedRect(r.adjusted(14, 4, -14, -4), h/2-4, h/2-4); //const int h = qMin((qreal) height(), width()*0.4);
const int h = height()/2;
const QRect r(0, h/2, width(), h);
painter.drawRoundedRect(r.adjusted(14, 4, -14, -4), h/2-4, h/2-4);
//painter.drawRect(r.adjusted(14, 4, -14, -4));
} else {
//const int w = qMin((qreal) width(), height()*0.4);
const int w = width()/2;
const QRect r(w/2, 0, w, height());
painter.drawRoundedRect(r.adjusted(4, 14, -4, -14), w/2-4, w/2-4);
//painter.drawRect(r.adjusted(4, 14, -4, -14));
//const QRect r(w/2, 0, qMin(w, height()/4), height());
//painter.drawRect(r.adjusted(4, 0, -4, 0));
//const QRect r(0, h/2, width(), h);
}
} }

View File

@ -17,7 +17,7 @@ public:
explicit Thumb(Toggle *parent); explicit Thumb(Toggle *parent);
~Thumb(); ~Thumb();
void setProgress(qreal p); void setProgress(qreal progress);
inline qreal progress() const { return _progress; } inline qreal progress() const { return _progress; }
inline int offset() const { return _offset; } inline int offset() const { return _offset; }
@ -28,7 +28,7 @@ signals:
protected: protected:
bool eventFilter(QObject *obj, QEvent *event) Q_DECL_OVERRIDE; bool eventFilter(QObject *obj, QEvent *event) Q_DECL_OVERRIDE;
void mousePressEvent(QMouseEvent *event) Q_DECL_OVERRIDE; //void mousePressEvent(QMouseEvent *event) Q_DECL_OVERRIDE;
void mouseReleaseEvent(QMouseEvent *event) Q_DECL_OVERRIDE; void mouseReleaseEvent(QMouseEvent *event) Q_DECL_OVERRIDE;
void paintEvent(QPaintEvent *event) Q_DECL_OVERRIDE; void paintEvent(QPaintEvent *event) Q_DECL_OVERRIDE;
@ -47,7 +47,10 @@ public:
explicit Toggle(QWidget *parent = 0); explicit Toggle(QWidget *parent = 0);
~Toggle(); ~Toggle();
QSize sizeHint() const { return QSize(64, 48); } QSize sizeHint() const;
inline Qt::Orientation orientation() const { return _orientation; }
void setOrientation(Qt::Orientation orientation);
protected slots: protected slots:
void xx(); void xx();
@ -60,6 +63,7 @@ protected:
private: private:
Thumb *const _thumb; Thumb *const _thumb;
RippleOverlay *const _overlay; RippleOverlay *const _overlay;
Qt::Orientation _orientation;
}; };
#endif // TOGGLE_H #endif // TOGGLE_H