2017-07-21 18:21:34 +02:00
|
|
|
/******************************************************************************
|
|
|
|
* QSkinny - Copyright (C) 2016 Uwe Rathmann
|
|
|
|
* This file may be used under the terms of the QSkinny License, Version 1.0
|
|
|
|
*****************************************************************************/
|
|
|
|
|
|
|
|
#include "QskMaterialSkin.h"
|
|
|
|
|
2020-12-26 12:57:08 +01:00
|
|
|
#include <QskSkinHintTableEditor.h>
|
|
|
|
|
2019-12-15 13:57:19 +01:00
|
|
|
#include <QskBox.h>
|
2022-04-04 08:53:20 +02:00
|
|
|
#include <QskCheckBox.h>
|
2018-04-03 10:47:21 +02:00
|
|
|
#include <QskDialogButton.h>
|
2018-08-03 08:15:28 +02:00
|
|
|
#include <QskDialogButtonBox.h>
|
2018-04-03 10:47:21 +02:00
|
|
|
#include <QskFocusIndicator.h>
|
2018-06-12 08:20:48 +02:00
|
|
|
#include <QskInputPanelBox.h>
|
2018-04-03 10:47:21 +02:00
|
|
|
#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>
|
2018-04-03 10:47:21 +02:00
|
|
|
#include <QskScrollView.h>
|
2022-04-20 14:14:37 +02:00
|
|
|
#include <QskSegmentedBar.h>
|
2018-04-03 10:47:21 +02:00
|
|
|
#include <QskSeparator.h>
|
2017-07-21 18:21:34 +02:00
|
|
|
#include <QskSlider.h>
|
2018-04-03 10:47:21 +02:00
|
|
|
#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>
|
2018-04-03 10:47:21 +02:00
|
|
|
#include <QskTextInput.h>
|
2018-08-03 08:15:28 +02:00
|
|
|
#include <QskTextLabel.h>
|
2018-03-28 09:01:25 -07:00
|
|
|
#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>
|
2017-08-23 14:53:29 +02:00
|
|
|
#include <QskMargins.h>
|
2017-07-21 18:21:34 +02:00
|
|
|
|
2021-12-26 12:57:02 +01:00
|
|
|
#include <QskNamespace.h>
|
|
|
|
#include <QskPlatform.h>
|
|
|
|
|
2017-07-21 18:21:34 +02:00
|
|
|
static const int qskDuration = 150;
|
|
|
|
|
|
|
|
namespace
|
|
|
|
{
|
2020-12-26 12:57:08 +01:00
|
|
|
class Editor : private QskSkinHintTableEditor
|
|
|
|
{
|
|
|
|
public:
|
2022-06-03 10:15:20 +02:00
|
|
|
Editor( QskSkinHintTable* table, const QskMaterialTheme& 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();
|
2022-04-04 08:53:20 +02:00
|
|
|
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();
|
2022-04-20 14:14:37 +02:00
|
|
|
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-06-03 10:15:20 +02:00
|
|
|
const QskMaterialTheme& m_pal;
|
2022-06-03 10:40:13 +02:00
|
|
|
const uint rippleSize = 40; // ### remove
|
2020-12-26 12:57:08 +01:00
|
|
|
};
|
2022-06-07 12:40:21 +02:00
|
|
|
|
|
|
|
QFont createFont( int pixelSize, QFont::Weight weight = QFont::Normal )
|
|
|
|
{
|
|
|
|
QFont font( "Roboto" );
|
|
|
|
font.setPixelSize( pixelSize );
|
|
|
|
font.setLetterSpacing( QFont::AbsoluteSpacing, 0.1 );
|
|
|
|
font.setWeight( weight );
|
|
|
|
|
|
|
|
return font;
|
|
|
|
}
|
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();
|
2022-04-04 08:53:20 +02:00
|
|
|
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();
|
2022-04-20 14:14:37 +02:00
|
|
|
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
|
|
|
}
|
|
|
|
|
2022-04-04 08:53:20 +02:00
|
|
|
void Editor::setupCheckBox()
|
|
|
|
{
|
2022-04-05 08:48:16 +02:00
|
|
|
using A = QskAspect;
|
2022-04-04 08:53:20 +02:00
|
|
|
using Q = QskCheckBox;
|
|
|
|
|
2022-06-03 10:40:13 +02:00
|
|
|
setStrutSize( Q::Panel, 24, 24 );
|
2022-04-04 08:53:20 +02:00
|
|
|
|
2022-06-03 10:40:13 +02:00
|
|
|
setPadding( Q::Panel, 6 );
|
2022-04-05 08:48:16 +02:00
|
|
|
setBoxShape( Q::Panel, 2 );
|
2022-06-03 10:40:13 +02:00
|
|
|
setBoxBorderMetrics( Q::Panel, 2 );
|
|
|
|
setBoxBorderColors( Q::Panel, m_pal.onBackground );
|
|
|
|
setBoxBorderMetrics( Q::Panel | Q::Checked, 0 );
|
|
|
|
|
|
|
|
setGradient( Q::Panel, m_pal.background );
|
|
|
|
setGradient( Q::Panel | Q::Checked, m_pal.primary );
|
|
|
|
|
|
|
|
QColor c3( m_pal.surfaceVariant );
|
|
|
|
c3.setAlphaF( 0.12 );
|
|
|
|
setGradient( Q::Panel | Q::Disabled, c3 );
|
2022-04-04 08:53:20 +02:00
|
|
|
|
2022-06-03 10:40:13 +02:00
|
|
|
QColor c1( m_pal.onSurface );
|
|
|
|
c1.setAlphaF( 0.12 );
|
|
|
|
setGradient( Q::Panel | Q::Checked | Q::Disabled, c1 );
|
2022-04-04 08:53:20 +02:00
|
|
|
|
2022-06-03 10:40:13 +02:00
|
|
|
|
|
|
|
setColor( Q::Indicator | Q::Checked, m_pal.primaryContainer );
|
|
|
|
QColor c4( m_pal.onSurface );
|
|
|
|
c4.setAlphaF( 0.38 );
|
|
|
|
setColor( Q::Indicator | Q::Checked | Q::Disabled, c4 );
|
2022-04-04 08:53:20 +02:00
|
|
|
|
2022-04-05 08:48:16 +02:00
|
|
|
setAnimation( Q::Panel | A::Color, qskDuration );
|
2022-04-04 08:53:20 +02:00
|
|
|
}
|
|
|
|
|
2020-12-26 12:57:08 +01:00
|
|
|
void Editor::setupBox()
|
2019-12-15 13:57:19 +01:00
|
|
|
{
|
|
|
|
using Q = QskBox;
|
|
|
|
|
2022-02-17 21:54:56 +01:00
|
|
|
setGradient( Q::Panel, m_pal.background );
|
|
|
|
setBoxShape( Q::Panel, 14 );
|
2019-12-15 13:57:19 +01:00
|
|
|
setBoxBorderMetrics( Q::Panel, 0 );
|
|
|
|
}
|
|
|
|
|
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-06-03 10:40:13 +02:00
|
|
|
setGradient( Q::Overlay, m_pal.surface );
|
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;
|
|
|
|
|
|
|
|
setBoxShape( Q::Panel, qskDpiScaled( 4 ) );
|
|
|
|
setBoxBorderMetrics( Q::Panel, qskDpiScaled( 1 ) );
|
2022-04-05 11:55:26 +02:00
|
|
|
setBoxBorderColors( Q::Panel, m_pal.primary );
|
2022-04-05 11:38:23 +02:00
|
|
|
|
2022-04-05 11:55:26 +02:00
|
|
|
setGradient( Q::Panel, m_pal.background );
|
2022-04-05 11:38:23 +02:00
|
|
|
|
2022-04-16 12:25:39 +02:00
|
|
|
setFlagHint( Q::Panel | A::Style, false ); // not cascading
|
2022-04-05 11:38:23 +02:00
|
|
|
|
|
|
|
#if 0
|
|
|
|
setPadding( Q::Separator, QMarginsF( 10, 0, 10, 0 ) );
|
|
|
|
#endif
|
|
|
|
setMetric( Q::Separator | A::Size, qskDpiScaled( 1 ) );
|
|
|
|
setBoxShape( Q::Separator, 0 );
|
|
|
|
setBoxBorderMetrics( Q::Separator, 0 );
|
2022-04-05 11:55:26 +02:00
|
|
|
setGradient( Q::Separator, m_pal.primary );
|
2022-04-05 11:38:23 +02:00
|
|
|
|
2022-04-20 13:58:53 +02:00
|
|
|
setPadding( Q::Segment, QskMargins( 2, 10, 2, 10 ) );
|
|
|
|
setSpacing( Q::Segment, 5 );
|
|
|
|
setGradient( Q::Segment, Qt::transparent );
|
2022-04-05 11:38:23 +02:00
|
|
|
|
2022-06-03 10:40:13 +02:00
|
|
|
setGradient( Q::Cursor, m_pal.primary );
|
2022-04-05 11:38:23 +02:00
|
|
|
|
2022-04-05 11:55:26 +02:00
|
|
|
setColor( Q::Text, m_pal.onBackground );
|
2022-04-05 11:38:23 +02:00
|
|
|
setFontRole( Q::Text, QskSkin::SmallFont );
|
|
|
|
|
|
|
|
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;
|
|
|
|
|
2020-12-15 07:21:12 +01:00
|
|
|
setAlignment( Q::Text, Qt::AlignCenter );
|
2022-06-03 10:40:13 +02:00
|
|
|
setColor( Q::Text, m_pal.onSurface );
|
2019-12-15 13:57:19 +01:00
|
|
|
|
2020-12-15 07:21:12 +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()
|
2018-04-03 10:47:21 +02:00
|
|
|
{
|
|
|
|
using Q = QskTextInput;
|
|
|
|
|
2020-12-15 07:21:12 +01:00
|
|
|
setAlignment( Q::Text, Qt::AlignLeft | Qt::AlignTop );
|
2018-04-03 10:47:21 +02:00
|
|
|
|
2022-02-17 21:54:56 +01:00
|
|
|
setColor( Q::Text, m_pal.onBackground );
|
2018-04-03 10:47:21 +02:00
|
|
|
|
2020-12-15 07:21:12 +01:00
|
|
|
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 );
|
2022-06-03 10:40:13 +02:00
|
|
|
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-06-03 10:40:13 +02:00
|
|
|
|
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 );
|
|
|
|
|
2022-06-03 10:40:13 +02:00
|
|
|
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
|
|
|
|
2022-06-03 10:40:13 +02:00
|
|
|
setGradient( Q::Panel, m_pal.surfaceVariant );
|
2022-04-02 11:50:55 +02:00
|
|
|
|
2022-06-03 10:40:13 +02:00
|
|
|
QColor c1( m_pal.onSurface );
|
|
|
|
c1.setAlphaF( 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-03 10:40:13 +02:00
|
|
|
QColor c2( m_pal.onSurface );
|
|
|
|
c2.setAlphaF( 0.38 ); // ### move this to the palette, we are using it all the time
|
|
|
|
setColor( Q::Text | Q::Disabled, c2 );
|
|
|
|
setBoxBorderColors( Q::Panel | Q::Disabled, c2 );
|
2018-04-03 10:47:21 +02:00
|
|
|
}
|
|
|
|
|
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 );
|
2020-12-15 07:21:12 +01:00
|
|
|
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 );
|
2022-06-03 10:40:13 +02:00
|
|
|
setGradient( Q::Groove, m_pal.primaryContainer );
|
|
|
|
|
|
|
|
QColor c1( m_pal.onSurface );
|
|
|
|
c1.setAlphaF( 0.12 );
|
|
|
|
setGradient( Q::Groove | Q::Disabled, c1 );
|
2022-02-17 21:54:56 +01:00
|
|
|
|
2022-06-03 10:40:13 +02:00
|
|
|
setGradient( Q::Bar, m_pal.primary );
|
2022-04-02 11:50:55 +02:00
|
|
|
|
2022-06-03 10:40:13 +02:00
|
|
|
QColor c2( m_pal.onSurface );
|
|
|
|
c2.setAlphaF( 0.38 );
|
|
|
|
setGradient( Q::Bar | Q::Disabled, c2 );
|
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;
|
2017-10-17 17:34:00 +02:00
|
|
|
setGradient( Q::Panel, QskGradient() );
|
2017-07-21 18:21:34 +02:00
|
|
|
}
|
|
|
|
|
2022-04-20 14:14:37 +02:00
|
|
|
void Editor::setupSegmentedBar()
|
|
|
|
{
|
2022-04-20 15:25:15 +02:00
|
|
|
// copied from Squiek: we need something similar to a tab bar here. TODO ...
|
|
|
|
using A = QskAspect;
|
|
|
|
using Q = QskSegmentedBar;
|
|
|
|
|
|
|
|
{
|
|
|
|
// Panel
|
|
|
|
|
|
|
|
setPadding( Q::Panel, 0 );
|
|
|
|
setSpacing( Q::Panel, 5 );
|
|
|
|
|
2022-06-03 10:40:13 +02:00
|
|
|
setBoxBorderMetrics( Q::Panel, 1 );
|
|
|
|
setBoxBorderColors( Q::Panel, m_pal.outline );
|
2022-04-20 15:25:15 +02:00
|
|
|
|
2022-06-03 10:40:13 +02:00
|
|
|
const QSize strutSize( qskDpiScaled( -1 ), qskDpiScaled( 40 ) );
|
2022-04-20 15:25:15 +02:00
|
|
|
|
|
|
|
setStrutSize( Q::Panel | A::Horizontal, strutSize );
|
|
|
|
setStrutSize( Q::Panel | A::Vertical, strutSize.transposed() );
|
|
|
|
}
|
|
|
|
|
|
|
|
{
|
|
|
|
// Segment
|
|
|
|
|
|
|
|
setPadding( Q::Segment, QskMargins( 2, 5, 2, 5 ) );
|
|
|
|
}
|
|
|
|
|
|
|
|
{
|
|
|
|
// Cursor
|
2022-06-03 10:40:13 +02:00
|
|
|
setGradient( Q::Cursor, m_pal.secondaryContainer );
|
|
|
|
QColor c1( m_pal.onSurface );
|
|
|
|
c1.setAlphaF( 0.12 );
|
|
|
|
setGradient( Q::Cursor | Q::Disabled, c1 );
|
2022-04-20 15:25:15 +02:00
|
|
|
|
|
|
|
setAnimation( Q::Cursor | A::Metric | A::Position, 100 );
|
|
|
|
}
|
|
|
|
|
|
|
|
for( auto subControl : { Q::Panel, Q::Cursor } )
|
2022-06-03 10:40:13 +02:00
|
|
|
{
|
|
|
|
setBoxShape( subControl, 100, Qt::RelativeSize );
|
|
|
|
}
|
2022-04-20 15:25:15 +02:00
|
|
|
|
|
|
|
{
|
|
|
|
// Text
|
|
|
|
|
2022-06-03 10:40:13 +02:00
|
|
|
setColor( Q::Text, m_pal.onSurface );
|
|
|
|
setColor( Q::Text | Q::Selected, m_pal.onSecondaryContainer );
|
2022-04-20 15:25:15 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
{
|
|
|
|
// Graphic
|
|
|
|
|
|
|
|
#if 0
|
|
|
|
setGraphicRole( Q::Graphic, ... );
|
|
|
|
setStrutSize( Q::Graphic, ... );
|
|
|
|
#endif
|
|
|
|
}
|
2022-04-20 14:14:37 +02:00
|
|
|
}
|
|
|
|
|
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 } )
|
2017-10-17 17:34:00 +02:00
|
|
|
{
|
2020-12-13 14:23:17 +01:00
|
|
|
const auto aspect = Q::Panel | placement;
|
2017-10-17 17:34:00 +02:00
|
|
|
|
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-10-17 17:34:00 +02:00
|
|
|
}
|
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 );
|
2017-10-17 17:34:00 +02:00
|
|
|
|
2022-01-04 13:58:34 +01:00
|
|
|
// circles, without border
|
|
|
|
setBoxShape( Q::Bullet, 100, Qt::RelativeSize );
|
|
|
|
setBoxBorderMetrics( Q::Bullet, 0 );
|
2017-10-17 17:34:00 +02:00
|
|
|
|
2022-06-03 10:40:13 +02:00
|
|
|
setGradient( Q::Bullet, m_pal.primaryContainer );
|
|
|
|
setGradient( Q::Bullet | Q::Selected, m_pal.primary );
|
2017-07-21 18:21:34 +02:00
|
|
|
|
2022-06-03 10:40:13 +02:00
|
|
|
QColor c1( m_pal.onSurface );
|
|
|
|
c1.setAlphaF( 0.12 );
|
|
|
|
setGradient( Q::Bullet | Q::Disabled, c1 );
|
2022-04-02 11:50:55 +02:00
|
|
|
|
2022-06-03 10:40:13 +02:00
|
|
|
QColor c2( m_pal.onSurface );
|
|
|
|
c2.setAlphaF( 0.38 );
|
|
|
|
setGradient( Q::Bullet | Q::Selected | Q::Disabled, c2 );
|
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;
|
|
|
|
|
2022-06-07 12:10:40 +02:00
|
|
|
setStrutSize( Q::Panel, -1, 31 );
|
2022-02-17 21:54:56 +01:00
|
|
|
setSpacing( Q::Panel, qskDpiScaled( 4 ) );
|
2022-06-03 10:40:13 +02:00
|
|
|
setPadding( Q::Panel, { 24, 0, 20, 0 } );
|
2017-07-21 18:21:34 +02:00
|
|
|
|
2022-06-03 10:40:13 +02:00
|
|
|
setBoxShape( Q::Panel, 100, Qt::RelativeSize );
|
2017-08-23 14:53:29 +02:00
|
|
|
|
2022-06-08 10:54:01 +02:00
|
|
|
setAlignment( Q::Graphic | A::Alignment, Qt::AlignLeft );
|
|
|
|
setPadding( Q::Graphic, 5 );
|
2017-07-21 18:21:34 +02:00
|
|
|
|
2022-06-07 12:40:21 +02:00
|
|
|
setFontRole( Q::Text, QskMaterialSkin::M3LabelLarge );
|
2020-12-15 07:21:12 +01:00
|
|
|
setAlignment( Q::Text, Qt::AlignCenter );
|
2017-07-21 18:21:34 +02:00
|
|
|
|
2022-06-08 10:54:01 +02:00
|
|
|
|
|
|
|
// normal buttons (i.e. Filled):
|
|
|
|
|
2022-06-03 10:40:13 +02:00
|
|
|
setGradient( Q::Panel, m_pal.primary );
|
2017-07-21 18:21:34 +02:00
|
|
|
|
2022-06-03 10:40:13 +02:00
|
|
|
QColor c1( m_pal.onSurface );
|
|
|
|
c1.setAlphaF( 0.12 );
|
|
|
|
setGradient( Q::Panel | Q::Disabled, c1 );
|
2017-07-21 18:21:34 +02:00
|
|
|
|
2022-06-08 10:54:01 +02:00
|
|
|
setColor( Q::Text, m_pal.onPrimary );
|
|
|
|
|
|
|
|
QColor c2( m_pal.onSurface );
|
|
|
|
c2.setAlphaF( 0.38 );
|
|
|
|
setColor( Q::Text | Q::Disabled, c2 );
|
|
|
|
|
|
|
|
|
|
|
|
// Outlined and Text:
|
|
|
|
|
|
|
|
const QskStateCombination combination( QskStateCombination::Combination, Q::Outlined | Q::TextState );
|
|
|
|
setGradient( Q::Panel, Qt::transparent, combination );
|
|
|
|
|
|
|
|
setBoxBorderMetrics( Q::Panel, 1, { QskStateCombination::CombinationNoState, Q::Outlined } );
|
|
|
|
setBoxBorderColors( Q::Panel | Q::Outlined, m_pal.outline );
|
|
|
|
|
|
|
|
setGradient( Q::Panel | Q::Disabled, Qt::transparent, combination );
|
|
|
|
setBoxBorderColors( Q::Panel | Q::Outlined | Q::Disabled, c1 );
|
|
|
|
|
|
|
|
QColor primary08( m_pal.primary );
|
|
|
|
primary08.setAlphaF( 0.08 );
|
|
|
|
setGradient( Q::Panel | Q::Outlined, primary08,
|
|
|
|
{ QskStateCombination::Combination,
|
|
|
|
Q::Hovered | Q::Focused | Q::Pressed } );
|
|
|
|
setGradient( Q::Panel | Q::TextState, primary08,
|
|
|
|
{ QskStateCombination::Combination,
|
|
|
|
Q::Hovered | Q::Focused | Q::Pressed } );
|
|
|
|
|
|
|
|
setColor( Q::Text, m_pal.primary, combination );
|
|
|
|
|
|
|
|
setColor( Q::Text | Q::Disabled, c1, combination );
|
2017-07-21 18:21:34 +02:00
|
|
|
|
2021-05-14 15:46:15 +02:00
|
|
|
|
2020-12-21 16:06:58 +01:00
|
|
|
setAnimation( Q::Panel | A::Color, qskDuration );
|
|
|
|
setAnimation( Q::Panel | A::Metric, qskDuration );
|
|
|
|
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
|
|
|
{
|
2020-12-21 16:06:58 +01:00
|
|
|
using A = QskAspect;
|
2017-07-21 18:21:34 +02:00
|
|
|
using Q = QskDialogButton;
|
|
|
|
|
2020-12-16 12:49:24 +01:00
|
|
|
setStrutSize( Q::Panel, 30, 16 );
|
|
|
|
setSpacing( Q::Panel, 4 );
|
2017-07-21 18:21:34 +02:00
|
|
|
|
2020-12-15 18:12:48 +01:00
|
|
|
setMargin( Q::Panel, QskMargins( 4, 3 ) );
|
|
|
|
setPadding( Q::Panel, QskMargins( 10, 6 ) );
|
2017-07-21 18:21:34 +02:00
|
|
|
|
2017-10-18 20:00:06 +02:00
|
|
|
setBoxShape( Q::Panel, 0 );
|
2017-07-21 18:21:34 +02:00
|
|
|
|
2022-02-17 21:54:56 +01:00
|
|
|
setGradient( Q::Panel, m_pal.primary );
|
2022-06-03 10:40:13 +02:00
|
|
|
setColor( Q::Text, m_pal.onPrimary );
|
|
|
|
|
|
|
|
QColor c2( m_pal.onSurface );
|
|
|
|
c2.setAlphaF( 0.38 );
|
|
|
|
setColor( Q::Text | Q::Disabled, c2 );
|
|
|
|
|
2022-06-07 12:40:21 +02:00
|
|
|
setFontRole( Q::Text, QskMaterialSkin::M3LabelLarge );
|
2020-12-15 07:21:12 +01:00
|
|
|
setAlignment( Q::Text, Qt::AlignCenter );
|
2017-07-21 18:21:34 +02:00
|
|
|
|
2021-08-04 08:24:36 +02:00
|
|
|
for ( auto state1 : { A::NoState, Q::Focused } )
|
2017-10-17 17:34:00 +02:00
|
|
|
{
|
2020-12-21 16:06:58 +01:00
|
|
|
for ( auto state2 : { A::NoState, Q::Hovered } )
|
2017-10-17 17:34:00 +02:00
|
|
|
{
|
2022-02-17 21:54:56 +01:00
|
|
|
for ( auto state3 : { Q::Pressed | A::NoState,
|
|
|
|
Q::Checked | A::NoState, Q::Checked | Q::Pressed } )
|
2017-10-17 17:34:00 +02:00
|
|
|
{
|
|
|
|
const auto states = state1 | state2 | state3;
|
2017-07-21 18:21:34 +02:00
|
|
|
|
2022-02-17 21:54:56 +01:00
|
|
|
setGradient( Q::Panel | states, m_pal.secondary );
|
|
|
|
setColor( Q::Text | states, m_pal.onSecondary );
|
2017-10-17 17:34:00 +02:00
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
2017-07-21 18:21:34 +02:00
|
|
|
|
2020-12-21 16:06:58 +01:00
|
|
|
setAnimation( Q::Panel | A::Color, qskDuration );
|
|
|
|
setAnimation( Q::Panel | A::Metric, qskDuration );
|
|
|
|
setAnimation( Q::Text | A::Color, qskDuration );
|
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
|
|
|
{
|
2017-10-17 17:34:00 +02:00
|
|
|
using Q = QskDialogButtonBox;
|
|
|
|
|
2022-02-17 21:54:56 +01:00
|
|
|
setGradient( Q::Panel, m_pal.background );
|
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
|
|
|
|
2017-10-17 17:34:00 +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 );
|
2022-03-31 18:29:39 +02:00
|
|
|
setGradient( Q::Panel, QskGradient() );
|
2018-01-03 11:57:05 +01:00
|
|
|
|
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 ) );
|
2017-10-17 17:34:00 +02:00
|
|
|
|
|
|
|
// Groove, Fill
|
2017-07-21 18:21:34 +02:00
|
|
|
|
|
|
|
for ( auto subControl : { Q::Groove, Q::Fill } )
|
|
|
|
{
|
2020-12-15 07:21:12 +01:00
|
|
|
setPadding( subControl, 0 );
|
2017-10-17 17:34:00 +02:00
|
|
|
|
2017-10-18 20:00:06 +02:00
|
|
|
setBoxShape( subControl, 0 );
|
|
|
|
setBoxBorderMetrics( subControl, 0 );
|
2017-07-21 18:21:34 +02:00
|
|
|
}
|
2022-03-31 18:29:39 +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
|
|
|
|
2022-06-03 10:40:13 +02:00
|
|
|
setGradient( Q::Groove, m_pal.primaryContainer );
|
|
|
|
|
|
|
|
QColor c1( m_pal.onSurface );
|
|
|
|
c1.setAlphaF( 0.12 );
|
|
|
|
setGradient( Q::Groove | Q::Disabled, c1 );
|
2017-10-17 17:34:00 +02:00
|
|
|
|
2022-06-03 10:40:13 +02:00
|
|
|
setGradient( Q::Fill, m_pal.primary );
|
|
|
|
|
|
|
|
QColor c2( m_pal.onSurface );
|
|
|
|
c2.setAlphaF( 0.38 );
|
|
|
|
setGradient( Q::Fill | Q::Disabled, c2 );
|
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 );
|
2018-01-03 11:57:05 +01:00
|
|
|
|
2022-02-17 21:54:56 +01:00
|
|
|
setStrutSize( Q::Handle, qskDpiScaled( 20 + rippleSize ),
|
|
|
|
qskDpiScaled( 20 + rippleSize ) );
|
2017-07-21 18:21:34 +02:00
|
|
|
|
2022-06-03 10:40:13 +02:00
|
|
|
setGradient( Q::Handle, m_pal.primary );
|
|
|
|
setGradient( Q::Handle | Q::Pressed, m_pal.primary );
|
2017-07-21 18:21:34 +02:00
|
|
|
|
2022-06-03 10:40:13 +02:00
|
|
|
setGradient( Q::Handle | Q::Disabled, c2 );
|
2017-07-21 18:21:34 +02:00
|
|
|
|
2022-02-17 21:54:56 +01:00
|
|
|
setBoxBorderMetrics( Q::Handle, qskDpiScaled( rippleSize / 2 ) );
|
2017-07-21 18:21:34 +02:00
|
|
|
|
2017-10-17 17:34:00 +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;
|
|
|
|
|
2021-08-03 15:02:33 +02:00
|
|
|
setBoxShape( Q::Groove, 100, Qt::RelativeSize );
|
2022-06-03 10:40:13 +02:00
|
|
|
const QSizeF strutSize( 52, 32 );
|
|
|
|
setStrutSize( Q::Groove | A::Horizontal, strutSize );
|
|
|
|
setStrutSize( Q::Groove | A::Vertical, strutSize.transposed() );
|
|
|
|
setGradient( Q::Groove, m_pal.surfaceVariant );
|
2021-08-03 15:02:33 +02:00
|
|
|
|
2022-06-03 10:40:13 +02:00
|
|
|
QColor c3( m_pal.surfaceVariant );
|
|
|
|
c3.setAlphaF( 0.12 );
|
|
|
|
setGradient( Q::Groove | Q::Disabled, c3 );
|
|
|
|
setGradient( Q::Groove | Q::Checked, m_pal.primary );
|
2021-08-03 15:02:33 +02:00
|
|
|
|
2022-06-03 10:40:13 +02:00
|
|
|
QColor c1( m_pal.onSurface );
|
|
|
|
c1.setAlphaF( 0.12 );
|
|
|
|
setGradient( Q::Groove | Q::Checked | Q::Disabled, c1 );
|
|
|
|
setBoxBorderMetrics( Q::Groove, 2 );
|
|
|
|
setBoxBorderColors( Q::Groove, m_pal.outline );
|
|
|
|
|
|
|
|
setBoxBorderMetrics( Q::Groove | Q::Checked, 0 );
|
2021-08-02 19:17:04 +02:00
|
|
|
|
2021-08-03 15:02:33 +02:00
|
|
|
setBoxShape( Q::Handle, 100, Qt::RelativeSize );
|
2022-06-03 10:40:13 +02:00
|
|
|
setStrutSize( Q::Handle, 16, 16 );
|
|
|
|
setStrutSize( Q::Handle | Q::Checked, 24, 24 );
|
2022-02-17 21:54:56 +01:00
|
|
|
|
2022-06-03 10:40:13 +02: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-03 10:40:13 +02:00
|
|
|
QColor c2( m_pal.onSurface );
|
|
|
|
c2.setAlphaF( 0.38 );
|
|
|
|
setGradient( Q::Handle | Q::Disabled, c2 );
|
|
|
|
setGradient( Q::Handle | Q::Disabled | Q::Checked, m_pal.surface );
|
2022-02-17 21:54:56 +01:00
|
|
|
|
2022-06-03 10:40:13 +02: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
|
|
|
|
2022-06-03 10:40:13 +02:00
|
|
|
QColor c4( m_pal.surface );
|
|
|
|
c4.setAlphaF( m_pal.focusOpacity );
|
|
|
|
setGradient( Q::Ripple | Q::Hovered, c4 );
|
|
|
|
|
|
|
|
QColor c5( m_pal.primary );
|
|
|
|
c5.setAlphaF( m_pal.focusOpacity );
|
|
|
|
setGradient( Q::Ripple | Q::Hovered | Q::Checked, c5 );
|
|
|
|
setStrutSize( Q::Ripple | Q::Hovered, 40, 40 );
|
|
|
|
setBoxShape( Q::Ripple, 100, Qt::RelativeSize );
|
|
|
|
setStrutSize( Q::Ripple | Q::Hovered | Q::Checked, 40, 40 );
|
2022-02-17 21:54:56 +01:00
|
|
|
|
2022-06-03 10:40:13 +02: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
|
|
|
|
2022-06-03 10:40:13 +02:00
|
|
|
setPosition( aspect, 0.15 );
|
|
|
|
setPosition( aspect | Q::Checked, 0.85 );
|
2021-08-02 13:22:37 +02:00
|
|
|
}
|
|
|
|
|
2021-08-03 15:02:33 +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-06-03 10:40:13 +02:00
|
|
|
setStrutSize( Q::Panel, 64, 64 );
|
2017-10-17 17:34:00 +02:00
|
|
|
|
2022-06-03 10:40:13 +02:00
|
|
|
setColor( Q::Text, m_pal.onSurfaceVariant );
|
2019-04-17 16:33:17 +02:00
|
|
|
|
2022-06-03 10:40:13 +02:00
|
|
|
QColor c2( m_pal.onSurface );
|
|
|
|
c2.setAlphaF( 0.38 );
|
|
|
|
setColor( Q::Text | Q::Disabled, c2 );
|
2017-10-17 17:34:00 +02:00
|
|
|
|
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-06-03 10:40:13 +02:00
|
|
|
setGradient( Q::Panel, m_pal.surface );
|
|
|
|
|
|
|
|
QColor c( m_pal.surface );
|
|
|
|
c.setAlphaF( m_pal.hoverOpacity );
|
|
|
|
setGradient( Q::Panel | Q::Hovered, c );
|
|
|
|
c.setAlphaF( m_pal.focusOpacity );
|
|
|
|
setGradient( Q::Panel | Q::Focused, c );
|
|
|
|
c.setAlphaF( m_pal.pressedOpacity );
|
|
|
|
setGradient( Q::Panel | Q::Pressed, c );
|
2022-02-17 21:54:56 +01:00
|
|
|
|
2020-12-21 16:06:58 +01:00
|
|
|
setAnimation( Q::Panel | A::Color, qskDuration );
|
2017-07-21 18:21:34 +02:00
|
|
|
|
2022-06-07 12:40:21 +02:00
|
|
|
setFontRole( Q::Text, QskMaterialSkin::M3LabelLarge );
|
2020-12-15 07:21:12 +01:00
|
|
|
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;
|
2017-10-17 17:34:00 +02:00
|
|
|
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
|
|
|
|
2022-06-03 10:40:13 +02: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
|
|
|
|
|
|
|
// 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
|
|
|
}
|
|
|
|
|
2022-03-31 18:29:39 +02:00
|
|
|
void Editor::setupTabView()
|
|
|
|
{
|
2017-10-17 17:34:00 +02:00
|
|
|
using Q = QskTabView;
|
|
|
|
|
2022-03-31 18:29:39 +02:00
|
|
|
setGradient( Q::Page, m_pal.background );
|
2017-10-17 17:34:00 +02:00
|
|
|
setAnimation( Q::Page, qskDuration );
|
2017-07-21 18:21:34 +02:00
|
|
|
}
|
|
|
|
|
2020-12-26 12:57:08 +01:00
|
|
|
void Editor::setupInputPanel()
|
2018-04-18 19:41:46 +02:00
|
|
|
{
|
2018-06-12 08:20:48 +02:00
|
|
|
using Q = QskInputPanelBox;
|
2018-04-18 19:41:46 +02:00
|
|
|
|
|
|
|
setBoxShape( Q::Panel, 0 );
|
|
|
|
setBoxBorderMetrics( Q::Panel, 0 );
|
2022-06-03 10:40:13 +02:00
|
|
|
setGradient( Q::Panel, m_pal.secondaryContainer );
|
2022-02-17 21:54:56 +01:00
|
|
|
setBoxBorderColors( Q::Panel, m_pal.background );
|
2018-04-18 19:41:46 +02:00
|
|
|
}
|
|
|
|
|
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
|
|
|
|
2017-10-17 17:34:00 +02:00
|
|
|
// key panel
|
2020-12-15 07:21:12 +01:00
|
|
|
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
|
|
|
|
2017-10-17 17:34:00 +02:00
|
|
|
// panel
|
2017-10-18 20:00:06 +02:00
|
|
|
setBoxShape( Q::Panel, 0 );
|
|
|
|
setBoxBorderMetrics( Q::Panel, 0 );
|
2022-06-03 10:40:13 +02:00
|
|
|
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-02-17 21:54:56 +01:00
|
|
|
setSpacing( Q::Panel, 5 );
|
2017-07-21 18:21:34 +02:00
|
|
|
|
2017-10-18 20:00:06 +02:00
|
|
|
setBoxBorderMetrics( Q::Viewport, 1 );
|
2022-02-17 21:54:56 +01:00
|
|
|
setGradient( Q::Viewport, m_pal.background );
|
|
|
|
setBoxBorderColors( Q::Viewport, m_pal.onBackground );
|
2018-01-03 11:57:05 +01:00
|
|
|
|
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 );
|
2020-12-15 07:21:12 +01:00
|
|
|
setPadding( subControl, 0 );
|
2018-01-03 11:57:05 +01:00
|
|
|
}
|
|
|
|
|
2020-12-16 12:49:24 +01:00
|
|
|
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 );
|
2022-06-03 10:40:13 +02:00
|
|
|
setGradient( subControl, m_pal.primary );
|
2020-12-21 16:06:58 +01:00
|
|
|
setAnimation( subControl | A::Color, qskDuration );
|
2018-01-03 11:57:05 +01:00
|
|
|
}
|
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-02-17 21:54:56 +01:00
|
|
|
setPadding( Q::Cell, 0 );
|
2017-07-21 18:21:34 +02:00
|
|
|
|
2022-06-03 10:40:13 +02:00
|
|
|
setGradient( Q::Cell, m_pal.surface );
|
|
|
|
setColor( Q::Text, m_pal.onSurfaceVariant );
|
2017-07-21 18:21:34 +02:00
|
|
|
|
2022-06-03 10:40:13 +02:00
|
|
|
setGradient( Q::Cell | Q::Selected, m_pal.secondaryContainer );
|
|
|
|
setColor( Q::Text | Q::Selected, m_pal.onSecondaryContainer );
|
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
|
|
|
|
2020-12-15 07:21:12 +01:00
|
|
|
setPadding( Q::Panel, 10 );
|
2017-10-18 20:00:06 +02:00
|
|
|
setBoxShape( Q::Panel, 0 );
|
|
|
|
setBoxBorderMetrics( Q::Panel, 2 );
|
2022-02-17 21:54:56 +01:00
|
|
|
setGradient( Q::Panel, m_pal.onBackground );
|
2017-07-21 18:21:34 +02:00
|
|
|
|
2022-02-17 21:54:56 +01:00
|
|
|
setBoxBorderColors( Q::Panel, m_pal.primary );
|
2017-07-21 18:21:34 +02:00
|
|
|
|
2021-04-28 09:32:49 +02:00
|
|
|
// TitleBarPanel
|
|
|
|
setFlagHint( Q::TitleBarPanel | QskAspect::Style,
|
|
|
|
Q::TitleBar | Q::Title | Q::Symbol );
|
|
|
|
|
2022-06-03 10:40:13 +02:00
|
|
|
setGradient( Q::TitleBarPanel, m_pal.surface );
|
|
|
|
setGradient( Q::TitleBarPanel | Q::Focused, m_pal.surfaceVariant );
|
2017-07-21 18:21:34 +02:00
|
|
|
|
2018-10-29 20:11:48 +01:00
|
|
|
// TitleBarText
|
|
|
|
setFontRole( Q::TitleBarText, QskSkin::SmallFont );
|
2020-12-15 07:21:12 +01:00
|
|
|
setAlignment( Q::TitleBarText, Qt::AlignLeft | Qt::AlignVCenter );
|
2018-10-29 20:11:48 +01:00
|
|
|
|
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-06-03 10:15:20 +02:00
|
|
|
QskMaterialTheme::QskMaterialTheme( Lightness lightness )
|
|
|
|
: QskMaterialTheme( lightness,
|
|
|
|
{
|
|
|
|
QskRgbPalette::palette( QskRgbPalette::DefaultMaterialPrimary ),
|
|
|
|
QskRgbPalette::palette( QskRgbPalette::DefaultMaterialSecondary ),
|
|
|
|
QskRgbPalette::palette( QskRgbPalette::DefaultMaterialTertiary ),
|
|
|
|
QskRgbPalette::palette( QskRgbPalette::DefaultMaterialError ),
|
|
|
|
QskRgbPalette::palette( QskRgbPalette::DefaultMaterialNeutral ),
|
|
|
|
QskRgbPalette::palette( QskRgbPalette::DefaultMaterialNeutralVariant ),
|
|
|
|
} )
|
|
|
|
{
|
|
|
|
}
|
|
|
|
|
|
|
|
QskMaterialTheme::QskMaterialTheme( Lightness lightness,
|
|
|
|
std::array< QskRgbPalette, NumPaletteTypes > palettes )
|
|
|
|
: m_palettes( palettes )
|
|
|
|
{
|
|
|
|
using Q = QskRgbPalette;
|
|
|
|
|
2022-06-07 16:21:04 +02:00
|
|
|
if ( lightness == Light )
|
2022-06-03 10:15:20 +02:00
|
|
|
{
|
|
|
|
primary = m_palettes[ Primary ].rgb( Q::W40 );
|
|
|
|
onPrimary = m_palettes[ Primary ].rgb( Q::W100 );
|
|
|
|
primaryContainer = m_palettes[ Primary ].rgb( Q::W90 );
|
|
|
|
onPrimaryContainer = m_palettes[ Primary ].rgb( Q::W10 );
|
|
|
|
|
2022-06-03 10:40:13 +02:00
|
|
|
secondary = m_palettes[ Secondary ].rgb( Q::W40 );
|
2022-06-03 10:15:20 +02:00
|
|
|
onSecondary = m_palettes[ Secondary ].rgb( Q::W100 );
|
|
|
|
secondaryContainer = m_palettes[ Secondary ].rgb( Q::W90 );
|
|
|
|
onSecondaryContainer = m_palettes[ Secondary ].rgb( Q::W10 );
|
|
|
|
|
|
|
|
tertiary = m_palettes[ Tertiary ].rgb( Q::W40 );
|
|
|
|
onTertiary = m_palettes[ Tertiary ].rgb( Q::W100 );
|
|
|
|
tertiaryContainer = m_palettes[ Tertiary ].rgb( Q::W90 );
|
|
|
|
onTertiaryContainer = m_palettes[ Tertiary ].rgb( Q::W10 );
|
|
|
|
|
|
|
|
error = m_palettes[ Error ].rgb( Q::W40 );
|
|
|
|
onError = m_palettes[ Error ].rgb( Q::W100 );
|
|
|
|
errorContainer = m_palettes[ Error ].rgb( Q::W90 );
|
|
|
|
onErrorContainer = m_palettes[ Error ].rgb( Q::W10 );
|
|
|
|
|
|
|
|
background = m_palettes[ Neutral ].rgb( Q::W99 );
|
|
|
|
onBackground = m_palettes[ Neutral ].rgb( Q::W10 );
|
|
|
|
surface = m_palettes[ Neutral ].rgb( Q::W99 );
|
|
|
|
onSurface = m_palettes[ Neutral ].rgb( Q::W10 );
|
|
|
|
|
|
|
|
surfaceVariant = m_palettes[ NeutralVariant ].rgb( Q::W90 );
|
|
|
|
onSurfaceVariant = m_palettes[ NeutralVariant ].rgb( Q::W30 );
|
|
|
|
outline = m_palettes[ NeutralVariant ].rgb( Q::W50 );
|
|
|
|
}
|
2022-06-07 16:21:04 +02:00
|
|
|
else if ( lightness == Dark )
|
2022-06-03 10:15:20 +02:00
|
|
|
{
|
|
|
|
primary = m_palettes[ Primary ].rgb( Q::W80 );
|
|
|
|
onPrimary = m_palettes[ Primary ].rgb( Q::W20 );
|
|
|
|
primaryContainer = m_palettes[ Primary ].rgb( Q::W30 );
|
|
|
|
onPrimaryContainer = m_palettes[ Primary ].rgb( Q::W90 );
|
|
|
|
|
2022-06-03 10:40:13 +02:00
|
|
|
secondary = m_palettes[ Secondary ].rgb( Q::W80 );
|
2022-06-03 10:15:20 +02:00
|
|
|
onSecondary = m_palettes[ Secondary ].rgb( Q::W20 );
|
|
|
|
secondaryContainer = m_palettes[ Secondary ].rgb( Q::W30 );
|
|
|
|
onSecondaryContainer = m_palettes[ Secondary ].rgb( Q::W90 );
|
|
|
|
|
|
|
|
tertiary = m_palettes[ Tertiary ].rgb( Q::W80 );
|
|
|
|
onTertiary = m_palettes[ Tertiary ].rgb( Q::W20 );
|
|
|
|
tertiaryContainer = m_palettes[ Tertiary ].rgb( Q::W30 );
|
|
|
|
onTertiaryContainer = m_palettes[ Tertiary ].rgb( Q::W90 );
|
|
|
|
|
|
|
|
error = m_palettes[ Error ].rgb( Q::W80 );
|
|
|
|
onError = m_palettes[ Error ].rgb( Q::W20 );
|
|
|
|
errorContainer = m_palettes[ Error ].rgb( Q::W30 );
|
|
|
|
onErrorContainer = m_palettes[ Error ].rgb( Q::W90 );
|
|
|
|
|
|
|
|
background = m_palettes[ Neutral ].rgb( Q::W10 );
|
|
|
|
onBackground = m_palettes[ Neutral ].rgb( Q::W90 );
|
|
|
|
surface = m_palettes[ Neutral ].rgb( Q::W10 );
|
|
|
|
onSurface = m_palettes[ Neutral ].rgb( Q::W80 );
|
|
|
|
|
|
|
|
surfaceVariant = m_palettes[ NeutralVariant ].rgb( Q::W30 );
|
|
|
|
onSurfaceVariant = m_palettes[ NeutralVariant ].rgb( Q::W80 );
|
|
|
|
outline = m_palettes[ NeutralVariant ].rgb( Q::W60 );
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2022-06-07 16:21:04 +02:00
|
|
|
QskMaterialSkin::QskMaterialSkin( const QskMaterialTheme& 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
|
|
|
|
2022-06-07 16:21:04 +02:00
|
|
|
Editor editor( &hintTable(), palette );
|
|
|
|
editor.setup();
|
2022-06-07 14:03:06 +02:00
|
|
|
}
|
|
|
|
|
2022-06-07 16:21:04 +02:00
|
|
|
QskMaterialSkin::~QskMaterialSkin()
|
2022-06-07 14:03:06 +02:00
|
|
|
{
|
|
|
|
}
|
|
|
|
|
2022-06-07 12:40:21 +02:00
|
|
|
void QskMaterialSkin::setupFonts()
|
|
|
|
{
|
|
|
|
Inherited::setupFonts( QStringLiteral( "Roboto" ) );
|
|
|
|
|
|
|
|
setFont( M3LabelLarge, createFont( 14 ) );
|
|
|
|
}
|
|
|
|
|
2017-07-21 18:21:34 +02:00
|
|
|
#include "moc_QskMaterialSkin.cpp"
|