Adds alignment property

This commit is contained in:
Clemens Manert 2023-05-01 17:07:21 +02:00 committed by uwerat
parent 9ef3b8ac6f
commit 99cb893f15
2 changed files with 76 additions and 16 deletions

View File

@ -14,6 +14,7 @@ public:
QskControl* content; QskControl* content;
QskBox* contentBox; QskBox* contentBox;
Qt::Edge edge = Qt::LeftEdge; Qt::Edge edge = Qt::LeftEdge;
Qt::Alignment alignment = Qt::AlignCenter;
}; };
QskDrawer::QskDrawer( QQuickItem* parentItem ) : QskDrawer::QskDrawer( QQuickItem* parentItem ) :
@ -27,7 +28,7 @@ QskDrawer::QskDrawer( QQuickItem* parentItem ) :
m_data->contentBox = new QskBox(this); m_data->contentBox = new QskBox(this);
m_data->contentBox->setSubcontrolProxy( QskBox::Panel, Panel ); m_data->contentBox->setSubcontrolProxy( QskBox::Panel, Panel );
setAnimationHint( Panel | QskAspect::Position, QskAnimationHint( 1000 ) ); setAnimationHint( Panel | QskAspect::Position, QskAnimationHint( 5000 ) );
setFaderAspect( Panel | QskAspect::Metric ); setFaderAspect( Panel | QskAspect::Metric );
@ -48,52 +49,107 @@ Qt::Edge QskDrawer::edge() const {
return m_data->edge; return m_data->edge;
} }
Qt::Alignment QskDrawer::alignment() const {
return m_data->alignment;
}
void QskDrawer::setEdge( Qt::Edge edge ) { void QskDrawer::setEdge( Qt::Edge edge ) {
if( m_data->edge == edge ) { if( m_data->edge == edge ) {
return; return;
} }
update();
m_data->edge = edge; m_data->edge = edge;
edgeChanged( edge ); edgeChanged( edge );
} }
void QskDrawer::setAlignment( Qt::Alignment alignment ) {
if( m_data->alignment == alignment ) {
return;
}
update();
m_data->alignment = alignment;
alignmentChanged( alignment );
}
void QskDrawer::setContent( QskControl* content ) { void QskDrawer::setContent( QskControl* content ) {
content->setParentItem( m_data->contentBox ); content->setParentItem( m_data->contentBox );
m_data->content = content; m_data->content = content;
} }
void QskDrawer::updateLayout() { void QskDrawer::updateLayout() {
auto size = m_data->content->preferredSize(); const auto& contentSize = m_data->content->preferredSize();
const auto& parentSize = parentItem()->size();
switch( m_data->edge ) { switch( m_data->edge ) {
case Qt::Edge::LeftEdge: case Qt::Edge::LeftEdge:
{ {
qreal off = metric( faderAspect() ) * size.width(); qreal x = metric( faderAspect() ) * contentSize.width() * -1.0;
qreal y = 0;
if( alignment().testFlag( Qt::AlignVCenter ) ) {
y = ( parentSize.height() - contentSize.height() ) / 2.0;
} else if ( alignment().testFlag( Qt::AlignBottom ) ) {
y = ( parentSize.height() - contentSize.height() );
}
qskSetItemGeometry( m_data->contentBox, qskSetItemGeometry( m_data->contentBox,
-off, 0, size.width(), size.height()); x, y,
contentSize.width(), parentSize.height() );
break; break;
} }
case Qt::Edge::RightEdge: case Qt::Edge::RightEdge:
{ {
qreal off = metric( faderAspect() ) * size.width(); qreal x = ( metric( faderAspect() ) * contentSize.width() )
+ parentSize.width()
- contentSize.width();
qreal y = 0;
if( alignment().testFlag( Qt::AlignVCenter ) ) {
y = ( parentSize.height() - contentSize.height() ) / 2.0;
} else if ( alignment().testFlag( Qt::AlignBottom ) ) {
y = ( parentSize.height() - contentSize.height() );
}
qskSetItemGeometry( m_data->contentBox, qskSetItemGeometry( m_data->contentBox,
size.width() + off, 0, size.width(), size.height()); x, y,
contentSize.width(),
parentSize.height() );
break; break;
} }
case Qt::Edge::TopEdge: case Qt::Edge::TopEdge:
{ {
qreal off = metric( faderAspect() ) * size.height(); qreal x = 0;
qreal y = metric( faderAspect() ) * contentSize.height();
if( alignment().testFlag( Qt::AlignCenter) ) {
x = ( parentSize.width() - contentSize.width() ) / 2;
} else if( alignment().testFlag( Qt::AlignRight) ) {
x = ( parentSize.width() - contentSize.width() );
}
qskSetItemGeometry( m_data->contentBox, qskSetItemGeometry( m_data->contentBox,
0, -off, size.width(), size.height()); x, -y,
parentSize.width(), contentSize.height());
break; break;
} }
case Qt::Edge::BottomEdge: case Qt::Edge::BottomEdge:
{ {
qreal off = metric( faderAspect() ) * size.height(); qreal x = 0;
qreal y = metric( faderAspect() ) * contentSize.height() + parentSize.height() - contentSize.height();
if( alignment().testFlag( Qt::AlignCenter) ) {
x = ( parentSize.width() - contentSize.width() ) / 2;
} else if( alignment().testFlag( Qt::AlignRight) ) {
x = ( parentSize.width() - contentSize.width() );
}
qskSetItemGeometry( m_data->contentBox, qskSetItemGeometry( m_data->contentBox,
0, size.height() + off, size.width(), size.height()); x, y,
parentSize.width(), contentSize.height());
break; break;
} }
break; break;

View File

@ -12,6 +12,7 @@ class QSK_EXPORT QskDrawer : public QskPopup
using Inherited = QskPopup; using Inherited = QskPopup;
Q_PROPERTY( Qt::Edge edge READ edge WRITE setEdge NOTIFY edgeChanged ) Q_PROPERTY( Qt::Edge edge READ edge WRITE setEdge NOTIFY edgeChanged )
Q_PROPERTY( Qt::Alignment alignment READ alignment WRITE setAlignment NOTIFY alignmentChanged )
public: public:
QSK_SUBCONTROLS( Panel ) QSK_SUBCONTROLS( Panel )
@ -19,17 +20,20 @@ class QSK_EXPORT QskDrawer : public QskPopup
~QskDrawer() override; ~QskDrawer() override;
Qt::Edge edge() const; Qt::Edge edge() const;
Qt::Alignment alignment() const;
void updateLayout() override; void updateLayout() override;
void setContent( QskControl* t ); void setContent( QskControl* t );
void setEdge( Qt::Edge edge ); void setEdge( Qt::Edge edge );
void setAlignment( Qt::Alignment aligmnent );
protected: protected:
void aboutToShow() override; void aboutToShow() override;
Q_SIGNALS: Q_SIGNALS:
void edgeChanged( Qt::Edge ); void edgeChanged( Qt::Edge );
void alignmentChanged( Qt::Alignment );
private: private:
class PrivateData; class PrivateData;