1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
|
/****************************************************************************
**
** Definition of the QSizePolicy class
**
** Created : 980929
**
** Copyright (C) 1998-2008 Trolltech ASA. All rights reserved.
**
** This file is part of the kernel module of the Qt GUI Toolkit.
**
** This file may be used under the terms of the GNU General
** Public License versions 2.0 or 3.0 as published by the Free
** Software Foundation and appearing in the files LICENSE.GPL2
** and LICENSE.GPL3 included in the packaging of this file.
** Alternatively you may (at your option) use any later version
** of the GNU General Public License if such license has been
** publicly approved by Trolltech ASA (or its successors, if any)
** and the KDE Free Qt Foundation.
**
** Please review the following information to ensure GNU General
** Public Licensing requirements will be met:
** http://trolltech.com/products/qt/licenses/licensing/opensource/.
** If you are unsure which license is appropriate for your use, please
** review the following information:
** http://trolltech.com/products/qt/licenses/licensing/licensingoverview
** or contact the sales department at sales@trolltech.com.
**
** This file may be used under the terms of the Q Public License as
** defined by Trolltech ASA and appearing in the file LICENSE.QPL
** included in the packaging of this file. Licensees holding valid Qt
** Commercial licenses may use this file in accordance with the Qt
** Commercial License Agreement provided with the Software.
**
** This file is provided "AS IS" with NO WARRANTY OF ANY KIND,
** INCLUDING THE WARRANTIES OF DESIGN, MERCHANTABILITY AND FITNESS FOR
** A PARTICULAR PURPOSE. Trolltech reserves all rights not granted
** herein.
**
**********************************************************************/
#ifndef QSIZEPOLICY_H
#define QSIZEPOLICY_H
#ifndef QT_H
#include "qglobal.h"
#endif // QT_H
// Documentation is in qabstractlayout.cpp.
class Q_EXPORT QSizePolicy
{
private:
enum SizePolicy_Internal { HSize = 6, HMask = 0x3f, VMask = HMask << HSize,
MayGrow = 1, ExpMask = 2, MayShrink = 4 };
public:
enum SizeType { Fixed = 0,
Minimum = MayGrow,
Maximum = MayShrink,
Preferred = MayGrow | MayShrink,
MinimumExpanding = MayGrow | ExpMask,
Expanding = MayGrow | MayShrink | ExpMask,
Ignored = ExpMask /* magic value */ };
enum ExpandData { NoDirection = 0,
Horizontally = 1,
Vertically = 2,
#ifndef QT_NO_COMPAT
Horizontal = Horizontally,
Vertical = Vertically,
#endif
BothDirections = Horizontally | Vertically };
QSizePolicy() : data( 0 ) { }
QSizePolicy( SizeType hor, SizeType ver, bool hfw = FALSE )
: data( hor | (ver<<HSize) | (hfw ? (Q_UINT32)(1<<2*HSize) : 0) ) { }
QSizePolicy( SizeType hor, SizeType ver, uchar hors, uchar vers, bool hfw = FALSE );
SizeType horData() const { return (SizeType)( data & HMask ); }
SizeType verData() const { return (SizeType)( (data & VMask) >> HSize ); }
bool mayShrinkHorizontally() const { return horData() & MayShrink || horData() == Ignored; }
bool mayShrinkVertically() const { return verData() & MayShrink || verData() == Ignored; }
bool mayGrowHorizontally() const { return horData() & MayGrow || horData() == Ignored; }
bool mayGrowVertically() const { return verData() & MayGrow || verData() == Ignored; }
ExpandData expanding() const
{
return (ExpandData)( (int)(verData() & ExpMask ? Vertically : 0) |
(int)(horData() & ExpMask ? Horizontally : 0) );
}
void setHorData( SizeType d ) { data = (Q_UINT32)(data & ~HMask) | d; }
void setVerData( SizeType d ) { data = (Q_UINT32)(data & ~(HMask << HSize)) |
(d << HSize); }
void setHeightForWidth( bool b ) { data = b ? (Q_UINT32)( data | ( 1 << 2*HSize ) )
: (Q_UINT32)( data & ~( 1 << 2*HSize ) ); }
bool hasHeightForWidth() const { return data & ( 1 << 2*HSize ); }
bool operator==( const QSizePolicy& s ) const { return data == s.data; }
bool operator!=( const QSizePolicy& s ) const { return data != s.data; }
uint horStretch() const { return data >> 24; }
uint verStretch() const { return (data >> 16) & 0xff; }
void setHorStretch( uchar sf ) { data = (data&0x00ffffff) | (uint(sf)<<24); }
void setVerStretch( uchar sf ) { data = (data&0xff00ffff) | (uint(sf)<<16); }
inline void transpose();
private:
QSizePolicy( int i ) : data( (Q_UINT32)i ) { }
Q_UINT32 data;
};
inline QSizePolicy::QSizePolicy( SizeType hor, SizeType ver, uchar hors, uchar vers, bool hfw )
: data( hor | (ver<<HSize) | (hfw ? (Q_UINT32)(1<<2*HSize) : 0) ) {
setHorStretch( hors );
setVerStretch( vers );
}
inline void QSizePolicy::transpose() {
*this = QSizePolicy( verData(), horData(), verStretch(), horStretch(),
hasHeightForWidth() );
}
#endif // QSIZEPOLICY_H
|