Improve material theme

This commit is contained in:
Clemens Manert 2021-11-22 20:59:43 +01:00
parent 2b78922b43
commit 8add804e3c
No known key found for this signature in database
GPG Key ID: 9197EAE8F85E3A18
5 changed files with 312 additions and 247 deletions

View File

@ -37,7 +37,6 @@
#include <QskFunctions.h>
#include <QskMargins.h>
#include <QskNamespace.h>
#include <QskRgbValue.h>
#if 1
// should be defined in the public header, so that
@ -57,45 +56,6 @@ static inline QColor qskShadedColor( const QColor color, qreal opacity )
namespace
{
class ColorPalette
{
public:
ColorPalette( const QColor base = QColor::fromRgba( QskRgb::Grey100 ),
const QColor& accent = QColor::fromRgba( QskRgb::Blue500 ),
const QColor& contrast = QColor::fromRgba( QskRgb::White ) )
{
baseColor = base;
accentColor = accent;
contrastColor = contrast;
darker125 = baseColor.darker( 125 );
darker150 = baseColor.darker( 150 );
darker200 = baseColor.darker( 200 );
lighter125 = baseColor.lighter( 125 );
lighter150 = baseColor.lighter( 150 );
lighter200 = baseColor.lighter( 200 );
textColor = ( baseColor.value() > 128 )
? QskRgb::Black : QskRgb::White;
}
QColor accentColor;
QColor contrastColor;
QColor baseColor;
QColor lighter125;
QColor lighter150;
QColor lighter200;
QColor darker125;
QColor darker150;
QColor darker200;
QColor textColor;
};
class Editor : private QskSkinHintTableEditor
{
public:
@ -133,6 +93,7 @@ namespace
void setupTextLabel();
const ColorPalette& m_pal;
const uint rippleSize = 30;
};
}
@ -168,20 +129,20 @@ void Editor::setupControl()
using A = QskAspect;
using Q = QskControl;
setPadding( A::Control, 4 );
setPadding( A::Control, 11 );
setGradient( A::Control, m_pal.baseColor );
setColor( A::Control | A::StyleColor, m_pal.textColor );
setGradient( A::Control, m_pal.background );
setColor( A::Control | A::StyleColor, m_pal.onBackground );
setColor( A::Control | A::StyleColor | Q::Disabled,
qskShadedColor( m_pal.textColor, 0.6 ) );
qskShadedColor( m_pal.onBackground, 0.6 ) );
}
void Editor::setupBox()
{
using Q = QskBox;
setGradient( Q::Panel, m_pal.baseColor );
setBoxShape( Q::Panel, 4 );
setGradient( Q::Panel, m_pal.background );
setBoxShape( Q::Panel, 14 );
setBoxBorderMetrics( Q::Panel, 0 );
}
@ -193,7 +154,7 @@ void Editor::setupPopup()
setFlagHint( Q::Overlay | A::Style, true );
const QskGradient gradient( QskGradient::Vertical,
qskShadedColor( m_pal.accentColor, 0.45 ), qskShadedColor( m_pal.accentColor, 0.7 ) );
qskShadedColor( m_pal.secondary, 0.45 ), qskShadedColor( m_pal.secondary, 0.7 ) );
setGradient( Q::Overlay, gradient );
}
@ -203,60 +164,87 @@ void Editor::setupTextLabel()
using Q = QskTextLabel;
setAlignment( Q::Text, Qt::AlignCenter );
setColor( Q::Text, m_pal.textColor );
setColor( Q::Text, m_pal.onBackground );
setPadding( Q::Panel, 5 );
setBoxShape( Q::Panel, 4 );
setBoxBorderMetrics( Q::Panel, 2 );
setBoxBorderColors( Q::Panel, m_pal.darker125 );
setGradient( Q::Panel, m_pal.baseColor );
setBoxBorderColors( Q::Panel, m_pal.primaryNoSaturation );
setGradient( Q::Panel, m_pal.background );
}
void Editor::setupTextInput()
{
using Q = QskTextInput;
setAlignment( Q::Text, Qt::AlignLeft | Qt::AlignTop );
setColor( Q::Text, m_pal.textColor );
setColor( Q::PanelSelected, m_pal.accentColor );
setColor( Q::TextSelected, m_pal.contrastColor );
setColor( Q::Text, m_pal.onBackground );
setColor( Q::PanelSelected, qskShadedColor( m_pal.primary, 0.16 ) );
setPadding( Q::Panel, 5 );
setBoxShape( Q::Panel, 4 );
setBoxBorderMetrics( Q::Panel, 2 );
setBoxBorderColors( Q::Panel, m_pal.darker125 );
setGradient( Q::Panel, m_pal.baseColor );
setBoxShape( Q::Panel, 4, 4, 0, 0 );
setBoxBorderMetrics( Q::Panel, 0, 0, 0, 1 );
setBoxBorderColors( Q::Panel, m_pal.onBackground );
setBoxBorderMetrics( Q::Panel | Q::Focused, 0, 0, 0, 2 );
setBoxBorderColors( Q::Panel | Q::Focused, m_pal.primary );
setBoxBorderMetrics( Q::Panel | Q::Editing, 0, 0, 0, 2 );
setBoxBorderColors( Q::Panel | Q::Editing, m_pal.primary );
setBoxBorderColors( Q::Panel | Q::Focused, m_pal.primary );
setColor( Q::Panel,
m_pal.elevated(m_pal.background, 1) );
setColor( Q::Panel | Q::Hovered,
m_pal.elevated(m_pal.background, 2) );
setColor( Q::Panel | Q::Focused,
m_pal.elevated(m_pal.background, 3) );
setColor( Q::Panel | Q::Editing,
m_pal.elevated(m_pal.background, 4) );
setColor( Q::Panel | Q::Disabled,
qskShadedColor(m_pal.secondaryVariantNoSaturation, m_pal.disabled ) );
setColor( Q::Text | Q::Disabled, qskShadedColor(m_pal.onBackground, m_pal.disabled ) );
setBoxBorderColors( Q::Panel,
qskShadedColor(m_pal.onBackground, m_pal.disabled ) );
}
void Editor::setupProgressBar()
{
using A = QskAspect;
using namespace QskRgb;
using Q = QskProgressBar;
auto size = qskDpiScaled(5);
for ( auto subControl : { Q::Groove, Q::Bar } )
{
setMetric( subControl | A::Size, 5 );
setMetric( subControl | A::Size, size );
setPadding( subControl, 0 );
setBoxShape( subControl, 0 );
setBoxBorderMetrics( subControl, 0 );
}
setGradient( Q::Groove, Grey );
setMetric( Q::Groove | A::Size, 5 );
setGradient( Q::Bar, m_pal.accentColor );
setGradient( Q::Groove, m_pal.secondaryNoSaturation );
setMetric( Q::Groove | A::Size, size );
setGradient( Q::Bar, m_pal.secondary );
setGradient( Q::Groove | Q::Disabled,
qskShadedColor(m_pal.secondaryNoSaturation, m_pal.disabled ) );
setGradient( Q::Bar | Q::Disabled,
qskShadedColor(m_pal.secondary, m_pal.disabled ) );
}
void Editor::setupFocusIndicator()
{
using Q = QskFocusIndicator;
setPadding( Q::Panel, 5 );
setBoxShape( Q::Panel, 4 );
setBoxBorderMetrics( Q::Panel, 2 );
setBoxBorderColors( Q::Panel, m_pal.accentColor );
setPadding( Q::Panel, 0 );
setBoxShape( Q::Panel, 0 );
setBoxBorderMetrics( Q::Panel, 0 );
setBoxBorderColors( Q::Panel, m_pal.secondary );
setGradient( Q::Panel, QskGradient() );
}
@ -272,7 +260,7 @@ void Editor::setupSeparator()
setMetric( aspect | A::Size, 4 );
setBoxShape( Q::Panel, 0 );
setBoxBorderMetrics( Q::Panel, 0 );
setGradient( aspect, m_pal.baseColor );
setGradient( aspect, m_pal.background );
}
}
@ -290,10 +278,15 @@ void Editor::setupPageIndicator()
setBoxBorderMetrics( subControl, 0 );
const QColor color = ( subControl == Q::Bullet )
? m_pal.lighter150 : m_pal.accentColor;
? m_pal.secondaryNoSaturation : m_pal.secondary;
const QColor colorDisabled = ( subControl == Q::Bullet )
? qskShadedColor(m_pal.secondaryNoSaturation, m_pal.disabled )
: qskShadedColor(m_pal.secondary, m_pal.disabled );
setGradient( subControl, color );
setBoxBorderColors( subControl, color );
setGradient( subControl | Q::Disabled, colorDisabled );
}
// no visible background panel
@ -318,42 +311,25 @@ void Editor::setupPushButton()
setMargin( Q::Panel, margin );
setPadding( Q::Panel, padding );
const QskBoxBorderColors borderColors( Grey400, Grey300, Grey400, Grey600 );
setBoxShape( Q::Panel, 5 );
QskBoxBorderColors noBorderColors = borderColors;
noBorderColors.setAlpha( 0 );
setBoxShape( Q::Panel, 0 );
setBoxBorderMetrics( Q::Panel, QskMargins( 1, 2, 1, 2 ) );
setBoxBorderColors( Q::Panel, noBorderColors );
setGradient( Q::Panel, White );
//setGradient( Q::Panel, m_pal.primary);
setGradient( Q::Panel | Q::Flat, White & ColorMask );
setColor( Q::Text, m_pal.textColor );
setColor( Q::Text | Q::Disabled, qskShadedColor( m_pal.textColor, 0.6 ) );
setColor( Q::Text, m_pal.primary );
setColor( Q::Text | Q::Disabled, qskShadedColor( m_pal.primary, 0.6 ) );
setFontRole( Q::Text, ButtonFontRole );
setAlignment( Q::Text, Qt::AlignCenter );
for ( auto state1 : { A::NoState, Q::Focused } )
{
setBoxBorderColors( Q::Panel | Q::Hovered | state1, borderColors );
setBoxBorderColors( Q::Panel | Q::Hovered | Q::Flat | state1, borderColors );
setBoxBorderMetrics(Q::Panel, 1);
setBoxBorderColors(Q::Panel, m_pal.primary);
for ( auto state2 : { A::NoState, Q::Hovered } )
{
for ( auto state3 : { Q::Pressed | A::NoState, Q::Checked | A::NoState, Q::Checked | Q::Pressed } )
{
const auto states = state1 | state2 | state3;
setBoxBorderColors(Q::Panel | Q::Disabled, qskShadedColor( m_pal.onBackground, m_pal.disabled ) );
setColor( Q::Text | Q::Disabled, qskShadedColor( m_pal.onBackground, m_pal.disabled ) );
setGradient( Q::Panel | states, m_pal.accentColor );
setColor( Q::Text | states, White );
setGradient( Q::Panel | Q::Flat | states, m_pal.accentColor );
setColor( Q::Text | Q::Flat | states, White );
}
}
}
setColor( Q::Panel | Q::Hovered, qskShadedColor( m_pal.primary, m_pal.hover ) );
setColor( Q::Panel | Q::Focused, qskShadedColor( m_pal.primary, m_pal.focused ) );
setColor( Q::Panel | Q::Pressed, qskShadedColor( m_pal.primary, m_pal.pressed ) );
setAnimation( Q::Panel | A::Color, qskDuration );
setAnimation( Q::Panel | A::Metric, qskDuration );
@ -372,33 +348,24 @@ void Editor::setupDialogButton()
setMargin( Q::Panel, QskMargins( 4, 3 ) );
setPadding( Q::Panel, QskMargins( 10, 6 ) );
const QskBoxBorderColors borderColors( Grey400, Grey300, Grey400, Grey600 );
QskBoxBorderColors noBorderColors = borderColors;
noBorderColors.setAlpha( 0 );
setBoxShape( Q::Panel, 0 );
setBoxBorderMetrics( Q::Panel, QskMargins( 1, 2, 1, 2 ) );
setBoxBorderColors( Q::Panel, noBorderColors );
setGradient( Q::Panel, White );
setColor( Q::Text, m_pal.textColor );
setColor( Q::Text | Q::Disabled, qskShadedColor( m_pal.textColor, 0.6 ) );
setGradient( Q::Panel, m_pal.primary );
setColor( Q::Text, m_pal.onBackground );
setColor( Q::Text | Q::Disabled, qskShadedColor( m_pal.onPrimary, 0.6 ) );
setFontRole( Q::Text, ButtonFontRole );
setAlignment( Q::Text, Qt::AlignCenter );
for ( auto state1 : { A::NoState, Q::Focused } )
{
setBoxBorderColors( Q::Panel | Q::Hovered | state1, borderColors );
for ( auto state2 : { A::NoState, Q::Hovered } )
{
for ( auto state3 : { Q::Pressed | A::NoState, Q::Checked | A::NoState, Q::Checked | Q::Pressed } )
{
const auto states = state1 | state2 | state3;
setGradient( Q::Panel | states, m_pal.accentColor );
setColor( Q::Text | states, White );
setGradient( Q::Panel | states, m_pal.secondary );
setColor( Q::Text | states, m_pal.onSecondary );
}
}
}
@ -412,7 +379,7 @@ void Editor::setupDialogButtonBox()
{
using Q = QskDialogButtonBox;
setGradient( Q::Panel, m_pal.baseColor );
setGradient( Q::Panel, m_pal.background );
setBoxShape( Q::Panel, 0 );
setBoxBorderMetrics( Q::Panel, 0 );
}
@ -430,7 +397,7 @@ void Editor::setupSlider()
setMetric( Q::Panel | A::Size, extent );
setBoxShape( Q::Panel, 0 );
setBoxBorderMetrics( Q::Panel, 0 );
setGradient( Q::Panel, QskGradient() );
setGradient( Q::Panel, m_pal.background );
setPadding( Q::Panel | A::Horizontal, QskMargins( 0.5 * extent, 0 ) );
setPadding( Q::Panel | A::Vertical, QskMargins( 0, 0.5 * extent ) );
@ -439,48 +406,46 @@ void Editor::setupSlider()
for ( auto subControl : { Q::Groove, Q::Fill } )
{
setMetric( subControl | A::Size, 5 );
setPadding( subControl, 0 );
setBoxShape( subControl, 0 );
setBoxBorderMetrics( subControl, 0 );
}
setMetric( Q::Groove | A::Size, qskDpiScaled( 4 ) );
setMetric( Q::Fill | A::Size, qskDpiScaled( 6 ) );
setGradient( Q::Groove, Grey );
setGradient( Q::Fill, m_pal.accentColor );
setBoxBorderColors( Q::Fill, m_pal.accentColor );
setGradient( Q::Groove, qskShadedColor(m_pal.secondary, .38) );
setGradient( Q::Groove | Q::Disabled,
qskShadedColor(m_pal.secondaryNoSaturation, m_pal.disabled ) );
setGradient( Q::Fill, m_pal.secondary );
setGradient( Q::Fill | Q::Disabled,
qskShadedColor(m_pal.secondaryNoSaturation, m_pal.disabled ) );
// handle
setBoxShape( Q::Handle, 100, Qt::RelativeSize );
setBoxBorderMetrics( Q::Handle, 4 );
setBoxBorderMetrics( Q::Handle, 0 );
// handle expanding, when being pressed
const QSize extentSize( extent, extent );
setStrutSize( Q::Handle, 0.6 * extentSize );
setStrutSize( Q::Handle | Q::Pressed, extentSize );
setGradient( Q::Handle | Q::Disabled, Grey );
setBoxBorderColors( Q::Handle | Q::Disabled, Grey );
setStrutSize( Q::Handle, qskDpiScaled( 20 + rippleSize ),
qskDpiScaled( 20 + rippleSize ) );
setGradient( Q::Handle, m_pal.accentColor );
setGradient( Q::Handle | Q::Pressed, m_pal.accentColor );
setGradient( Q::Handle | Q::Disabled, m_pal.secondaryNoSaturation );
for ( auto state : { A::States(), Q::Pressed | A::NoState, Q::Pressed | Q::Hovered } )
{
setBoxBorderColors( Q::Handle | state, m_pal.accentColor );
}
setGradient( Q::Handle, m_pal.secondary );
setGradient( Q::Handle | Q::Pressed, m_pal.secondary );
for ( auto state : { A::States(), Q::Pressed | A::NoState, Q::Pressed | Q::Hovered } )
{
const auto aspect = Q::Handle | Q::Minimum | state;
setGradient( aspect, Grey300 );
setBoxBorderColors( aspect, Grey );
}
setBoxBorderMetrics( Q::Handle, qskDpiScaled(rippleSize / 2) );
setAnimation( Q::Handle | A::Metric, qskDuration );
setAnimation( Q::Handle | A::Color, qskDuration );
setBoxBorderColors( Q::Handle | Q::Hovered,
qskShadedColor(m_pal.secondary, m_pal.hover ) );
setBoxBorderColors( Q::Handle | Q::Focused,
qskShadedColor(m_pal.secondary, m_pal.focused ) );
setBoxBorderColors( Q::Handle | Q::Pressed,
qskShadedColor(m_pal.secondary, m_pal.pressed ) );
// move the handle smoothly, when using keys
setAnimation( Q::Handle | A::Metric | A::Position, 2 * qskDuration );
@ -493,7 +458,6 @@ void Editor::setupSwitchButton()
using Q = QskSwitchButton;
const qreal radius = qskDpiScaled( 10 );
const qreal handleSize = 2 * radius;
setBoxShape( Q::Groove, 100, Qt::RelativeSize );
@ -501,53 +465,46 @@ void Editor::setupSwitchButton()
setStrutSize( Q::Groove | A::Horizontal, grooveSize );
setStrutSize( Q::Groove | A::Vertical, grooveSize.transposed() );
setGradient( Q::Groove, m_pal.darker125 );
setGradient( Q::Groove | Q::Disabled, m_pal.lighter150 );
setGradient( Q::Groove | Q::Checked, m_pal.darker200 );
setBoxBorderColors( Q::Groove, m_pal.darker200 );
setBoxBorderMetrics( Q::Groove, 2 );
setBoxBorderColors( Q::Groove | Q::Disabled, m_pal.darker125 );
setColor( Q::Groove, m_pal.secondaryNoSaturation);
setGradient( Q::Groove | Q::Disabled,
qskShadedColor(m_pal.secondaryNoSaturation, m_pal.disabled ) );
setGradient( Q::Groove | Q::Checked,
m_pal.secondaryVariant);
setGradient( Q::Groove | Q::Checked | Q::Disabled,
qskShadedColor(m_pal.secondaryVariant, m_pal.disabledOccupancy) );
setBoxShape( Q::Handle, 100, Qt::RelativeSize );
setStrutSize( Q::Handle, handleSize, handleSize );
setBoxBorderMetrics( Q::Handle, 2 );
setStrutSize( Q::Handle, qskDpiScaled( 2 * radius + rippleSize ),
qskDpiScaled( 2 * radius + rippleSize ) );
setGradient( Q::Handle, QskGradient( Qt::Vertical, m_pal.lighter150, m_pal.lighter125 ) );
setGradient( Q::Handle | Q::Checked, m_pal.accentColor );
setGradient( Q::Handle, m_pal.background.lighter(900) );
setGradient( Q::Handle | Q::Disabled, m_pal.lighter125 );
setBoxBorderColors( Q::Handle, m_pal.darker200 );
setBoxBorderColors( Q::Handle | Q::Disabled, m_pal.darker125 );
setGradient( Q::Handle | Q::Checked, m_pal.secondary );
setBoxShape( Q::Ripple, 100, Qt::RelativeSize );
setStrutSize( Q::Ripple, 2 * handleSize, 2 * handleSize );
setGradient( Q::Ripple, QskRgb::Transparent );
setGradient( Q::Handle | Q::Disabled,
m_pal.elevated( m_pal.secondaryNoSaturation, -2) );
setGradient( Q::Handle | Q::Disabled | Q::Checked,
m_pal.elevated( m_pal.secondary, -3) );
for ( auto state : { Q::Hovered, Q::Focused, Q::Pressed } )
{
auto weak = m_pal.darker125;
auto strong = m_pal.accentColor;
setBoxBorderMetrics( Q::Handle, qskDpiScaled(rippleSize / 2) );
setBoxBorderMetrics( Q::Handle, qskDpiScaled(rippleSize / 2) );
if ( state == Q::Hovered )
{
weak.setAlpha( 100 );
strong.setAlpha( 50 );
}
else if ( state == Q::Focused )
{
weak.setAlpha( 150 );
strong.setAlpha( 100 );
}
else
{
weak.setAlpha( 200 );
strong.setAlpha( 150 );
}
setBoxBorderColors( Q::Handle | Q::Checked | Q::Hovered,
qskShadedColor(m_pal.secondary, m_pal.hover ) );
setBoxBorderColors( Q::Handle | Q::Checked | Q::Focused,
qskShadedColor(m_pal.secondary, m_pal.focused ) );
setBoxBorderColors( Q::Handle | Q::Checked | Q::Pressed,
qskShadedColor(m_pal.secondary, m_pal.pressed ) );
setGradient( Q::Ripple | state, weak );
setGradient( Q::Ripple | Q::Checked | state, strong );
}
setBoxBorderColors( Q::Handle | Q::Hovered,
qskShadedColor(m_pal.secondaryVariantNoSaturation,
m_pal.hover ) );
setBoxBorderColors( Q::Handle | Q::Focused,
qskShadedColor(m_pal.secondaryVariantNoSaturation,
m_pal.focused ) );
setBoxBorderColors( Q::Handle | Q::Pressed,
qskShadedColor(m_pal.secondaryVariantNoSaturation,
m_pal.pressed ) );
for( auto state : { A::NoState, Q::Disabled } )
{
@ -597,7 +554,33 @@ void Editor::setupTabButton()
edge = Qt::Edge( 0 ); // making gcc4 happy
}
setGradient( aspect, QskRgb::White );
QskBoxBorderColors borderColors( m_pal.primary );
auto borderColorsActive = m_pal.onPrimary;
switch ( m_pal.lightness ) {
case ColorPalette::light:
setGradient( aspect, m_pal.primary );
setColor( Q::Text, qskShadedColor( m_pal.onPrimary, 0.6 ) );
setColor( Q::Text | Q::Disabled,
qskShadedColor( m_pal.onPrimary,
m_pal.widgetBackgroundDisabled ) );
setColor( Q::Text | Q::Checked, m_pal.onPrimary);
setColor( Q::Text | Q::Hovered, m_pal.onPrimary);
break;
case ColorPalette::dark:
setGradient( aspect, qskShadedColor(m_pal.background, 0.1) );
setColor( Q::Text, qskShadedColor( m_pal.primary, 0.6 ) );
setColor( Q::Text | Q::Disabled,
qskShadedColor( m_pal.primary,
m_pal.widgetBackgroundDisabled ) );
setColor( Q::Text | Q::Checked, m_pal.primary);
setColor( Q::Text | Q::Hovered, m_pal.primary);
borderColors = QskBoxBorderColors( m_pal.background );
borderColorsActive = m_pal.primary;
break;
}
// The highlighted button has a accented bar at one edge
setBoxShape( aspect, 0 );
@ -606,22 +589,20 @@ void Editor::setupTabButton()
border.setWidthAt( edge, 3 );
setBoxBorderMetrics( aspect, border );
QskBoxBorderColors borderColors( QskRgb::White );
setBoxBorderColors( aspect, borderColors );
borderColors.setColorsAt( edge, m_pal.accentColor );
borderColors.setColorsAt( edge, borderColorsActive );
for ( auto state : { Q::Checked, Q::Pressed, Q::Hovered } )
{
setBoxBorderColors( aspect | state, borderColors );
}
}
setAnimation( Q::Panel | A::Color, qskDuration );
// text
setFontRole( Q::Text, ButtonFontRole );
setAlignment( Q::Text, Qt::AlignCenter );
setColor( Q::Text, m_pal.textColor );
setColor( Q::Text | Q::Disabled, qskShadedColor( m_pal.textColor, 0.6 ) );
}
void Editor::setupTabBar()
@ -631,21 +612,24 @@ void Editor::setupTabBar()
setBoxShape( Q::Panel, 0 );
setBoxBorderMetrics( Q::Panel, 0 );
setGradient( Q::Panel, QskGradient() );
switch ( m_pal.lightness ) {
case ColorPalette::light:
setGradient( Q::Panel, m_pal.primary );
break;
case ColorPalette::dark:
setGradient( Q::Panel, m_pal.background );
break;
}
// when flicking
setAnimation( Q::Panel | A::Metric, QskAnimationHint( 200, QEasingCurve::InCubic ) );
}
void Editor::setupTabView()
{
void Editor::setupTabView() {
using Q = QskTabView;
setBoxShape( Q::Page, 0 );
setBoxBorderMetrics( Q::Page, 0 );
setGradient( Q::Page, m_pal.darker150 );
setBoxBorderColors( Q::Page, m_pal.baseColor );
setAnimation( Q::Page, qskDuration );
}
@ -655,8 +639,8 @@ void Editor::setupInputPanel()
setBoxShape( Q::Panel, 0 );
setBoxBorderMetrics( Q::Panel, 0 );
setGradient( Q::Panel, m_pal.darker150 );
setBoxBorderColors( Q::Panel, m_pal.baseColor );
setGradient( Q::Panel, m_pal.elevated(m_pal.background, 1) );
setBoxBorderColors( Q::Panel, m_pal.background );
}
void Editor::setupVirtualKeyboard()
@ -669,12 +653,11 @@ void Editor::setupVirtualKeyboard()
setBoxShape( Q::ButtonPanel, 20.0, Qt::RelativeSize );
setBoxBorderMetrics( Q::ButtonPanel, 2 );
setGradient( Q::ButtonPanel, m_pal.darker125 );
setBoxBorderColors( Q::ButtonPanel, m_pal.baseColor );
setBoxBorderColors( Q::ButtonPanel, m_pal.background );
for ( auto state : { A::NoState, Q::Focused } )
setBoxBorderColors( Q::ButtonPanel | QskPushButton::Pressed | state, m_pal.accentColor );
setBoxBorderColors( Q::ButtonPanel | QskPushButton::Pressed | state,
m_pal.secondary );
setAnimation( Q::ButtonPanel | A::Color, qskDuration );
setAnimation( Q::ButtonPanel | A::Metric, qskDuration );
@ -682,8 +665,8 @@ void Editor::setupVirtualKeyboard()
// panel
setBoxShape( Q::Panel, 0 );
setBoxBorderMetrics( Q::Panel, 0 );
setGradient( Q::Panel, m_pal.darker150 );
setBoxBorderColors( Q::Panel, m_pal.baseColor );
setGradient( Q::Panel, m_pal.elevated(m_pal.background, 1) );
setBoxBorderColors( Q::Panel, m_pal.background );
}
void Editor::setupScrollView()
@ -691,16 +674,15 @@ void Editor::setupScrollView()
using A = QskAspect;
using Q = QskScrollView;
setSpacing( Q::Panel, 2 );
setSpacing( Q::Panel, 5 );
setBoxShape( Q::Viewport, 5 );
setBoxBorderMetrics( Q::Viewport, 1 );
setGradient( Q::Viewport, QskRgb::White );
setBoxBorderColors( Q::Viewport, Qt::black );
setGradient( Q::Viewport, m_pal.background );
setBoxBorderColors( Q::Viewport, m_pal.onBackground );
for ( auto subControl : { Q::HorizontalScrollBar, Q::VerticalScrollBar } )
{
setMetric( subControl | A::Size, 12 );
setMetric( subControl | A::Size, 10 );
setPadding( subControl, 0 );
}
@ -711,37 +693,36 @@ void Editor::setupScrollView()
for ( auto subControl : { Q::HorizontalScrollHandle, Q::VerticalScrollHandle } )
{
setBoxShape( subControl, 3 );
setBoxBorderMetrics( subControl, 1 );
setGradient( subControl, m_pal.accentColor );
setBoxBorderColors( subControl, QskRgb::White );
setBoxBorderMetrics( subControl, 0 );
setColor( subControl, qskShadedColor( m_pal.onBackground, m_pal.hover) );
setAnimation( subControl | A::Color, qskDuration );
}
for ( auto subControl : {
Q::HorizontalScrollHandle | Q::HorizontalHandlePressed,
Q::VerticalScrollHandle | Q::VerticalHandlePressed } )
Q::VerticalScrollHandle | Q::VerticalHandlePressed
} )
{
setGradient( subControl, m_pal.accentColor );
setBoxBorderColors( subControl, m_pal.accentColor );
setColor( subControl,
qskShadedColor( m_pal.onBackground, m_pal.pressed) );
}
// when changing the position by QskScrollView::scrollTo
setAnimation( Q::Viewport | A::Metric, QskAnimationHint( 200, QEasingCurve::InCubic ) );
}
void Editor::setupListView()
{
using Q = QskListView;
// padding for each cell
setPadding( Q::Cell, QskMargins( 4, 8 ) );
setPadding( Q::Cell, 0 );
setColor( Q::Cell, m_pal.baseColor );
setColor( Q::Text, m_pal.textColor );
setColor( Q::Cell, m_pal.background );
setColor( Q::Text, m_pal.onBackground );
setColor( Q::CellSelected, m_pal.accentColor );
setColor( Q::TextSelected, m_pal.contrastColor );
setColor( Q::CellSelected, qskShadedColor(m_pal.onBackground, m_pal.focused) );
setColor( Q::TextSelected, m_pal.onBackground );
}
void Editor::setupSubWindow()
@ -754,20 +735,16 @@ void Editor::setupSubWindow()
setPadding( Q::Panel, 10 );
setBoxShape( Q::Panel, 0 );
setBoxBorderMetrics( Q::Panel, 2 );
setGradient( Q::Panel, m_pal.baseColor );
setGradient( Q::Panel, m_pal.onBackground );
QskBoxBorderColors colors;
colors.setColorsAt( Qt::TopEdge | Qt::LeftEdge, m_pal.lighter125 );
colors.setColorsAt( Qt::RightEdge | Qt::BottomEdge, m_pal.darker200 );
setBoxBorderColors( Q::Panel, colors );
setBoxBorderColors( Q::Panel, m_pal.primary);
// TitleBarPanel
setFlagHint( Q::TitleBarPanel | QskAspect::Style,
Q::TitleBar | Q::Title | Q::Symbol );
setGradient( Q::TitleBarPanel, m_pal.darker200 );
setGradient( Q::TitleBarPanel | Q::Focused, m_pal.accentColor );
setGradient( Q::TitleBarPanel, m_pal.primary );
setGradient( Q::TitleBarPanel | Q::Focused, m_pal.primaryVariant );
// TitleBarText
setFontRole( Q::TitleBarText, QskSkin::SmallFont );
@ -784,13 +761,10 @@ class QskMaterialSkin::PrivateData
ColorPalette palette;
};
QskMaterialSkin::QskMaterialSkin( QObject* parent )
QskMaterialSkin::QskMaterialSkin( ColorPalette colors, QObject* parent )
: Inherited( parent )
, m_data( new PrivateData() )
, m_data( new PrivateData { colors } )
{
m_data->palette = ColorPalette( QskRgb::Grey100,
QskRgb::Blue500, QskRgb::White );
// Default theme colors
setupFonts( "Roboto" );
@ -806,13 +780,4 @@ QskMaterialSkin::~QskMaterialSkin()
{
}
void QskMaterialSkin::resetColors( const QColor& accent )
{
m_data->palette = ColorPalette( m_data->palette.baseColor,
accent, m_data->palette.contrastColor );
Editor editor( &hintTable(), m_data->palette );
editor.setup();
}
#include "moc_QskMaterialSkin.cpp"

View File

@ -8,8 +8,89 @@
#include "QskMaterialGlobal.h"
#include <QskSkin.h>
#include <QskRgbValue.h>
#include <memory>
struct ColorPalette
{
enum Lightness { light, dark } lightness;
QColor primary;
QColor primaryVariant;
QColor onPrimary;
QColor secondary;
QColor secondaryVariant;
QColor onSecondary;
QColor background;
QColor onBackground;
QColor error;
QColor onError;
QColor primaryNoSaturation = QColor::fromHsl(primary.hslHue(), 0,
primary.lightness() );
QColor secondaryNoSaturation =
QColor::fromHsl(secondary.hslHue(), 0,
secondary.lightness() );
QColor secondaryVariantNoSaturation =
QColor::fromHsl(secondaryVariant.hslHue(), 0,
secondaryVariant.lightness() +
secondaryVariant.hslSaturation() );
qreal disabledOccupancy = 0.2;
qreal widgetBackgroundDisabled = 0.6;
qreal hover = 0.1;
qreal focused = 0.4;
qreal pressed = 0.5;
qreal disabled = 0.3;
ColorPalette(
Lightness lightness = light,
QColor primary = QColor::fromRgb(0x6200EE),
QColor primaryVariant = QColor::fromRgb(0x3700B3),
QColor onPrimary = Qt::white,
QColor secondary = QColor::fromRgb(0x03DAC6),
QColor secondaryVariant = QColor::fromRgb(0x018786),
QColor onSecondary = Qt::white,
QColor background = QColor::fromRgba( QskRgb::Grey100 ),
QColor onBackground = Qt::black,
QColor error = QColor::fromRgb(0xB00020),
QColor onError = Qt::white):
lightness(lightness),
primary(primary),
primaryVariant(primaryVariant),
onPrimary(onPrimary),
secondary(secondary),
secondaryVariant(secondaryVariant),
onSecondary(onSecondary),
background(background),
onBackground(onBackground),
error(error),
onError(onError)
{
primaryNoSaturation = QColor::fromHsl(primary.hslHue(), 0,
primary.lightness() );
secondaryNoSaturation = QColor::fromHsl(secondary.hslHue(),
0,
secondary.lightness() );
secondaryVariantNoSaturation =
QColor::fromHsl( secondaryVariant.hslHue(), 0,
secondaryVariant.lightness() );
}
inline QColor elevated( const QColor target, const float level = 1 ) const {
return ( lightness == light ) ? target.darker(100 + level * 15)
: target.lighter(130 + level * 30);
}
};
class QSK_MATERIAL_EXPORT QskMaterialSkin : public QskSkin
{
Q_OBJECT
@ -17,12 +98,10 @@ class QSK_MATERIAL_EXPORT QskMaterialSkin : public QskSkin
using Inherited = QskSkin;
public:
QskMaterialSkin( QObject* parent = nullptr );
QskMaterialSkin( ColorPalette, QObject* parent = nullptr );
~QskMaterialSkin() override;
private:
void resetColors( const QColor& accent ) override;
class PrivateData;
std::unique_ptr< PrivateData > m_data;
};

View File

@ -6,7 +6,8 @@
#include "QskMaterialSkinFactory.h"
#include "QskMaterialSkin.h"
static const QString materialSkinName = QStringLiteral( "material" );
static const QString materialLightSkinName = QStringLiteral( "materialLight" );
static const QString materialDarkSkinName = QStringLiteral( "materialDark" );
QskMaterialSkinFactory::QskMaterialSkinFactory( QObject* parent )
: QskSkinFactory( parent )
@ -19,13 +20,30 @@ QskMaterialSkinFactory::~QskMaterialSkinFactory()
QStringList QskMaterialSkinFactory::skinNames() const
{
return { materialSkinName };
return { materialLightSkinName, materialDarkSkinName };
}
QskSkin* QskMaterialSkinFactory::createSkin( const QString& skinName )
{
if ( skinName.toLower() == materialSkinName )
return new QskMaterialSkin();
if (QString::compare(skinName, materialLightSkinName, Qt::CaseInsensitive)) {
return new QskMaterialSkin(ColorPalette());
}
if (QString::compare(skinName, materialDarkSkinName, Qt::CaseInsensitive) ) {
return new QskMaterialSkin( ColorPalette(
ColorPalette::dark, // lightness
QColor::fromRgb(0xBB86FC), // primary
QColor::fromRgb(0x3700B3), // primaryVariant
Qt::black, // onPrimary
QColor::fromRgb(0x03DAC6), // secondary
QColor::fromRgb(0x018786), // secondaryVariant
Qt::black, // onSecondary
QColor::fromRgb( 0x121212 ), // background
Qt::white, // onBackground
QColor::fromRgb(0xCF6679), // error
Qt::black // onError
));
}
return nullptr;
}

View File

@ -1,4 +1,4 @@
{
"FactoryId": "MaterialFactory",
"Skins": [ "material" ]
"Skins": [ "materialLight", "materialDark" ]
}

View File

@ -319,6 +319,9 @@ QskTextInput::QskTextInput( QQuickItem* parent )
m_data->textInput->setAcceptedMouseButtons( Qt::NoButton );
initSizePolicy( QskSizePolicy::Minimum, QskSizePolicy::Fixed );
setAcceptHoverEvents( true );
}
QskTextInput::QskTextInput( const QString& text, QQuickItem* parent )