qskinny/skins/material3/QskMaterial3Skin.cpp

1015 lines
31 KiB
C++
Raw Normal View History

2017-07-21 18:21:34 +02:00
/******************************************************************************
2022-07-06 14:48:06 +02:00
* QSkinny - Copyright (C) 2022 Edelhirsch Software GmbH
* This file may be used under the terms of the 3-clause BSD License
2017-07-21 18:21:34 +02:00
*****************************************************************************/
2022-07-05 08:36:25 +02:00
#include "QskMaterial3Skin.h"
2017-07-21 18:21:34 +02:00
2020-12-26 12:57:08 +01:00
#include <QskSkinHintTableEditor.h>
2019-12-15 13:57:19 +01:00
#include <QskBox.h>
#include <QskCheckBox.h>
#include <QskDialogButton.h>
2018-08-03 08:15:28 +02:00
#include <QskDialogButtonBox.h>
#include <QskFocusIndicator.h>
#include <QskFunctions.h>
2018-06-12 08:20:48 +02:00
#include <QskInputPanelBox.h>
#include <QskListView.h>
2022-04-05 11:38:23 +02:00
#include <QskMenu.h>
2017-07-21 18:21:34 +02:00
#include <QskPageIndicator.h>
#include <QskPushButton.h>
2020-08-01 17:51:45 +02:00
#include <QskProgressBar.h>
#include <QskScrollView.h>
#include <QskSegmentedBar.h>
#include <QskSeparator.h>
2022-06-13 12:54:17 +02:00
#include <QskShadowMetrics.h>
2017-07-21 18:21:34 +02:00
#include <QskSlider.h>
#include <QskSubWindow.h>
2021-08-02 13:22:37 +02:00
#include <QskSwitchButton.h>
#include <QskSwitchButtonSkinlet.h>
2017-07-21 18:21:34 +02:00
#include <QskTabBar.h>
2018-08-03 08:15:28 +02:00
#include <QskTabButton.h>
2017-07-21 18:21:34 +02:00
#include <QskTabView.h>
#include <QskTextInput.h>
2018-08-03 08:15:28 +02:00
#include <QskTextLabel.h>
#include <QskVirtualKeyboard.h>
2017-07-21 18:21:34 +02:00
2018-08-03 08:15:28 +02:00
#include <QskAnimationHint.h>
2017-07-21 18:21:34 +02:00
#include <QskAspect.h>
2018-08-03 08:15:28 +02:00
#include <QskBoxBorderColors.h>
#include <QskBoxBorderMetrics.h>
#include <QskBoxShapeMetrics.h>
#include <QskMargins.h>
2022-07-15 08:39:52 +02:00
#include <QskRgbValue.h>
2017-07-21 18:21:34 +02:00
#include <QskNamespace.h>
#include <QskPlatform.h>
#include <qguiapplication.h>
#include <qscreen.h>
2017-07-21 18:21:34 +02:00
static const int qskDuration = 150;
namespace
{
// see: https://en.wikipedia.org/wiki/Device-independent_pixel
inline qreal dpToPixels( long double value )
{
static qreal factor = -1.0;
if ( factor < 0.0 )
{
factor = 1.0;
#if 0
if ( const auto screen = QGuiApplication::primaryScreen() )
{
// is this calculation correct ? TODO ...
factor = screen->logicalDotsPerInch() / 160.0;
}
#endif
}
return value * factor;
}
inline double operator ""_dp( long double value )
{
return dpToPixels( value );
}
inline double operator ""_dp( unsigned long long int value )
{
return dpToPixels( value );
}
2020-12-26 12:57:08 +01:00
class Editor : private QskSkinHintTableEditor
{
public:
2022-07-05 08:36:25 +02:00
Editor( QskSkinHintTable* table, const QskMaterial3Theme& palette )
2020-12-26 12:57:08 +01:00
: QskSkinHintTableEditor( table )
, m_pal( palette )
{
}
2017-07-21 18:21:34 +02:00
2020-12-26 12:57:08 +01:00
void setup();
private:
void setupControl();
2021-08-02 13:22:37 +02:00
2020-12-26 12:57:08 +01:00
void setupBox();
void setupCheckBox();
2020-12-26 12:57:08 +01:00
void setupDialogButtonBox();
void setupDialogButton();
void setupFocusIndicator();
void setupInputPanel();
void setupVirtualKeyboard();
void setupListView();
2022-04-05 11:38:23 +02:00
void setupMenu();
2020-12-26 12:57:08 +01:00
void setupPageIndicator();
void setupPopup();
void setupProgressBar();
void setupPushButton();
void setupScrollView();
void setupSegmentedBar();
2020-12-26 12:57:08 +01:00
void setupSeparator();
void setupSubWindow();
void setupSlider();
2021-08-02 13:22:37 +02:00
void setupSwitchButton();
2020-12-26 12:57:08 +01:00
void setupTabButton();
void setupTabBar();
void setupTabView();
void setupTextInput();
void setupTextLabel();
2022-07-05 08:36:25 +02:00
const QskMaterial3Theme& m_pal;
2020-12-26 12:57:08 +01:00
};
2022-06-07 12:40:21 +02:00
QFont createFont( int pixelSize, qreal tracking, QFont::Weight weight )
2022-06-07 12:40:21 +02:00
{
QFont font( "Roboto" );
font.setPixelSize( pixelSize );
if( !qskFuzzyCompare( tracking, 0.0 ) )
{
font.setLetterSpacing( QFont::AbsoluteSpacing, tracking );
}
2022-06-07 12:40:21 +02:00
font.setWeight( weight );
return font;
}
2022-06-14 11:33:22 +02:00
2022-07-15 08:39:52 +02:00
inline QRgb flattenedColor(
QRgb foregroundColor, QRgb backgroundColor, qreal ratio )
2022-06-14 11:33:22 +02:00
{
2022-07-15 08:39:52 +02:00
return QskRgb::interpolated( backgroundColor, foregroundColor, ratio );
2022-06-14 11:33:22 +02:00
}
2022-07-06 10:39:17 +02:00
2022-07-15 08:39:52 +02:00
inline QRgb stateLayerColor( QRgb rgb, qreal opacity )
2022-07-06 10:39:17 +02:00
{
2022-07-15 08:39:52 +02:00
return QskRgb::toTransparentF( rgb, opacity );
2022-07-06 10:39:17 +02:00
}
2017-07-21 18:21:34 +02:00
}
2020-12-26 12:57:08 +01:00
void Editor::setup()
2017-07-21 18:21:34 +02:00
{
2020-12-26 12:57:08 +01:00
setupControl();
setupBox();
setupCheckBox();
2020-12-26 12:57:08 +01:00
setupDialogButtonBox();
setupDialogButton();
setupFocusIndicator();
setupInputPanel();
setupVirtualKeyboard();
setupListView();
2022-04-05 11:38:23 +02:00
setupMenu();
2020-12-26 12:57:08 +01:00
setupPageIndicator();
setupPopup();
setupProgressBar();
setupPushButton();
setupScrollView();
setupSegmentedBar();
2020-12-26 12:57:08 +01:00
setupSeparator();
setupSlider();
setupSubWindow();
2021-08-02 13:22:37 +02:00
setupSwitchButton();
2020-12-26 12:57:08 +01:00
setupTabButton();
setupTabBar();
setupTabView();
setupTextLabel();
setupTextInput();
2017-07-21 18:21:34 +02:00
}
2020-12-26 12:57:08 +01:00
void Editor::setupControl()
2017-07-21 18:21:34 +02:00
{
2020-12-21 16:06:58 +01:00
using A = QskAspect;
2017-07-21 18:21:34 +02:00
2022-02-17 21:54:56 +01:00
setPadding( A::Control, 11 );
2017-07-21 18:21:34 +02:00
2022-02-17 21:54:56 +01:00
setGradient( A::Control, m_pal.background );
setColor( A::Control | A::StyleColor, m_pal.onBackground );
2017-07-21 18:21:34 +02:00
}
void Editor::setupCheckBox()
{
using Q = QskCheckBox;
2022-07-05 10:32:05 +02:00
setSpacing( Q::Panel, 10 );
2022-07-05 10:32:05 +02:00
setStrutSize( Q::Box, 24, 24 );
2022-07-05 10:32:05 +02:00
setPadding( Q::Box, 6 );
setBoxShape( Q::Box, 2 );
setBoxBorderMetrics( Q::Box, 2 );
setBoxBorderColors( Q::Box, m_pal.onBackground );
setBoxBorderMetrics( Q::Box | Q::Checked, 0 );
2022-07-05 10:32:05 +02:00
setGradient( Q::Box, m_pal.background );
setGradient( Q::Box | Q::Checked, m_pal.primary );
setGradient( Q::Box | Q::Disabled, m_pal.surfaceVariant12 );
setGradient( Q::Box | Q::Checked | Q::Disabled, m_pal.onSurface12 );
2022-07-05 10:32:05 +02:00
setColor( Q::Indicator, m_pal.background );
setColor( Q::Indicator | Q::Checked, m_pal.onPrimary );
2022-06-17 17:37:44 +02:00
setColor( Q::Indicator | Q::Checked | Q::Disabled, m_pal.onSurface38 );
2022-07-05 10:32:05 +02:00
setColor( Q::Text, m_pal.onBackground );
2022-08-25 09:39:33 +02:00
setTextOptions( Q::Text, Qt::ElideMiddle, QskTextOptions::NoWrap );
}
2020-12-26 12:57:08 +01:00
void Editor::setupBox()
2019-12-15 13:57:19 +01:00
{
using Q = QskBox;
using A = QskAspect;
2019-12-15 13:57:19 +01:00
2022-02-17 21:54:56 +01:00
setGradient( Q::Panel, m_pal.background );
setGradient( Q::Panel | A::Header, m_pal.surface2 );
setGradient( Q::Panel | A::Footer, m_pal.surface2 );
2019-12-15 13:57:19 +01:00
}
2020-12-26 12:57:08 +01:00
void Editor::setupPopup()
2017-07-21 18:21:34 +02:00
{
2020-12-21 16:06:58 +01:00
using A = QskAspect;
2017-07-21 18:21:34 +02:00
using Q = QskPopup;
2020-12-26 12:57:08 +01:00
setFlagHint( Q::Overlay | A::Style, true );
2022-07-12 13:47:39 +02:00
setGradient( Q::Overlay, stateLayerColor( m_pal.outline, 0.8 ) );
2017-07-21 18:21:34 +02:00
}
2022-04-05 11:38:23 +02:00
void Editor::setupMenu()
{
using A = QskAspect;
using Q = QskMenu;
2022-06-13 15:36:06 +02:00
setBoxShape( Q::Panel, 4 );
setBoxBorderMetrics( Q::Panel, 0 );
setPadding( Q::Panel, 0 );
2022-04-05 11:38:23 +02:00
2022-06-14 11:33:22 +02:00
// The color here is primary with an opacity of 8% - we blend that
// with the background, because we don't want the menu to have transparency:
2022-07-15 08:39:52 +02:00
const auto panel = flattenedColor( m_pal.primary, m_pal.background, 0.08 );
2022-06-14 11:33:22 +02:00
setGradient( Q::Panel, panel );
setShadowMetrics( Q::Panel, m_pal.elevationLight2 );
setShadowColor( Q::Panel, m_pal.shadow );
2022-04-05 11:38:23 +02:00
setMetric( Q::Separator | A::Size, qskDpiScaled( 1 ) );
setBoxShape( Q::Separator, 0 );
setBoxBorderMetrics( Q::Separator, 0 );
2022-06-17 17:37:44 +02:00
setGradient( Q::Separator, m_pal.primary12 );
2022-04-05 11:38:23 +02:00
2022-06-13 15:36:06 +02:00
setPadding( Q::Segment, 6 );
setSpacing( Q::Segment, 5 );
setGradient( Q::Segment, Qt::transparent );
2022-04-05 11:38:23 +02:00
2022-06-17 17:37:44 +02:00
setGradient( Q::Cursor, m_pal.primary12 );
2022-04-05 11:38:23 +02:00
2022-06-13 15:36:06 +02:00
setPadding( Q::Graphic, 7 );
setStrutSize( Q::Graphic, { 46, -1 } );
setColor( Q::Text, m_pal.onSurface );
setFontRole( Q::Text, QskMaterial3Skin::M3BodyMedium );
2022-04-05 11:38:23 +02:00
setPosition( Q::Panel, 0 );
setPosition( Q::Panel | QskPopup::Closed, 1 );
setAnimation( Q::Panel | A::Metric, 150 );
setAnimation( Q::Cursor | A::Position | A::Metric, 75, QEasingCurve::OutCubic );
}
2020-12-26 12:57:08 +01:00
void Editor::setupTextLabel()
2017-07-21 18:21:34 +02:00
{
using Q = QskTextLabel;
setAlignment( Q::Text, Qt::AlignCenter );
setColor( Q::Text, m_pal.onSurface );
2019-12-15 13:57:19 +01:00
setPadding( Q::Panel, 5 );
2017-07-21 18:21:34 +02:00
}
2022-02-17 21:54:56 +01:00
2020-12-26 12:57:08 +01:00
void Editor::setupTextInput()
{
using Q = QskTextInput;
setAlignment( Q::Text, Qt::AlignLeft | Qt::AlignTop );
2022-02-17 21:54:56 +01:00
setColor( Q::Text, m_pal.onBackground );
setPadding( Q::Panel, 5 );
2022-02-17 21:54:56 +01:00
setBoxShape( Q::Panel, 4, 4, 0, 0 );
setBoxBorderMetrics( Q::Panel, 0, 0, 0, 1 );
setBoxBorderColors( Q::Panel, m_pal.onSurface );
2022-02-17 21:54:56 +01:00
setBoxBorderMetrics( Q::Panel | Q::Focused, 0, 0, 0, 2 );
setBoxBorderColors( Q::Panel | Q::Focused, m_pal.primary );
2022-02-17 21:54:56 +01:00
setBoxBorderMetrics( Q::Panel | Q::Editing, 0, 0, 0, 2 );
setBoxBorderColors( Q::Panel | Q::Editing, m_pal.primary );
setBoxBorderMetrics( Q::Panel | Q::Hovered, 0, 0, 0, 1 );
setBoxBorderColors( Q::Panel | Q::Hovered, m_pal.onSurface );
2022-02-17 21:54:56 +01:00
setGradient( Q::Panel, m_pal.surfaceVariant );
2022-04-02 11:50:55 +02:00
2022-07-15 08:39:52 +02:00
const auto c1 = QskRgb::toTransparentF( m_pal.onSurface, 0.04 );
setGradient( Q::Panel | Q::Disabled, c1 );
setBoxBorderMetrics( Q::Panel | Q::Disabled, 0, 0, 0, 1 );
2022-02-17 21:54:56 +01:00
2022-06-17 17:37:44 +02:00
setColor( Q::Text | Q::Disabled, m_pal.onSurface38 );
setBoxBorderColors( Q::Panel | Q::Disabled, m_pal.onSurface38 );
}
2020-12-26 12:57:08 +01:00
void Editor::setupProgressBar()
2020-07-31 16:57:22 +02:00
{
2020-12-21 16:06:58 +01:00
using A = QskAspect;
2020-08-01 17:51:45 +02:00
using Q = QskProgressBar;
2020-07-31 16:57:22 +02:00
2022-02-17 21:54:56 +01:00
auto size = qskDpiScaled( 5 );
2020-08-06 09:28:18 +02:00
for ( auto subControl : { Q::Groove, Q::Bar } )
2020-12-05 15:09:31 +01:00
{
2022-02-17 21:54:56 +01:00
setMetric( subControl | A::Size, size );
setPadding( subControl, 0 );
2020-12-05 15:09:31 +01:00
2020-08-06 09:28:18 +02:00
setBoxShape( subControl, 0 );
setBoxBorderMetrics( subControl, 0 );
2020-12-05 15:09:31 +01:00
}
2020-07-31 16:57:22 +02:00
2022-02-17 21:54:56 +01:00
setMetric( Q::Groove | A::Size, size );
setGradient( Q::Groove, m_pal.primaryContainer );
2022-06-17 17:37:44 +02:00
setGradient( Q::Groove | Q::Disabled, m_pal.onSurface12 );
2022-02-17 21:54:56 +01:00
setGradient( Q::Bar, m_pal.primary );
2022-06-17 17:37:44 +02:00
setGradient( Q::Bar | Q::Disabled, m_pal.onSurface38 );
2020-07-31 16:57:22 +02:00
}
2020-12-26 12:57:08 +01:00
void Editor::setupFocusIndicator()
2017-07-21 18:21:34 +02:00
{
using Q = QskFocusIndicator;
setGradient( Q::Panel, QskGradient() );
2017-07-21 18:21:34 +02:00
}
void Editor::setupSegmentedBar()
{
// copied from Squiek: we need something similar to a tab bar here. TODO ...
using A = QskAspect;
using Q = QskSegmentedBar;
2022-06-17 12:50:35 +02:00
const QSize strutSize( -1, 40 );
{
// Panel
setPadding( Q::Panel, 0 );
2022-06-16 09:47:17 +02:00
setSpacing( Q::Panel, 0 );
setBoxShape( Q::Panel, 100, Qt::RelativeSize );
setBoxBorderMetrics( Q::Panel, 1 );
setBoxBorderColors( Q::Panel, m_pal.outline );
2022-06-17 18:20:34 +02:00
setBoxBorderColors( Q::Panel | Q::Disabled, m_pal.onSurface12 );
setStrutSize( Q::Panel | A::Horizontal, strutSize );
setStrutSize( Q::Panel | A::Vertical, strutSize.transposed() );
}
{
// Segment
2022-06-16 09:47:17 +02:00
setGradient( Q::Segment, Qt::transparent );
2022-06-17 12:50:35 +02:00
setPadding( Q::Segment, 0 );
}
2022-06-16 09:47:17 +02:00
2022-06-17 12:50:35 +02:00
{
// Separator
setStrutSize( Q::Separator | A::Horizontal, 1, strutSize.height() );
setStrutSize( Q::Separator | A::Vertical, strutSize.height(), 1 );
setPadding( Q::Separator, 0 );
setGradient( Q::Separator, m_pal.outline );
2022-06-17 18:20:34 +02:00
setColor( Q::Separator | Q::Disabled, m_pal.onSurface38 );
}
{
// Cursor
2022-06-16 09:47:17 +02:00
setMargin( Q::Cursor, 1 );
setBoxShape( Q::Cursor, 0 );
2022-06-17 18:20:34 +02:00
setBoxShape( Q::Cursor | Q::Minimum | A::Horizontal,
{ 100, 0, 100, 0, Qt::RelativeSize },
{ QskStateCombination::CombinationNoState, Q::Disabled } );
setBoxShape( Q::Cursor | Q::Maximum | A::Horizontal,
{ 0, 100, 0, 100, Qt::RelativeSize },
{ QskStateCombination::CombinationNoState, Q::Disabled } );
2022-06-16 09:47:17 +02:00
2022-06-17 18:20:34 +02:00
setBoxShape( Q::Cursor | Q::Minimum | A::Vertical,
{ 100, 100, 0, 0, Qt::RelativeSize },
{ QskStateCombination::CombinationNoState, Q::Disabled } );
setBoxShape( Q::Cursor | Q::Maximum | A::Vertical,
{ 0, 0, 100, 100, Qt::RelativeSize },
{ QskStateCombination::CombinationNoState, Q::Disabled } );
2022-06-16 09:47:17 +02:00
setGradient( Q::Cursor, m_pal.secondaryContainer );
2022-06-17 17:37:44 +02:00
setGradient( Q::Cursor | Q::Disabled, m_pal.onSurface12 );
setAnimation( Q::Cursor | A::Metric | A::Position, 100 );
}
{
// Text
2022-07-05 08:36:25 +02:00
setFontRole( Q::Text, QskMaterial3Skin::M3LabelLarge );
2022-08-25 09:39:33 +02:00
setTextOptions( Q::Text, Qt::ElideMiddle, QskTextOptions::NoWrap );
2022-06-17 12:50:35 +02:00
setColor( Q::Text, m_pal.onSurface );
setColor( Q::Text | Q::Selected, m_pal.onSecondaryContainer );
2022-06-17 18:20:34 +02:00
setColor( Q::Text | Q::Disabled, m_pal.onSurface38 );
2022-08-25 09:39:33 +02:00
}
{
// Graphic
2022-06-16 09:47:17 +02:00
setPadding( Q::Graphic, 10 );
setMargin( Q::Graphic, 10 );
}
}
2020-12-26 12:57:08 +01:00
void Editor::setupSeparator()
2017-07-21 18:21:34 +02:00
{
2020-12-21 16:06:58 +01:00
using A = QskAspect;
2017-07-21 18:21:34 +02:00
using Q = QskSeparator;
2020-12-21 16:06:58 +01:00
for ( auto placement : { A::Horizontal, A::Vertical } )
{
const auto aspect = Q::Panel | placement;
2020-12-21 16:06:58 +01:00
setMetric( aspect | A::Size, 4 );
2017-10-18 20:00:06 +02:00
setBoxShape( Q::Panel, 0 );
setBoxBorderMetrics( Q::Panel, 0 );
2022-02-17 21:54:56 +01:00
setGradient( aspect, m_pal.background );
}
2017-07-21 18:21:34 +02:00
}
2020-12-26 12:57:08 +01:00
void Editor::setupPageIndicator()
2017-07-21 18:21:34 +02:00
{
using Q = QskPageIndicator;
2022-01-04 13:58:34 +01:00
const auto extent = qskDpiScaled( 9 );
setStrutSize( Q::Bullet, extent, extent );
2022-01-04 13:58:34 +01:00
// circles, without border
setBoxShape( Q::Bullet, 100, Qt::RelativeSize );
setBoxBorderMetrics( Q::Bullet, 0 );
setGradient( Q::Bullet, m_pal.primaryContainer );
setGradient( Q::Bullet | Q::Selected, m_pal.primary );
2017-07-21 18:21:34 +02:00
2022-06-17 17:37:44 +02:00
setGradient( Q::Bullet | Q::Disabled, m_pal.onSurface12 );
setGradient( Q::Bullet | Q::Selected | Q::Disabled, m_pal.onSurface38 );
2022-02-17 21:54:56 +01:00
setSpacing( Q::Panel, qskDpiScaled( 3 ) );
2022-01-04 13:58:34 +01:00
setPadding( Q::Panel, 0 );
setGradient( Q::Panel, QskGradient() ); // invisible
2017-07-21 18:21:34 +02:00
}
2020-12-26 12:57:08 +01:00
void Editor::setupPushButton()
2017-07-21 18:21:34 +02:00
{
2020-12-21 16:06:58 +01:00
using A = QskAspect;
2017-07-21 18:21:34 +02:00
using Q = QskPushButton;
setFlagHint( Q::Panel | QskAspect::Direction, Qsk::LeftToRight );
setStrutSize( Q::Panel, -1, 31 );
2022-02-17 21:54:56 +01:00
setSpacing( Q::Panel, qskDpiScaled( 4 ) );
setPadding( Q::Panel, { 24, 0, 20, 0 } );
2017-07-21 18:21:34 +02:00
setBoxShape( Q::Panel, 100, Qt::RelativeSize );
2022-08-26 12:56:12 +02:00
setAlignment( Q::Graphic, Qt::AlignCenter );
setStrutSize( Q::Graphic, 24_dp, 24_dp );
setPadding( Q::Graphic, 0 );
2017-07-21 18:21:34 +02:00
2022-07-05 08:36:25 +02:00
setFontRole( Q::Text, QskMaterial3Skin::M3LabelLarge );
setPadding( Q::Text, 0 );
2017-07-21 18:21:34 +02:00
2022-08-26 12:56:12 +02:00
setAlignment( Q::Text | A::Vertical, Qt::AlignCenter );
setAlignment( Q::Text | A::Horizontal, Qt::AlignLeft | Qt::AlignVCenter );
// normal buttons (i.e. Filled):
setGradient( Q::Panel, m_pal.primary );
2022-06-17 17:37:44 +02:00
setGradient( Q::Panel | Q::Disabled, m_pal.onSurface12 );
2017-07-21 18:21:34 +02:00
2022-07-15 08:39:52 +02:00
const auto hoverColor = flattenedColor( m_pal.onPrimary, m_pal.primary, 0.08 );
setGradient( Q::Panel | Q::Hovered, hoverColor );
setShadowMetrics( Q::Panel | Q::Hovered, m_pal.elevationLight1 );
2022-06-13 12:54:17 +02:00
setShadowColor( Q::Panel | Q::Hovered, m_pal.shadow );
2022-07-15 08:39:52 +02:00
const auto focusColor = flattenedColor( m_pal.onPrimary, m_pal.primary, 0.12 );
setGradient( Q::Panel | Q::Focused, focusColor );
setGradient( Q::Panel | Q::Pressed, focusColor );
setGradient( Q::Ripple, stateLayerColor( m_pal.onPrimary, m_pal.hoverOpacity ) );
setColor( Q::Text, m_pal.onPrimary );
setColor( Q::Text | Q::Disabled, m_pal.onSurface38 );
2022-08-25 09:39:33 +02:00
setTextOptions( Q::Text, Qt::ElideMiddle, QskTextOptions::NoWrap );
2020-12-21 16:06:58 +01:00
setAnimation( Q::Panel | A::Color, qskDuration );
setAnimation( Q::Panel | A::Metric, qskDuration );
setAnimation( Q::Ripple | A::Color, qskDuration );
2020-12-21 16:06:58 +01:00
setAnimation( Q::Text | A::Color, qskDuration );
2017-07-21 18:21:34 +02:00
}
2020-12-26 12:57:08 +01:00
void Editor::setupDialogButton()
2017-07-21 18:21:34 +02:00
{
using Q = QskDialogButton;
2022-07-06 10:39:17 +02:00
setStrutSize( Q::Panel, 48, -1 );
setSpacing( Q::Panel, 8 );
setPadding( Q::Panel, { 12, 13, 12, 13 } );
setBoxShape( Q::Panel, 100, Qt::RelativeSize );
setGradient( Q::Panel, m_pal.secondaryContainer );
2017-07-21 18:21:34 +02:00
2022-07-06 10:39:17 +02:00
setGradient( Q::Panel | Q::Hovered, stateLayerColor( m_pal.primary, m_pal.hoverOpacity ) );
setGradient( Q::Panel | Q::Pressed, stateLayerColor( m_pal.primary, m_pal.pressedOpacity ) );
2022-07-06 10:39:17 +02:00
setColor( Q::Text, m_pal.primary );
2022-07-05 08:36:25 +02:00
setFontRole( Q::Text, QskMaterial3Skin::M3LabelLarge );
2017-07-21 18:21:34 +02:00
}
2020-12-26 12:57:08 +01:00
void Editor::setupDialogButtonBox()
2017-07-21 18:21:34 +02:00
{
using Q = QskDialogButtonBox;
2022-07-05 16:15:00 +02:00
setGradient( Q::Panel, m_pal.secondaryContainer );
2017-10-18 20:00:06 +02:00
setBoxShape( Q::Panel, 0 );
setBoxBorderMetrics( Q::Panel, 0 );
2017-07-21 18:21:34 +02:00
}
2020-12-26 12:57:08 +01:00
void Editor::setupSlider()
2017-07-21 18:21:34 +02:00
{
2020-12-21 16:06:58 +01:00
using A = QskAspect;
2017-07-21 18:21:34 +02:00
using Q = QskSlider;
2020-12-17 16:14:56 +01:00
const qreal extent = 30;
2017-07-21 18:21:34 +02:00
// Panel
2020-12-21 16:06:58 +01:00
setMetric( Q::Panel | A::Size, extent );
2017-10-18 20:00:06 +02:00
setBoxShape( Q::Panel, 0 );
setBoxBorderMetrics( Q::Panel, 0 );
setGradient( Q::Panel, QskGradient() );
2020-12-21 16:06:58 +01:00
setPadding( Q::Panel | A::Horizontal, QskMargins( 0.5 * extent, 0 ) );
setPadding( Q::Panel | A::Vertical, QskMargins( 0, 0.5 * extent ) );
// Groove, Fill
2017-07-21 18:21:34 +02:00
for ( auto subControl : { Q::Groove, Q::Fill } )
{
setPadding( subControl, 0 );
2017-10-18 20:00:06 +02:00
setBoxShape( subControl, 0 );
setBoxBorderMetrics( subControl, 0 );
2017-07-21 18:21:34 +02:00
}
2022-02-17 21:54:56 +01:00
setMetric( Q::Groove | A::Size, qskDpiScaled( 4 ) );
setMetric( Q::Fill | A::Size, qskDpiScaled( 6 ) );
2017-07-21 18:21:34 +02:00
setGradient( Q::Groove, m_pal.primaryContainer );
2022-06-17 17:37:44 +02:00
setGradient( Q::Groove | Q::Disabled, m_pal.onSurface12 );
setGradient( Q::Fill, m_pal.primary );
2022-06-17 17:37:44 +02:00
setGradient( Q::Fill | Q::Disabled, m_pal.onSurface38 );
2017-07-21 18:21:34 +02:00
2017-10-18 20:00:06 +02:00
setBoxShape( Q::Handle, 100, Qt::RelativeSize );
2022-02-17 21:54:56 +01:00
setBoxBorderMetrics( Q::Handle, 0 );
2022-07-05 13:27:35 +02:00
setStrutSize( Q::Handle, { 20, 20 } );
2017-07-21 18:21:34 +02:00
setGradient( Q::Handle, m_pal.primary );
setGradient( Q::Handle | Q::Pressed, m_pal.primary );
2017-07-21 18:21:34 +02:00
const auto disabledColor = flattenedColor( m_pal.onSurface, m_pal.background, 0.38 );
setGradient( Q::Handle | Q::Disabled, disabledColor );
2017-07-21 18:21:34 +02:00
2022-07-05 13:27:35 +02:00
setStrutSize( Q::Ripple, { 40, 40 } );
setBoxShape( Q::Ripple, 100, Qt::RelativeSize );
setGradient( Q::Ripple, Qt::transparent );
setGradient( Q::Ripple | Q::Hovered, m_pal.primary12 );
setGradient( Q::Ripple | Q::Pressed, m_pal.primary12 );
2017-07-21 18:21:34 +02:00
// move the handle smoothly, when using keys
2020-12-21 16:06:58 +01:00
setAnimation( Q::Handle | A::Metric | A::Position, 2 * qskDuration );
setAnimation( Q::Handle | A::Metric | A::Position | Q::Pressed, 0 );
2017-07-21 18:21:34 +02:00
}
2021-08-02 13:22:37 +02:00
void Editor::setupSwitchButton()
{
using A = QskAspect;
using Q = QskSwitchButton;
setBoxShape( Q::Groove, 100, Qt::RelativeSize );
const QSizeF strutSize( 52, 32 );
setStrutSize( Q::Groove | A::Horizontal, strutSize );
setStrutSize( Q::Groove | A::Vertical, strutSize.transposed() );
setGradient( Q::Groove, m_pal.surfaceVariant );
2022-06-17 17:37:44 +02:00
setGradient( Q::Groove | Q::Disabled, m_pal.surfaceVariant12 );
setGradient( Q::Groove | Q::Checked, m_pal.primary );
2022-06-17 17:37:44 +02:00
setGradient( Q::Groove | Q::Checked | Q::Disabled, m_pal.onSurface12 );
setBoxBorderMetrics( Q::Groove, 2 );
setBoxBorderColors( Q::Groove, m_pal.outline );
setBoxBorderMetrics( Q::Groove | Q::Checked, 0 );
2021-08-02 19:17:04 +02:00
setBoxShape( Q::Handle, 100, Qt::RelativeSize );
setStrutSize( Q::Handle, 16, 16 );
2022-06-08 11:50:43 +02:00
setStrutSize( Q::Handle | Q::Checked, 24, 24, { QskStateCombination::CombinationNoState, Q::Disabled } );
2022-02-17 21:54:56 +01:00
setGradient( Q::Handle, m_pal.outline );
setGradient( Q::Handle | Q::Checked, m_pal.primaryContainer );
2022-02-17 21:54:56 +01:00
2022-06-17 17:37:44 +02:00
setGradient( Q::Handle | Q::Disabled, m_pal.onSurface38 );
setGradient( Q::Handle | Q::Disabled | Q::Checked, m_pal.surface );
2022-02-17 21:54:56 +01:00
// just to keep the strut size the same at all times:
setStrutSize( Q::Ripple, 40, 40 );
setGradient( Q::Ripple, Qt::transparent );
2022-02-17 21:54:56 +01:00
setStrutSize( Q::Ripple | Q::Hovered, 40, 40 );
setBoxShape( Q::Ripple, 100, Qt::RelativeSize );
2022-07-06 14:23:05 +02:00
setGradient( Q::Ripple | Q::Hovered, stateLayerColor( m_pal.onSurface, m_pal.focusOpacity ) );
setGradient( Q::Ripple | Q::Hovered | Q::Checked, stateLayerColor( m_pal.primary, m_pal.focusOpacity ) );
2022-02-17 21:54:56 +01:00
setBoxBorderColors( Q::Handle, m_pal.outline );
setBoxBorderColors( Q::Handle | Q::Checked, m_pal.primary );
2022-02-17 21:54:56 +01:00
for ( auto state : { A::NoState, Q::Disabled } )
2021-08-02 13:22:37 +02:00
{
2021-12-29 17:05:29 +01:00
auto aspect = Q::Handle | state;
2021-08-02 13:22:37 +02:00
setPosition( aspect, 0.15 );
setPosition( aspect | Q::Checked, 0.85 );
2021-08-02 13:22:37 +02:00
}
setAnimation( Q::Handle | A::Color, qskDuration );
2021-08-02 19:17:04 +02:00
setAnimation( Q::Handle | A::Metric, qskDuration );
2021-08-02 13:22:37 +02:00
setAnimation( Q::Groove | A::Color, qskDuration );
}
2020-12-26 12:57:08 +01:00
void Editor::setupTabButton()
2017-07-21 18:21:34 +02:00
{
2020-12-21 16:06:58 +01:00
using A = QskAspect;
2017-07-21 18:21:34 +02:00
using Q = QskTabButton;
2022-07-06 13:27:35 +02:00
setStrutSize( Q::Panel, 48, 48 );
2022-07-05 12:59:41 +02:00
setGradient( Q::Panel, m_pal.surface );
setColor( Q::Text, m_pal.onSurfaceVariant );
setColor( Q::Text | A::Footer, m_pal.onSecondaryContainer );
2022-06-17 17:37:44 +02:00
setColor( Q::Text | Q::Disabled, m_pal.onSurface38 );
2022-02-17 21:54:56 +01:00
setColor( Q::Text | Q::Checked, m_pal.primary );
setColor( Q::Text | Q::Hovered, m_pal.primary );
2022-07-05 12:59:41 +02:00
for ( const auto placement : { A::Left, A::Right, A::Top, A::Bottom } )
{
const auto aspect = Q::Panel | placement;
Qt::Edge edge;
switch( placement )
{
case A::Left:
edge = Qt::RightEdge;
break;
case A::Right:
edge = Qt::LeftEdge;
break;
case A::Top:
edge = Qt::BottomEdge;
break;
case A::Bottom:
edge = Qt::TopEdge;
break;
default:
edge = Qt::Edge( 0 ); // making gcc4 happy
}
QskBoxBorderMetrics border;
border.setWidthAt( edge, 3 );
setBoxBorderMetrics( aspect, border );
QskBoxBorderColors borderColors( m_pal.surface );
setBoxBorderColors( aspect, borderColors );
borderColors.setGradientAt( edge, m_pal.primary );
setBoxBorderColors( aspect | Q::Checked, borderColors );
}
2022-07-15 08:39:52 +02:00
setGradient( Q::Panel | Q::Hovered,
QskRgb::toTransparentF( m_pal.surface, m_pal.hoverOpacity ) );
setGradient( Q::Panel | Q::Focused,
QskRgb::toTransparentF( m_pal.surface, m_pal.focusOpacity ) );
setGradient( Q::Panel | Q::Pressed,
QskRgb::toTransparentF( m_pal.surface, m_pal.pressedOpacity ) );
2022-02-17 21:54:56 +01:00
setGradient( Q::Panel | A::Footer, m_pal.surface2 );
setGradient( Q::Panel | A::Footer | Q::Checked, m_pal.secondaryContainer );
setGradient( Q::Panel | A::Footer | Q::Hovered, stateLayerColor( m_pal.onSurfaceVariant, m_pal.hoverOpacity ) );
setGradient( Q::Panel | A::Footer | Q::Hovered | Q::Checked, stateLayerColor( m_pal.onSurface, m_pal.hoverOpacity ) );
setGradient( Q::Panel | A::Footer | Q::Focused, stateLayerColor( m_pal.onSurfaceVariant, m_pal.focusOpacity ) );
setGradient( Q::Panel | A::Footer | Q::Focused | Q::Checked, stateLayerColor( m_pal.onSurface, m_pal.focusOpacity ) );
setGradient( Q::Panel | A::Footer | Q::Pressed, stateLayerColor( m_pal.onSurfaceVariant, m_pal.pressedOpacity ) );
setGradient( Q::Panel | A::Footer | Q::Pressed | Q::Checked, stateLayerColor( m_pal.onSurface, m_pal.pressedOpacity ) );
2020-12-21 16:06:58 +01:00
setAnimation( Q::Panel | A::Color, qskDuration );
2017-07-21 18:21:34 +02:00
2022-07-05 08:36:25 +02:00
setFontRole( Q::Text, QskMaterial3Skin::M3LabelLarge );
setAlignment( Q::Text, Qt::AlignCenter );
2017-07-21 18:21:34 +02:00
}
2020-12-26 12:57:08 +01:00
void Editor::setupTabBar()
2017-07-21 18:21:34 +02:00
{
2020-12-21 16:06:58 +01:00
using A = QskAspect;
using Q = QskTabBar;
2017-10-18 20:00:06 +02:00
setBoxShape( Q::Panel, 0 );
setBoxBorderMetrics( Q::Panel, 0 );
2022-02-17 21:54:56 +01:00
setGradient( Q::Panel, m_pal.secondaryContainer );
2022-02-17 21:54:56 +01:00
setPadding( Q::Panel, 0 );
2020-03-13 07:39:31 +01:00
setFlagHint( Q::Panel | A::Style, Qt::BottomEdge );
2020-03-13 07:39:31 +01:00
// when flicking
2020-12-21 16:06:58 +01:00
setAnimation( Q::Panel | A::Metric, QskAnimationHint( 200, QEasingCurve::InCubic ) );
2017-07-21 18:21:34 +02:00
}
void Editor::setupTabView()
{
using Q = QskTabView;
setGradient( Q::Page, m_pal.background );
setAnimation( Q::Page, qskDuration );
2017-07-21 18:21:34 +02:00
}
2020-12-26 12:57:08 +01:00
void Editor::setupInputPanel()
{
2018-06-12 08:20:48 +02:00
using Q = QskInputPanelBox;
setBoxShape( Q::Panel, 0 );
setBoxBorderMetrics( Q::Panel, 0 );
setGradient( Q::Panel, m_pal.secondaryContainer );
2022-02-17 21:54:56 +01:00
setBoxBorderColors( Q::Panel, m_pal.background );
}
2020-12-26 12:57:08 +01:00
void Editor::setupVirtualKeyboard()
2017-07-21 18:21:34 +02:00
{
2020-12-21 16:06:58 +01:00
using A = QskAspect;
2018-04-06 17:30:24 +02:00
using Q = QskVirtualKeyboard;
2017-07-21 18:21:34 +02:00
// key panel
setMargin( Q::ButtonPanel, 2 );
2017-07-21 18:21:34 +02:00
2018-04-06 17:30:24 +02:00
setBoxShape( Q::ButtonPanel, 20.0, Qt::RelativeSize );
setBoxBorderMetrics( Q::ButtonPanel, 2 );
2022-02-17 21:54:56 +01:00
setBoxBorderColors( Q::ButtonPanel, m_pal.background );
2017-07-21 18:21:34 +02:00
2020-12-21 16:06:58 +01:00
for ( auto state : { A::NoState, Q::Focused } )
2022-02-17 21:54:56 +01:00
setBoxBorderColors( Q::ButtonPanel | QskPushButton::Pressed | state,
m_pal.secondary );
2017-07-21 18:21:34 +02:00
2020-12-21 16:06:58 +01:00
setAnimation( Q::ButtonPanel | A::Color, qskDuration );
setAnimation( Q::ButtonPanel | A::Metric, qskDuration );
2017-07-21 18:21:34 +02:00
// panel
2017-10-18 20:00:06 +02:00
setBoxShape( Q::Panel, 0 );
setBoxBorderMetrics( Q::Panel, 0 );
setGradient( Q::Panel, m_pal.secondaryContainer );
2022-02-17 21:54:56 +01:00
setBoxBorderColors( Q::Panel, m_pal.background );
2017-07-21 18:21:34 +02:00
}
2020-12-26 12:57:08 +01:00
void Editor::setupScrollView()
2017-07-21 18:21:34 +02:00
{
2020-12-21 16:06:58 +01:00
using A = QskAspect;
2017-07-21 18:21:34 +02:00
using Q = QskScrollView;
2022-07-12 14:21:50 +02:00
setGradient( Q::Panel, m_pal.background );
2022-07-06 13:42:04 +02:00
setGradient( Q::Viewport, m_pal.secondaryContainer );
2017-07-21 18:21:34 +02:00
for ( auto subControl : { Q::HorizontalScrollBar, Q::VerticalScrollBar } )
{
2022-02-17 21:54:56 +01:00
setMetric( subControl | A::Size, 10 );
setPadding( subControl, 0 );
}
const auto handleExtent = qskDpiScaled( 40.0 );
setStrutSize( Q::HorizontalScrollHandle, handleExtent, 0.0 );
setStrutSize( Q::VerticalScrollHandle, 0.0, handleExtent );
2017-07-21 18:21:34 +02:00
for ( auto subControl : { Q::HorizontalScrollHandle, Q::VerticalScrollHandle } )
{
2017-10-18 20:00:06 +02:00
setBoxShape( subControl, 3 );
2022-02-17 21:54:56 +01:00
setBoxBorderMetrics( subControl, 0 );
setGradient( subControl, m_pal.primary );
2020-12-21 16:06:58 +01:00
setAnimation( subControl | A::Color, qskDuration );
}
2017-07-21 18:21:34 +02:00
2018-01-16 12:13:38 +01:00
// when changing the position by QskScrollView::scrollTo
2020-12-21 16:06:58 +01:00
setAnimation( Q::Viewport | A::Metric, QskAnimationHint( 200, QEasingCurve::InCubic ) );
2017-07-21 18:21:34 +02:00
}
2020-12-26 12:57:08 +01:00
void Editor::setupListView()
2017-07-21 18:21:34 +02:00
{
using Q = QskListView;
2022-07-05 14:19:55 +02:00
setPadding( Q::Cell, { 16, 12, 16, 12 } );
2022-07-06 13:42:04 +02:00
setBoxBorderMetrics( Q::Cell, { 0, 0, 0, 1 } );
setBoxBorderColors( Q::Cell, m_pal.outline );
setColor( Q::Cell, m_pal.surface );
setColor( Q::Cell | Q::Selected, m_pal.primary12 );
2017-07-21 18:21:34 +02:00
2022-07-06 13:42:04 +02:00
setColor( Q::Text, m_pal.onSurfaceVariant );
2017-07-21 18:21:34 +02:00
}
2020-12-26 12:57:08 +01:00
void Editor::setupSubWindow()
2017-07-21 18:21:34 +02:00
{
2020-12-21 16:06:58 +01:00
using A = QskAspect;
2017-07-21 18:21:34 +02:00
using Q = QskSubWindow;
2018-10-29 20:11:48 +01:00
// Panel
2017-07-21 18:21:34 +02:00
2022-07-05 16:15:00 +02:00
setPadding( Q::Panel, { 24, 0, 24, 24 } );
setStrutSize( Q::Panel, { 280, -1 } );
setBoxShape( Q::Panel, 28 );
setBoxBorderMetrics( Q::Panel, 0 );
setGradient( Q::Panel, m_pal.secondaryContainer );
setShadowMetrics( Q::Panel, m_pal.elevationLight3 );
setShadowColor( Q::Panel, m_pal.shadow );
2017-07-21 18:21:34 +02:00
2021-04-28 09:32:49 +02:00
// TitleBarPanel
2022-07-12 14:54:45 +02:00
setBoxShape( Q::TitleBarPanel, { 28, 28, 0, 0 } );
2022-07-05 16:15:00 +02:00
setPadding( Q::TitleBarPanel, { 24, 24, 24, 16 } );
2021-04-28 09:32:49 +02:00
setFlagHint( Q::TitleBarPanel | QskAspect::Style,
Q::TitleBar | Q::Title | Q::Symbol );
2022-07-05 16:15:00 +02:00
setGradient( Q::TitleBarPanel, m_pal.secondaryContainer );
2017-07-21 18:21:34 +02:00
2018-10-29 20:11:48 +01:00
// TitleBarText
2022-07-05 16:15:00 +02:00
setFontRole( Q::TitleBarText, QskMaterial3Skin::M3HeadlineSmall );
setColor( Q::TitleBarText, m_pal.onSurface );
setAlignment( Q::TitleBarText, Qt::AlignCenter );
2018-10-29 20:11:48 +01:00
2022-08-25 09:39:33 +02:00
setTextOptions( Q::TitleBarText, Qt::ElideRight, QskTextOptions::NoWrap );
2021-04-28 09:32:49 +02:00
for ( auto subControl : { Q::Panel, Q::TitleBarPanel, Q::TitleBarText } )
2020-12-21 16:06:58 +01:00
setAnimation( subControl | A::Color, qskDuration );
2018-10-29 20:11:48 +01:00
2017-07-21 18:21:34 +02:00
}
2022-07-05 08:36:25 +02:00
QskMaterial3Theme::QskMaterial3Theme( Lightness lightness )
: QskMaterial3Theme( lightness,
2022-06-27 14:32:37 +02:00
{ // default Material colors:
0xff6750A4,
0xff625B71,
0xff7D5260,
0xffB3261E,
0xff605D62,
0xff605D66,
} )
{
}
2022-07-05 08:36:25 +02:00
QskMaterial3Theme::QskMaterial3Theme(Lightness lightness,
2022-06-27 14:32:37 +02:00
std::array<QskHctColor, NumPaletteTypes> palettes )
: m_palettes( palettes )
{
if ( lightness == Light )
{
2022-06-27 14:32:37 +02:00
primary = m_palettes[ Primary ].toned( 40 ).rgb();
onPrimary = m_palettes[ Primary ].toned( 100 ).rgb();
primaryContainer = m_palettes[ Primary ].toned( 90 ).rgb();
onPrimaryContainer = m_palettes[ Primary ].toned( 10 ).rgb();
secondary = m_palettes[ Secondary ].toned( 40 ).rgb();
onSecondary = m_palettes[ Secondary ].toned( 100 ).rgb();
secondaryContainer = m_palettes[ Secondary ].toned( 90 ).rgb();
onSecondaryContainer = m_palettes[ Secondary ].toned( 10 ).rgb();
tertiary = m_palettes[ Tertiary ].toned( 40 ).rgb();
onTertiary = m_palettes[ Tertiary ].toned( 100 ).rgb();
tertiaryContainer = m_palettes[ Tertiary ].toned( 90 ).rgb();
onTertiaryContainer = m_palettes[ Tertiary ].toned( 10 ).rgb();
error = m_palettes[ Error ].toned( 40 ).rgb();
onError = m_palettes[ Error ].toned( 100 ).rgb();
errorContainer = m_palettes[ Error ].toned( 90 ).rgb();
onErrorContainer = m_palettes[ Error ].toned( 10 ).rgb();
background = m_palettes[ Neutral ].toned( 99 ).rgb();
onBackground = m_palettes[ Neutral ].toned( 10 ).rgb();
surface = m_palettes[ Neutral ].toned( 99 ).rgb();
onSurface = m_palettes[ Neutral ].toned( 10 ).rgb();
surfaceVariant = m_palettes[ NeutralVariant ].toned( 90 ).rgb();
onSurfaceVariant = m_palettes[ NeutralVariant ].toned( 30 ).rgb();
outline = m_palettes[ NeutralVariant ].toned( 50 ).rgb();
shadow = m_palettes[ Neutral ].toned( 0 ).rgb();
}
else if ( lightness == Dark )
{
2022-06-27 14:32:37 +02:00
primary = m_palettes[ Primary ].toned( 80 ).rgb();
onPrimary = m_palettes[ Primary ].toned( 20 ).rgb();
primaryContainer = m_palettes[ Primary ].toned( 30 ).rgb();
onPrimaryContainer = m_palettes[ Primary ].toned( 90 ).rgb();
secondary = m_palettes[ Secondary ].toned( 80 ).rgb();
onSecondary = m_palettes[ Secondary ].toned( 20 ).rgb();
secondaryContainer = m_palettes[ Secondary ].toned( 30 ).rgb();
onSecondaryContainer = m_palettes[ Secondary ].toned( 90 ).rgb();
tertiary = m_palettes[ Tertiary ].toned( 80 ).rgb();
onTertiary = m_palettes[ Tertiary ].toned( 20 ).rgb();
tertiaryContainer = m_palettes[ Tertiary ].toned( 30 ).rgb();
onTertiaryContainer = m_palettes[ Tertiary ].toned( 90 ).rgb();
error = m_palettes[ Error ].toned( 80 ).rgb();
onError = m_palettes[ Error ].toned( 20 ).rgb();
errorContainer = m_palettes[ Error ].toned( 30 ).rgb();
onErrorContainer = m_palettes[ Error ].toned( 90 ).rgb();
background = m_palettes[ Neutral ].toned( 10 ).rgb();
onBackground = m_palettes[ Neutral ].toned( 90 ).rgb();
surface = m_palettes[ Neutral ].toned( 10 ).rgb();
onSurface = m_palettes[ Neutral ].toned( 80 ).rgb();
surfaceVariant = m_palettes[ NeutralVariant ].toned( 30 ).rgb();
onSurfaceVariant = m_palettes[ NeutralVariant ].toned( 80 ).rgb();
outline = m_palettes[ NeutralVariant ].toned( 60 ).rgb();
shadow = m_palettes[ Neutral ].toned( 0 ).rgb();
}
2022-07-15 08:39:52 +02:00
primary12 = QskRgb::toTransparentF( primary, 0.12 );
2022-06-17 17:37:44 +02:00
surface1 = flattenedColor( primary, background, 0.05 );
surface2 = flattenedColor( primary, background, 0.08 );
surface3 = flattenedColor( primary, background, 0.11 );
surface4 = flattenedColor( primary, background, 0.12 );
surface5 = flattenedColor( primary, background, 0.14 );
2022-07-15 08:39:52 +02:00
onSurface12 = QskRgb::toTransparentF( onSurface, 0.12 );
onSurface38 = QskRgb::toTransparentF( onSurface, 0.38 );
2022-06-17 17:37:44 +02:00
2022-07-15 08:39:52 +02:00
surfaceVariant12 = QskRgb::toTransparentF( surfaceVariant, 0.12 );
2022-06-17 17:37:44 +02:00
2022-06-17 15:28:42 +02:00
elevationLight1 = QskShadowMetrics( -3, 5, { 0, 2 } );
elevationLight2 = QskShadowMetrics( -2, 8, { 0, 2 } );
2022-07-05 16:15:00 +02:00
elevationLight3 = QskShadowMetrics( -1, 11, { 0, 2 } );
}
2022-07-05 08:36:25 +02:00
QskMaterial3Skin::QskMaterial3Skin( const QskMaterial3Theme& palette, QObject* parent )
2020-12-26 12:57:08 +01:00
: Inherited( parent )
{
2022-06-07 12:40:21 +02:00
setupFonts();
2020-12-26 12:57:08 +01:00
Editor editor( &hintTable(), palette );
editor.setup();
}
2022-07-05 08:36:25 +02:00
QskMaterial3Skin::~QskMaterial3Skin()
{
}
2022-07-05 08:36:25 +02:00
void QskMaterial3Skin::setupFonts()
2022-06-07 12:40:21 +02:00
{
Inherited::setupFonts( QStringLiteral( "Roboto" ) );
setFont( M3BodyMedium, createFont( 14, 0.25, QFont::Normal ) );
setFont( M3BodyLarge, createFont( 16, 0.5, QFont::Normal ) );
setFont( M3HeadlineSmall, createFont( 28, 0.0, QFont::Normal ) );
setFont( M3LabelLarge, createFont( 14, 0.1, QFont::Medium ) );
2022-06-07 12:40:21 +02:00
}
2022-07-05 08:36:25 +02:00
#include "moc_QskMaterial3Skin.cpp"