formal changes for QskLayoutHint
This commit is contained in:
parent
f920eee6c5
commit
bc54bfbe97
|
@ -17,6 +17,7 @@
|
||||||
#include <QskGradient.h>
|
#include <QskGradient.h>
|
||||||
#include <QskGraphicLabel.h>
|
#include <QskGraphicLabel.h>
|
||||||
#include <QskIntervalF.h>
|
#include <QskIntervalF.h>
|
||||||
|
#include <QskLayoutHint.h>
|
||||||
#include <QskMessageWindow.h>
|
#include <QskMessageWindow.h>
|
||||||
#include <QskPopup.h>
|
#include <QskPopup.h>
|
||||||
#include <QskPushButton.h>
|
#include <QskPushButton.h>
|
||||||
|
@ -289,6 +290,7 @@ void QskQml::registerTypes()
|
||||||
QSK_REGISTER_GADGET( QskGradient, "Gradient" );
|
QSK_REGISTER_GADGET( QskGradient, "Gradient" );
|
||||||
QSK_REGISTER_GADGET( QskGradientStop, "GradientStop" );
|
QSK_REGISTER_GADGET( QskGradientStop, "GradientStop" );
|
||||||
QSK_REGISTER_GADGET( QskIntervalF, "IntervalF" );
|
QSK_REGISTER_GADGET( QskIntervalF, "IntervalF" );
|
||||||
|
QSK_REGISTER_GADGET( QskLayoutHint, "LayoutHint" );
|
||||||
QSK_REGISTER_GADGET( QskSizePolicy, "SizePolicy" );
|
QSK_REGISTER_GADGET( QskSizePolicy, "SizePolicy" );
|
||||||
QSK_REGISTER_GADGET( QskTextOptions, "TextOptions" );
|
QSK_REGISTER_GADGET( QskTextOptions, "TextOptions" );
|
||||||
|
|
||||||
|
|
|
@ -6,38 +6,9 @@
|
||||||
#include "QskLayoutHint.h"
|
#include "QskLayoutHint.h"
|
||||||
#include "QskControl.h"
|
#include "QskControl.h"
|
||||||
#include <qnamespace.h>
|
#include <qnamespace.h>
|
||||||
|
#include <algorithm>
|
||||||
|
|
||||||
QskLayoutHint::QskLayoutHint()
|
void QskLayoutHint::setSize( int which, qreal size ) noexcept
|
||||||
: QskLayoutHint( 0.0, 0.0, QskLayoutHint::unlimited )
|
|
||||||
{
|
|
||||||
}
|
|
||||||
|
|
||||||
QskLayoutHint::QskLayoutHint( qreal minimum, qreal preferred, qreal maximum )
|
|
||||||
: m_minimum( minimum )
|
|
||||||
, m_preferred( preferred )
|
|
||||||
, m_maximum( maximum )
|
|
||||||
{
|
|
||||||
}
|
|
||||||
|
|
||||||
qreal QskLayoutHint::size( int which ) const
|
|
||||||
{
|
|
||||||
switch( which )
|
|
||||||
{
|
|
||||||
case Qt::MinimumSize:
|
|
||||||
return m_minimum;
|
|
||||||
|
|
||||||
case Qt::PreferredSize:
|
|
||||||
return m_preferred;
|
|
||||||
|
|
||||||
case Qt::MaximumSize:
|
|
||||||
return m_maximum;
|
|
||||||
|
|
||||||
default:
|
|
||||||
return 0.0;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
void QskLayoutHint::setSize( int which, qreal size )
|
|
||||||
{
|
{
|
||||||
switch (which)
|
switch (which)
|
||||||
{
|
{
|
||||||
|
@ -58,27 +29,21 @@ void QskLayoutHint::setSize( int which, qreal size )
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
void QskLayoutHint::expandTo( const QskLayoutHint& other )
|
void QskLayoutHint::expandTo( const QskLayoutHint& other ) noexcept
|
||||||
{
|
{
|
||||||
m_minimum = qMax( m_minimum, other.m_minimum );
|
m_minimum = std::max( m_minimum, other.m_minimum );
|
||||||
m_preferred = qMax( m_preferred, other.m_preferred );
|
m_preferred = std::max( m_preferred, other.m_preferred );
|
||||||
m_maximum = qMax( m_maximum, other.m_maximum );
|
m_maximum = std::max( m_maximum, other.m_maximum );
|
||||||
}
|
}
|
||||||
|
|
||||||
void QskLayoutHint::normalize()
|
void QskLayoutHint::normalize() noexcept
|
||||||
{
|
{
|
||||||
m_minimum = qMax( m_minimum, qreal( 0.0 ) );
|
m_minimum = std::max( m_minimum, qreal( 0.0 ) );
|
||||||
m_maximum = qMax( m_minimum, m_maximum );
|
m_maximum = std::max( m_minimum, m_maximum );
|
||||||
m_preferred = qBound( m_minimum, m_preferred, m_maximum );
|
m_preferred = qBound( m_minimum, m_preferred, m_maximum );
|
||||||
}
|
}
|
||||||
|
|
||||||
bool QskLayoutHint::isDefault() const
|
qreal QskLayoutHint::combined( int which, qreal value1, qreal value2 ) noexcept
|
||||||
{
|
|
||||||
return ( m_minimum == 0.0 ) && ( m_preferred == 0.0 )
|
|
||||||
&& ( m_maximum == QskLayoutHint::unlimited );
|
|
||||||
}
|
|
||||||
|
|
||||||
qreal QskLayoutHint::combined( int which, qreal value1, qreal value2 )
|
|
||||||
{
|
{
|
||||||
if ( which == Qt::MaximumSize )
|
if ( which == Qt::MaximumSize )
|
||||||
{
|
{
|
||||||
|
@ -88,10 +53,10 @@ qreal QskLayoutHint::combined( int which, qreal value1, qreal value2 )
|
||||||
if ( value2 < 0.0 )
|
if ( value2 < 0.0 )
|
||||||
return value1;
|
return value1;
|
||||||
|
|
||||||
return qMin( value1, value2 );
|
return std::min( value1, value2 );
|
||||||
}
|
}
|
||||||
|
|
||||||
return qMax( value1, value2 );
|
return std::max( value1, value2 );
|
||||||
}
|
}
|
||||||
|
|
||||||
#ifndef QT_NO_DEBUG_STREAM
|
#ifndef QT_NO_DEBUG_STREAM
|
||||||
|
@ -120,3 +85,5 @@ QDebug operator<<( QDebug debug, const QskLayoutHint& hint )
|
||||||
}
|
}
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
#include "moc_QskLayoutHint.cpp"
|
||||||
|
|
|
@ -8,133 +8,178 @@
|
||||||
|
|
||||||
#include "QskGlobal.h"
|
#include "QskGlobal.h"
|
||||||
#include <qglobal.h>
|
#include <qglobal.h>
|
||||||
|
#include <qmetatype.h>
|
||||||
#include <limits>
|
#include <limits>
|
||||||
|
|
||||||
class QDebug;
|
|
||||||
|
|
||||||
class QSK_EXPORT QskLayoutHint
|
class QSK_EXPORT QskLayoutHint
|
||||||
{
|
{
|
||||||
|
Q_GADGET
|
||||||
|
|
||||||
|
Q_PROPERTY( qreal minimum READ minimum WRITE setMinimum )
|
||||||
|
Q_PROPERTY( qreal preferred READ preferred WRITE setPreferred )
|
||||||
|
Q_PROPERTY( qreal maximum READ maximum WRITE setMaximum )
|
||||||
|
|
||||||
public:
|
public:
|
||||||
QskLayoutHint();
|
constexpr QskLayoutHint() noexcept = default;
|
||||||
QskLayoutHint( qreal minimum, qreal preferred, qreal maximum );
|
constexpr QskLayoutHint( qreal minimum, qreal preferred, qreal maximum ) noexcept;
|
||||||
|
|
||||||
void normalize();
|
void normalize() noexcept;
|
||||||
|
|
||||||
QskLayoutHint normalized() const;
|
QskLayoutHint normalized() const noexcept;
|
||||||
bool isDefault() const;
|
constexpr bool isDefault() const noexcept;
|
||||||
|
|
||||||
qreal size( int which ) const;
|
qreal size( int which ) const noexcept;
|
||||||
void setSize( int which, qreal size );
|
void setSize( int which, qreal size ) noexcept;
|
||||||
|
|
||||||
bool operator==( const QskLayoutHint& ) const;
|
constexpr bool operator==( const QskLayoutHint& ) const noexcept;
|
||||||
bool operator!=( const QskLayoutHint& ) const;
|
constexpr bool operator!=( const QskLayoutHint& ) const noexcept;
|
||||||
|
|
||||||
void setMinimum( qreal value );
|
void setMinimum( qreal value ) noexcept;
|
||||||
qreal minimum() const;
|
constexpr qreal minimum() const noexcept;
|
||||||
|
|
||||||
void setPreferred( qreal value );
|
void setPreferred( qreal value ) noexcept;
|
||||||
qreal preferred() const;
|
constexpr qreal preferred() const noexcept;
|
||||||
|
|
||||||
void setMaximum( qreal value );
|
void setMaximum( qreal value ) noexcept;
|
||||||
qreal maximum() const;
|
constexpr qreal maximum() const noexcept;
|
||||||
|
|
||||||
void setSizes( qreal minimum, qreal preferred, qreal maximum );
|
void setSizes( qreal minimum, qreal preferred, qreal maximum ) noexcept;
|
||||||
void expandTo( const QskLayoutHint& );
|
void expandTo( const QskLayoutHint& ) noexcept;
|
||||||
|
|
||||||
void expandMinimum( qreal value );
|
void expandMinimum( qreal value ) noexcept;
|
||||||
void expandPreferred( qreal value );
|
void expandPreferred( qreal value ) noexcept;
|
||||||
void expandMaximum( qreal value );
|
void expandMaximum( qreal value ) noexcept;
|
||||||
|
|
||||||
static qreal combined( int which, qreal value1, qreal value2 );
|
static qreal combined( int which, qreal value1, qreal value2 ) noexcept;
|
||||||
static constexpr qreal unlimited = std::numeric_limits< float >::max();
|
static constexpr qreal unlimited = std::numeric_limits< float >::max();
|
||||||
|
|
||||||
private:
|
private:
|
||||||
qreal m_minimum;
|
qreal m_minimum = 0.0;
|
||||||
qreal m_preferred;
|
qreal m_preferred = 0.0;
|
||||||
qreal m_maximum;
|
qreal m_maximum = QskLayoutHint::unlimited;
|
||||||
};
|
};
|
||||||
|
|
||||||
inline qreal QskLayoutHint::minimum() const
|
Q_DECLARE_TYPEINFO( QskLayoutHint, Q_MOVABLE_TYPE );
|
||||||
|
Q_DECLARE_METATYPE( QskLayoutHint )
|
||||||
|
|
||||||
|
QT_WARNING_PUSH
|
||||||
|
QT_WARNING_DISABLE_CLANG("-Wfloat-equal")
|
||||||
|
QT_WARNING_DISABLE_GCC("-Wfloat-equal")
|
||||||
|
QT_WARNING_DISABLE_INTEL(1572)
|
||||||
|
|
||||||
|
inline constexpr QskLayoutHint::QskLayoutHint(
|
||||||
|
qreal minimum, qreal preferred, qreal maximum ) noexcept
|
||||||
|
: m_minimum( minimum )
|
||||||
|
, m_preferred( preferred )
|
||||||
|
, m_maximum( maximum )
|
||||||
|
{
|
||||||
|
}
|
||||||
|
|
||||||
|
inline constexpr qreal QskLayoutHint::minimum() const noexcept
|
||||||
{
|
{
|
||||||
return m_minimum;
|
return m_minimum;
|
||||||
}
|
}
|
||||||
|
|
||||||
inline void QskLayoutHint::setMinimum( qreal value )
|
inline void QskLayoutHint::setMinimum( qreal value ) noexcept
|
||||||
{
|
{
|
||||||
m_minimum = value;
|
m_minimum = value;
|
||||||
}
|
}
|
||||||
|
|
||||||
inline qreal QskLayoutHint::preferred() const
|
inline constexpr qreal QskLayoutHint::preferred() const noexcept
|
||||||
{
|
{
|
||||||
return m_preferred;
|
return m_preferred;
|
||||||
}
|
}
|
||||||
|
|
||||||
inline void QskLayoutHint::setPreferred( qreal value )
|
inline void QskLayoutHint::setPreferred( qreal value ) noexcept
|
||||||
{
|
{
|
||||||
m_preferred = value;
|
m_preferred = value;
|
||||||
}
|
}
|
||||||
|
|
||||||
inline qreal QskLayoutHint::maximum() const
|
inline constexpr qreal QskLayoutHint::maximum() const noexcept
|
||||||
{
|
{
|
||||||
return m_maximum;
|
return m_maximum;
|
||||||
}
|
}
|
||||||
|
|
||||||
inline void QskLayoutHint::setMaximum( qreal value )
|
inline void QskLayoutHint::setMaximum( qreal value ) noexcept
|
||||||
{
|
{
|
||||||
m_maximum = value;
|
m_maximum = value;
|
||||||
}
|
}
|
||||||
|
|
||||||
inline void QskLayoutHint::expandMinimum( qreal value )
|
inline void QskLayoutHint::expandMinimum( qreal value ) noexcept
|
||||||
{
|
{
|
||||||
if ( value > m_minimum )
|
if ( value > m_minimum )
|
||||||
m_minimum = value;
|
m_minimum = value;
|
||||||
}
|
}
|
||||||
|
|
||||||
inline void QskLayoutHint::expandPreferred( qreal value )
|
inline void QskLayoutHint::expandPreferred( qreal value ) noexcept
|
||||||
{
|
{
|
||||||
if ( value > m_preferred )
|
if ( value > m_preferred )
|
||||||
m_preferred = value;
|
m_preferred = value;
|
||||||
}
|
}
|
||||||
|
|
||||||
inline void QskLayoutHint::expandMaximum( qreal value )
|
inline void QskLayoutHint::expandMaximum( qreal value ) noexcept
|
||||||
{
|
{
|
||||||
if ( value > m_maximum )
|
if ( value > m_maximum )
|
||||||
m_maximum = value;
|
m_maximum = value;
|
||||||
}
|
}
|
||||||
|
|
||||||
inline void QskLayoutHint::setSizes(
|
inline void QskLayoutHint::setSizes(
|
||||||
qreal minimum, qreal preferred, qreal maximum )
|
qreal minimum, qreal preferred, qreal maximum ) noexcept
|
||||||
{
|
{
|
||||||
m_minimum = minimum;
|
m_minimum = minimum;
|
||||||
m_preferred = preferred;
|
m_preferred = preferred;
|
||||||
m_maximum = maximum;
|
m_maximum = maximum;
|
||||||
}
|
}
|
||||||
|
|
||||||
inline bool QskLayoutHint::operator==( const QskLayoutHint& other ) const
|
inline qreal QskLayoutHint::size( int which ) const noexcept
|
||||||
|
{
|
||||||
|
switch( which )
|
||||||
|
{
|
||||||
|
case Qt::MinimumSize:
|
||||||
|
return m_minimum;
|
||||||
|
|
||||||
|
case Qt::PreferredSize:
|
||||||
|
return m_preferred;
|
||||||
|
|
||||||
|
case Qt::MaximumSize:
|
||||||
|
return m_maximum;
|
||||||
|
}
|
||||||
|
|
||||||
|
return 0.0;
|
||||||
|
}
|
||||||
|
|
||||||
|
inline constexpr bool QskLayoutHint::isDefault() const noexcept
|
||||||
|
{
|
||||||
|
return ( m_minimum == 0.0 ) && ( m_preferred == 0.0 )
|
||||||
|
&& ( m_maximum == QskLayoutHint::unlimited );
|
||||||
|
}
|
||||||
|
|
||||||
|
inline constexpr bool QskLayoutHint::operator==( const QskLayoutHint& other ) const noexcept
|
||||||
{
|
{
|
||||||
return ( m_preferred == other.m_preferred )
|
return ( m_preferred == other.m_preferred )
|
||||||
&& ( m_minimum == other.m_minimum )
|
&& ( m_minimum == other.m_minimum )
|
||||||
&& ( m_maximum == other.m_maximum );
|
&& ( m_maximum == other.m_maximum );
|
||||||
}
|
}
|
||||||
|
|
||||||
inline bool QskLayoutHint::operator!=( const QskLayoutHint& other ) const
|
inline constexpr bool QskLayoutHint::operator!=( const QskLayoutHint& other ) const noexcept
|
||||||
{
|
{
|
||||||
return !( *this == other );
|
return !( *this == other );
|
||||||
}
|
}
|
||||||
|
|
||||||
inline QskLayoutHint QskLayoutHint::normalized() const
|
inline QskLayoutHint QskLayoutHint::normalized() const noexcept
|
||||||
{
|
{
|
||||||
auto hint = *this;
|
auto hint = *this;
|
||||||
hint.normalize();
|
hint.normalize();
|
||||||
return hint;
|
return hint;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
QT_WARNING_POP
|
||||||
|
|
||||||
#ifndef QT_NO_DEBUG_STREAM
|
#ifndef QT_NO_DEBUG_STREAM
|
||||||
|
|
||||||
|
class QDebug;
|
||||||
QSK_EXPORT QDebug operator<<( QDebug, const QskLayoutHint& );
|
QSK_EXPORT QDebug operator<<( QDebug, const QskLayoutHint& );
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
Q_DECLARE_TYPEINFO( QskLayoutHint, Q_MOVABLE_TYPE );
|
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
|
Loading…
Reference in New Issue