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 ); setHint( Q::Panel | QskAspect::Style, Q::ButtonsLeftAndRight );
setStrutSize( Q::Panel, -1.0, 48_dp );
setBoxShape( Q::Panel, 4_dp ); setBoxShape( Q::Panel, 4_dp );
setBoxBorderMetrics( Q::Panel, 1_dp ); setBoxBorderMetrics( Q::Panel, 1_dp );
@ -909,21 +910,25 @@ void Editor::setupSpinBox()
setSpacing( Q::Panel, 4_dp ); setSpacing( Q::Panel, 4_dp );
setStrutSize( Q::TextPanel, 80_dp, 40_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 ); setStrutSize( Q::DownPanel, 40_dp, 40_dp );
setAlignment( Q::Text, Qt::AlignCenter ); setAlignment( Q::Text, Qt::AlignCenter );
for( const auto subControl : { Q::DownPanel, Q::UpPanel, Q::TextPanel } ) for( const auto subControl : { Q::DownPanel, Q::UpPanel, Q::TextPanel } )
{ {
setBoxShape( subControl, 4_dp );
setBoxBorderMetrics( subControl, 1_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 } ) for( const auto subControl : { Q::DownPanel, Q::UpPanel } )
{ {
setGradient( subControl | Q::Hovered, m_pal.primary8 ); 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 ); setBoundaries( min, max );
setStepSize( stepSize ); setStepSize( stepSize );
setAcceptHoverEvents( true );
setAcceptedMouseButtons( Qt::LeftButton ); setAcceptedMouseButtons( Qt::LeftButton );
setFocusPolicy( Qt::StrongFocus ); setFocusPolicy( Qt::StrongFocus );
@ -302,6 +304,36 @@ void QskSpinBox::mouseUngrabEvent()
m_data->setAutoRepeat( this, 0.0 ); 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 ) void QskSpinBox::keyPressEvent( QKeyEvent* event )
{ {
if ( !isReadOnly() && !m_data->repeatTimer.isActive() ) if ( !isReadOnly() && !m_data->repeatTimer.isActive() )

View File

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

View File

@ -14,22 +14,39 @@ static inline QskAspect::States qskButtonStates(
const QskSkinnable* skinnable, QskAspect::Subcontrol subControl ) const QskSkinnable* skinnable, QskAspect::Subcontrol subControl )
{ {
using Q = QskSpinBox; using Q = QskSpinBox;
using A = QskAspect;
auto spinBox = static_cast< const QskSpinBox* >( skinnable ); auto spinBox = static_cast< const QskSpinBox* >( skinnable );
auto states = spinBox->skinStates(); auto states = spinBox->skinStates();
if ( spinBox->isEnabled() && !spinBox->isWrapping() ) if ( spinBox->isEnabled() )
{ {
if ( subControl == Q::DownIndicator || subControl == Q::DownPanel ) if ( subControl == Q::DownIndicator || subControl == Q::DownPanel )
{ {
if ( spinBox->value() <= spinBox->minimum() ) if ( !spinBox->isWrapping() && spinBox->value() <= spinBox->minimum() )
states |= QskControl::Disabled; 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 ) else if ( subControl == Q::UpIndicator || subControl == Q::UpPanel )
{ {
if ( spinBox->value() >= spinBox->maximum() ) if ( !spinBox->isWrapping() && spinBox->value() >= spinBox->maximum() )
states |= QskControl::Disabled; 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; using Q = QskSpinBox;
QskSkinStateChanger stateChanger( skinnable );
stateChanger.setStates( qskButtonStates( skinnable, subControl ) );
if ( subControl == Q::Panel ) if ( subControl == Q::Panel )
return contentsRect; return contentsRect;