shadows example improved
This commit is contained in:
parent
1e675e5b8c
commit
bf15d21fb5
@ -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"
|
||||||
|
@ -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& );
|
||||||
};
|
};
|
||||||
|
@ -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();
|
||||||
|
|
||||||
|
Loading…
x
Reference in New Issue
Block a user