shadows example improved

This commit is contained in:
Uwe Rathmann 2022-06-14 11:58:56 +02:00
parent 1e675e5b8c
commit bf15d21fb5
3 changed files with 200 additions and 61 deletions

View File

@ -14,40 +14,103 @@
ShadowedBox::ShadowedBox( QQuickItem* parentItem ) ShadowedBox::ShadowedBox( QQuickItem* parentItem )
: QskBox( true, parentItem ) : QskBox( true, parentItem )
{ {
QColor c( Qt::darkRed );
#if 0
c.setAlpha( 100 );
#endif
setGradientHint( Panel, c );
setBoxShapeHint( Panel, QskBoxShapeMetrics( 40, 0, 15, 0 ) );
setBoxBorderMetricsHint( Panel, 0 );
#if 0
setBoxBorderMetricsHint( Panel, 10 );
setBoxBorderColorsHint( Panel, Qt::blue );
#endif
setShadowColorHint( Panel, Qt::black );
} }
ShadowedBox::~ShadowedBox() ShadowedBox::~ShadowedBox()
{ {
} }
void ShadowedBox::setShadow( const QskShadowMetrics& shadow ) void ShadowedBox::setOffsetX( qreal dx )
{ {
setShadowMetricsHint( Panel, shadow ); auto metrics = shadowMetrics();
metrics.setOffsetX( dx );
setShadowMetrics( metrics );
} }
void ShadowedBox::setShadowColor( const QColor& color ) qreal ShadowedBox::offsetX() const
{ {
return shadowMetrics().offset().x();
}
void ShadowedBox::setOffsetY( qreal dy )
{
auto metrics = shadowMetrics();
metrics.setOffsetY( dy );
setShadowMetrics( metrics );
}
qreal ShadowedBox::offsetY() const
{
return shadowMetrics().offset().y();
}
void ShadowedBox::setSpreadRadius( qreal radius )
{
auto metrics = shadowMetrics();
metrics.setSpreadRadius( radius );
setShadowMetrics( metrics );
}
qreal ShadowedBox::spreadRadius() const
{
return shadowMetrics().spreadRadius();
}
void ShadowedBox::setBlurRadius( qreal radius )
{
auto metrics = shadowMetrics();
metrics.setBlurRadius( radius );
setShadowMetrics( metrics );
}
qreal ShadowedBox::blurRadius() const
{
return shadowMetrics().blurRadius();
}
void ShadowedBox::setOpacity( qreal opacity )
{
opacity = qBound( 0.0, opacity, 1.0 );
auto color = shadowColorHint( Panel );
color.setAlphaF( opacity );
setShadowColorHint( Panel, color ); setShadowColorHint( Panel, color );
} }
void ShadowedBox::setGradient( const QskGradient& gradient ) qreal ShadowedBox::opacity() const
{ {
setGradientHint( Panel, gradient ); return shadowColorHint( Panel ).alphaF();
} }
void ShadowedBox::setShape( const QskBoxShapeMetrics& shape ) QskShadowMetrics ShadowedBox::shadowMetrics() const
{ {
setBoxShapeHint( Panel, shape ); return shadowMetricsHint( Panel );
} }
void ShadowedBox::setBorderWidth( qreal width ) void ShadowedBox::setShadowMetrics( const QskShadowMetrics& metrics )
{ {
setBoxBorderMetricsHint( Panel, width ); setShadowMetricsHint( Panel, metrics );
}
void ShadowedBox::setBorderColors( const QskBoxBorderColors& colors )
{
setBoxBorderColorsHint( Panel, colors );
} }
#include "moc_ShadowedBox.cpp" #include "moc_ShadowedBox.cpp"

View File

@ -7,25 +7,34 @@
#include <QskBox.h> #include <QskBox.h>
class QskGradient;
class QskShadowMetrics; class QskShadowMetrics;
class QskBoxShapeMetrics;
class QskBoxBorderColors;
class ShadowedBox : public QskBox class ShadowedBox : public QskBox
{ {
Q_OBJECT Q_OBJECT
public: public:
ShadowedBox(QQuickItem* parent = nullptr); ShadowedBox( QQuickItem* parent = nullptr );
~ShadowedBox() override; ~ShadowedBox() override;
void setShape( const QskBoxShapeMetrics& ); qreal offsetX() const;
void setGradient( const QskGradient& ); qreal offsetY() const;
void setBorderWidth( qreal width ); qreal spreadRadius() const;
void setBorderColors( const QskBoxBorderColors& ); qreal blurRadius() const;
void setShadow( const QskShadowMetrics& ); qreal opacity() const;
void setShadowColor( const QColor& );
public Q_SLOTS:
void setOffsetX( qreal );
void setOffsetY( qreal );
void setSpreadRadius( qreal );
void setBlurRadius( qreal );
void setOpacity( qreal );
private:
QskShadowMetrics shadowMetrics() const;
void setShadowMetrics( const QskShadowMetrics& );
}; };

View File

@ -7,43 +7,122 @@
#include <QskObjectCounter.h> #include <QskObjectCounter.h>
#include <QskWindow.h> #include <QskWindow.h>
#include <QskLinearBox.h> #include <QskGridBox.h>
#include <QskSlider.h>
#include <QskTextLabel.h>
#include <QskRgbValue.h> #include <QskRgbValue.h>
#include <QskGradient.h>
#include <QskShadowMetrics.h>
#include <QskBoxShapeMetrics.h>
#include <QskBoxBorderColors.h>
#include <SkinnyShortcut.h> #include <SkinnyShortcut.h>
#include <QGuiApplication> #include <QGuiApplication>
#include <QFontMetrics>
class Box : public ShadowedBox class BoxPanel : public QskBox
{ {
public: public:
Box( QQuickItem* parent = nullptr ) BoxPanel( QQuickItem* parent = nullptr )
: ShadowedBox( parent ) : QskBox( parent )
{ {
const qreal w = 10; setAutoLayoutChildren( true );
setPadding( 60 );
QskShadowMetrics shadow; setPanel( true );
//shadow.setOffset( 20.0, 20.0 ); setGradientHint( QskBox::Panel, QGradient::SnowAgain );
shadow.setSpreadRadius( w ); }
shadow.setBlurRadius( w ); };
setShadow( shadow ); class Slider : public QskSlider
setShadowColor( Qt::black ); {
public:
Slider( qreal min, qreal max, qreal step, qreal value, QQuickItem* parent = nullptr )
: QskSlider( parent )
{
setBoundaries( min, max );
setStepSize( step );
setSnap( true );
setValue( value );
}
};
QColor c( Qt::darkRed ); class ValueLabel : public QskTextLabel
#if 0 {
c.setAlpha( 100 ); public:
#endif ValueLabel( QQuickItem* parent = nullptr )
: QskTextLabel( parent )
{
setFixedWidth( QFontMetrics( font() ).horizontalAdvance( "-100" ) );
setAlignment( Qt::AlignLeft | Qt::AlignVCenter );
}
setGradient( c ); void setValue( qreal value )
setShape( QskBoxShapeMetrics( 40, 10, 15, 5 ) ); {
setText( QString::number( value ) );
}
};
setBorderWidth( w ); class GridBox : public QskGridBox
setBorderColors( Qt::blue ); {
public:
GridBox( QQuickItem* parent = nullptr )
: QskGridBox( parent )
{
setMargins( 5 );
setColumnStretchFactor( 1, 1 );
auto sliderX = new Slider( -50, 50, 1, 10 );
auto sliderY = new Slider( -50, 50, 1, 10 );
auto sliderSpread = new Slider( 0, 50, 1, 0 );
auto sliderBlur = new Slider( 0, 50, 1, 10 );
auto sliderOpacity = new Slider( 0, 1, 0.01, 1 );
auto panel = new BoxPanel();
int row = 0;
addSlider( row++, "Offset X", sliderX );
addSlider( row++, "Offset Y", sliderY );
addSlider( row++, "Spread Radius", sliderSpread );
addSlider( row++, "Blur Radius", sliderBlur );
addSlider( row++, "Opacity", sliderOpacity );
addItem( panel, row, 0, -1, -1 );
auto box = new ShadowedBox( panel );
box->setOffsetX( sliderX->value() );
box->setOffsetY( sliderY->value() );
box->setSpreadRadius( sliderSpread->value() );
box->setBlurRadius( sliderBlur->value() );
box->setOpacity( sliderOpacity->value() );
connect( sliderX, &QskSlider::valueChanged,
box, &ShadowedBox::setOffsetX );
connect( sliderY, &QskSlider::valueChanged,
box, &ShadowedBox::setOffsetY );
connect( sliderSpread, &QskSlider::valueChanged,
box, &ShadowedBox::setSpreadRadius );
connect( sliderBlur, &QskSlider::valueChanged,
box, &ShadowedBox::setBlurRadius );
connect( sliderOpacity, &QskSlider::valueChanged,
box, &ShadowedBox::setOpacity );
}
private:
void addSlider( int row, const QString& text, QskSlider* slider )
{
addItem( new QskTextLabel( text ), row, 0 );
addItem( slider, row, 1 );
auto label = new ValueLabel();
label->setValue( slider->value() );
addItem( label, row, 2 );
connect( slider, &QskSlider::valueChanged,
label, [label]( qreal value ) { label->setText( QString::number( value ) ); } );
} }
}; };
@ -57,20 +136,8 @@ int main( int argc, char* argv[] )
SkinnyShortcut::enable( SkinnyShortcut::AllShortcuts ); SkinnyShortcut::enable( SkinnyShortcut::AllShortcuts );
auto layout = new QskLinearBox();
layout->setPanel( true );
#if 1
layout->setGradientHint( QskBox::Panel,
QskGradient( Qt::Vertical, QskRgb::WhiteSmoke, QskRgb::MistyRose ) );
#else
layout->setGradientHint( QskBox::Panel, Qt::white );
#endif
layout->setPadding( 60 );
(void ) new Box( layout );
QskWindow window; QskWindow window;
window.setColor( QskRgb::PapayaWhip ); window.addItem( new GridBox() );
window.addItem( layout );
window.resize( 600, 600 ); window.resize( 600, 600 );
window.show(); window.show();