spin box: Improve for M3

Resolves #398
This commit is contained in:
Peter Hartmann 2024-10-15 17:33:26 +02:00
parent 3d77cfbb7a
commit b414afdded
4 changed files with 64 additions and 9 deletions

View File

@ -898,6 +898,7 @@ void Editor::setupSpinBox()
setHint( Q::Panel | QskAspect::Style, Q::ButtonsLeftAndRight );
setStrutSize( Q::Panel, -1.0, 48_dp );
setBoxShape( Q::Panel, 4_dp );
setBoxBorderMetrics( Q::Panel, 1_dp );
@ -909,21 +910,25 @@ void Editor::setupSpinBox()
setSpacing( Q::Panel, 4_dp );
setStrutSize( Q::TextPanel, 80_dp, 40_dp );
setStrutSize( Q::UpPanel, 40_dp,40_dp );
setStrutSize( Q::UpPanel, 40_dp, 40_dp );
setStrutSize( Q::DownPanel, 40_dp, 40_dp );
setAlignment( Q::Text, Qt::AlignCenter );
for( const auto subControl : { Q::DownPanel, Q::UpPanel, Q::TextPanel } )
{
setBoxShape( subControl, 4_dp );
setBoxBorderMetrics( subControl, 1_dp );
}
setBoxShape( Q::TextPanel, 4_dp );
setBoxShape( Q::DownPanel, 100, Qt::RelativeSize );
setBoxShape( Q::UpPanel, 100, Qt::RelativeSize );
for( const auto subControl : { Q::DownPanel, Q::UpPanel } )
{
setGradient( subControl | Q::Hovered, m_pal.primary8 );
setPadding( subControl, 10 );
setPadding( subControl, 11_dp );
}
{

View File

@ -139,6 +139,8 @@ QskSpinBox::QskSpinBox( qreal min, qreal max, qreal stepSize, QQuickItem* parent
setBoundaries( min, max );
setStepSize( stepSize );
setAcceptHoverEvents( true );
setAcceptedMouseButtons( Qt::LeftButton );
setFocusPolicy( Qt::StrongFocus );
@ -302,6 +304,36 @@ void QskSpinBox::mouseUngrabEvent()
m_data->setAutoRepeat( this, 0.0 );
}
void QskSpinBox::hoverEnterEvent( QHoverEvent* event )
{
using A = QskAspect;
setSkinHint( UpPanel | Hovered | A::Metric | A::Position, qskHoverPosition( event ) );
setSkinHint( DownPanel | Hovered | A::Metric | A::Position, qskHoverPosition( event ) );
update();
}
void QskSpinBox::hoverMoveEvent( QHoverEvent* event )
{
using A = QskAspect;
setSkinHint( UpPanel | Hovered | A::Metric | A::Position, qskHoverPosition( event ) );
setSkinHint( DownPanel | Hovered | A::Metric | A::Position, qskHoverPosition( event ) );
update();
}
void QskSpinBox::hoverLeaveEvent( QHoverEvent* )
{
using A = QskAspect;
setSkinHint( UpPanel | Hovered | A::Metric | A::Position, QPointF() );
setSkinHint( DownPanel | Hovered | A::Metric | A::Position, QPointF() );
update();
}
void QskSpinBox::keyPressEvent( QKeyEvent* event )
{
if ( !isReadOnly() && !m_data->repeatTimer.isActive() )

View File

@ -75,6 +75,10 @@ class QSK_EXPORT QskSpinBox : public QskBoundedValueInput
void mousePressEvent( QMouseEvent* ) override;
void mouseUngrabEvent() override;
void hoverEnterEvent( QHoverEvent* ) override;
void hoverMoveEvent( QHoverEvent* ) override;
void hoverLeaveEvent( QHoverEvent* ) override;
void keyPressEvent( QKeyEvent* ) override;
void keyReleaseEvent( QKeyEvent* ) override;

View File

@ -14,22 +14,39 @@ static inline QskAspect::States qskButtonStates(
const QskSkinnable* skinnable, QskAspect::Subcontrol subControl )
{
using Q = QskSpinBox;
using A = QskAspect;
auto spinBox = static_cast< const QskSpinBox* >( skinnable );
auto states = spinBox->skinStates();
if ( spinBox->isEnabled() && !spinBox->isWrapping() )
if ( spinBox->isEnabled() )
{
if ( subControl == Q::DownIndicator || subControl == Q::DownPanel )
{
if ( spinBox->value() <= spinBox->minimum() )
if ( !spinBox->isWrapping() && spinBox->value() <= spinBox->minimum() )
states |= QskControl::Disabled;
const auto cursorPos = spinBox->effectiveSkinHint(
Q::DownPanel | Q::Hovered | A::Metric | A::Position ).toPointF();
if( !cursorPos.isNull() && spinBox->subControlRect( Q::DownPanel ).contains( cursorPos ) )
{
states |= Q::Hovered;
}
}
else if ( subControl == Q::UpIndicator || subControl == Q::UpPanel )
{
if ( spinBox->value() >= spinBox->maximum() )
if ( !spinBox->isWrapping() && spinBox->value() >= spinBox->maximum() )
states |= QskControl::Disabled;
const auto cursorPos = spinBox->effectiveSkinHint(
Q::UpPanel | Q::Hovered | A::Metric | A::Position ).toPointF();
if( !cursorPos.isNull() && spinBox->subControlRect( Q::UpPanel ).contains( cursorPos ) )
{
states |= Q::Hovered;
}
}
}
@ -47,9 +64,6 @@ QRectF QskSpinBoxSkinlet::subControlRect( const QskSkinnable* skinnable,
{
using Q = QskSpinBox;
QskSkinStateChanger stateChanger( skinnable );
stateChanger.setStates( qskButtonStates( skinnable, subControl ) );
if ( subControl == Q::Panel )
return contentsRect;