QPageSize

PyQt5.QtGui.QPageSize

Description

The QPageSize class describes the size and name of a defined page size.

This class implements support for the set of standard page sizes as defined in the Adobe Postscript PPD Standard v4.3. It defines the standard set of page sizes in points, millimeters and inches and ensures these sizes are consistently used. Other size units can be used but will be calculated results and so may not always be consistent. The defined point sizes are always a integer, all other sizes can be fractions of a unit.

The defined size is always in width x height order with no implied page orientation. Note that it is possible for page sizes to be defined where the width is greater than the height, such as Ledger, so you cannot rely on comparing the width and height values to determine page orientation.

For example, A4 is defined by the standard as 210mm x 297mm, 8.27in x 11.69in, or 595pt x 842pt.

You can also define custom page sizes with custom names in any units you want and this unit size will be preserved and used as the base for all other unit size calculations.

When creating a QPageSize using a custom QSize you can choose if you want QPageSize to try match the size to a standard page size. By default QPaperSize uses a FuzzyMatch mode where it will match a given page size to a standard page size if it falls within 3 postscript points of a defined standard size. You can override this to request only an exact match but this is not recommended as conversions between units can easily lose 3 points and result in incorrect page sizes.

A QPageSize instance may also be obtained by querying the supported page sizes for a print device. In this case the localized name returned is that defined by the printer itself. Note that the print device may not support the current default locale language.

The class also provides convenience methods for converting page size IDs to and from various unit sizes.

Enums

PageSizeId

This enum type lists the available page sizes as defined in the Postscript PPD standard. These values are duplicated in QPagedPaintDevice and QPrinter.

The defined sizes are:

Due to historic reasons is not the same as the standard Postscript and Windows Executive size, use instead.

The Postscript standard size is different to the Windows DMPAPER_FOLIO size, use the Postscript standard size if needed.

Member

Value

Description

A0

5

841 x 1189 mm

A1

6

594 x 841 mm

A10

TODO

TODO

A2

7

420 x 594 mm

A3

8

297 x 420 mm

A3Extra

TODO

TODO

A4

0

210 x 297 mm, 8.26 x 11.69 inches

A4Extra

TODO

TODO

A4Plus

TODO

TODO

A4Small

TODO

TODO

A5

9

148 x 210 mm

A5Extra

TODO

TODO

A6

10

105 x 148 mm

A7

11

74 x 105 mm

A8

12

52 x 74 mm

A9

13

37 x 52 mm

AnsiA

Letter

= Letter

AnsiB

Ledger

= Ledger

AnsiC

TODO

TODO

AnsiD

TODO

TODO

AnsiE

TODO

TODO

ArchA

TODO

TODO

ArchB

TODO

TODO

ArchC

TODO

TODO

ArchD

TODO

TODO

ArchE

TODO

TODO

B0

14

1000 x 1414 mm

B1

15

707 x 1000 mm

B10

16

31 x 44 mm

B2

17

500 x 707 mm

B3

18

353 x 500 mm

B4

19

250 x 353 mm

B5

1

176 x 250 mm, 6.93 x 9.84 inches

B5Extra

TODO

TODO

B6

20

125 x 176 mm

B7

21

88 x 125 mm

B8

22

62 x 88 mm

B9

23

44 x 62 mm

C5E

24

163 x 229 mm

Comm10E

25

105 x 241 mm, U.S. Common 10 Envelope

Custom

30

Unknown, or a user defined size.

DLE

26

110 x 220 mm

DoublePostcard

TODO

TODO

Envelope10

Comm10E

=

Envelope11

TODO

TODO

Envelope12

TODO

TODO

Envelope14

TODO

TODO

Envelope9

TODO

TODO

EnvelopeB4

TODO

TODO

EnvelopeB5

TODO

TODO

EnvelopeB6

TODO

TODO

EnvelopeC0

TODO

TODO

EnvelopeC1

TODO

TODO

EnvelopeC2

TODO

TODO

EnvelopeC3

TODO

TODO

EnvelopeC4

TODO

TODO

EnvelopeC5

C5E

= C5E

EnvelopeC6

TODO

TODO

EnvelopeC65

TODO

TODO

EnvelopeC7

TODO

TODO

EnvelopeChou3

TODO

TODO

EnvelopeChou4

TODO

TODO

EnvelopeDL

DLE

= DLE

EnvelopeInvite

TODO

TODO

EnvelopeItalian

TODO

TODO

EnvelopeKaku2

TODO

TODO

EnvelopeKaku3

TODO

TODO

EnvelopeMonarch

TODO

TODO

EnvelopePersonal

TODO

TODO

EnvelopePrc1

TODO

TODO

EnvelopePrc10

TODO

TODO

EnvelopePrc2

TODO

TODO

EnvelopePrc3

TODO

TODO

EnvelopePrc4

TODO

TODO

EnvelopePrc5

TODO

TODO

EnvelopePrc6

TODO

TODO

EnvelopePrc7

TODO

TODO

EnvelopePrc8

TODO

TODO

EnvelopePrc9

TODO

TODO

EnvelopeYou4

TODO

TODO

Executive

4

7.5 x 10 inches, 190.5 x 254 mm

ExecutiveStandard

TODO

TODO

FanFoldGerman

TODO

TODO

FanFoldGermanLegal

TODO

TODO

FanFoldUS

TODO

TODO

Folio

27

210 x 330 mm

Imperial10x11

TODO

TODO

Imperial10x13

TODO

TODO

Imperial10x14

TODO

TODO

Imperial12x11

TODO

TODO

Imperial15x11

TODO

TODO

Imperial7x9

TODO

TODO

Imperial8x10

TODO

TODO

Imperial9x11

TODO

TODO

Imperial9x12

TODO

TODO

JisB0

TODO

TODO

JisB1

TODO

TODO

JisB10

TODO

TODO

JisB2

TODO

TODO

JisB3

TODO

TODO

JisB4

TODO

TODO

JisB5

TODO

TODO

JisB6

44

,

JisB7

TODO

TODO

JisB8

TODO

TODO

JisB9

TODO

TODO

LastPageSize

EnvelopeYou4

=

Ledger

28

431.8 x 279.4 mm

3

8.5 x 14 inches, 215.9 x 355.6 mm

LegalExtra

TODO

TODO

Letter

2

8.5 x 11 inches, 215.9 x 279.4 mm

LetterExtra

TODO

TODO

LetterPlus

TODO

TODO

LetterSmall

TODO

TODO

Note

TODO

TODO

NPageSize

TODO

TODO

NPaperSize

TODO

TODO

Postcard

TODO

TODO

Prc16K

TODO

TODO

Prc32K

TODO

TODO

Prc32KBig

TODO

TODO

Quarto

TODO

TODO

Statement

TODO

TODO

SuperA

TODO

TODO

SuperB

TODO

TODO

Tabloid

29

279.4 x 431.8 mm

TabloidExtra

TODO

TODO


SizeMatchPolicy

Member

Value

Description

ExactMatch

2

Only match to a standard page size if the sizes match exactly.

FuzzyMatch

0

Match to a standard page size if within the margin of tolerance.

FuzzyOrientationMatch

1

Match to a standard page size if within the margin of tolerance regardless of orientation.


Unit

This enum type is used to specify the measurement unit for page sizes.

Member

Value

Description

Cicero

5

1/6th of a French inch, 12 Didot, 4.5mm

Didot

4

1/72th of a French inch, 0.375 mm

Inch

TODO

TODO

Millimeter

TODO

TODO

Pica

3

1/72th of a foot, 1/6th of an inch, 12 Points

Point

1

1/72th of an inch

Methods

__init__()

Creates a null QPageSize.


__init__(PageSizeId)

Creates a QPageSize of the standard pageSize.

If pageSize is Custom then the resulting QPageSize will not be valid. Use the custom size constructor instead.


__init__(QPageSize)

Copy constructor, copies other to this.


__init__(QSize, name: str = '', matchPolicy: SizeMatchPolicy = FuzzyMatch)

Creates a QPageSize of the given pointSize in Points using the matching matchPolicy.

If the given pointSize matches a standard PageSizeId, then that page size will be used. Note that if the matchPolicy is FuzzyMatch this may result in the pointSize being adjusted to the standard size. To prevent this happening use a matchPolicy of ExactMatch instead.

If the given pointSize is not a standard PageSizeId then a Custom size will be created.

If name is null then the standard localized name will be used. If a custom page size then a custom name in the format “Custom (width x height)” will be created.

The matchPolicy defaults to FuzzyMatch.


__init__(QSizeF, Unit, name: str = '', matchPolicy: SizeMatchPolicy = FuzzyMatch)

Creates a custom page of the given size in units.

If the given size matches a standard PageSizeId, then that page size will be used. Note that if the matchPolicy is FuzzyMatch this may result in the size being adjusted to the standard size. To prevent this happening use a matchPolicy of ExactMatch instead.

If the given size is not a standard PageSizeId then a Custom size will be created. The original unit size will be preserved and used as the base for all other unit size calculations.

If name is null then a custom name will be created in the form “Custom (width x height)” where the size is expressed in units provided.


definitionSize() → QSizeF

Returns the definition size of the page size.

For a standard page size this will be the size as defined in the relevant standard, i.e. ISO A4 will be defined in millimeters while ANSI Letter will be defined in inches.

For a custom page size this will be the original size used to create the page size object.

If the QPageSize is invalid then the QSizeF will be invalid.

See also

definitionUnits().


@staticmethod
definitionSize(PageSizeId) → QSizeF

Returns the definition size of the standard pageSizeId.

To obtain the definition units, call QPageSize::definitionUnits().


definitionUnits() → Unit

Returns the definition units of the page size.

For a standard page size this will be the units as defined in the relevant standard, i.e. ISO A4 will be defined in millimeters while ANSI Letter will be defined in inches.

For a custom page size this will be the original units used to create the page size object.

If the QPageSize is invalid then the Unit will be invalid.

See also

definitionSize().


@staticmethod
definitionUnits(PageSizeId) → Unit

Returns the definition units of the standard pageSizeId.

To obtain the definition size, call QPageSize::definitionSize().


__eq__(QPageSize) → bool

TODO


id() → PageSizeId

Returns the standard PageSizeId of the page, or Custom.

If the QPageSize is invalid then the ID will be Custom.


@staticmethod
id(int) → PageSizeId

Returns the PageSizeId for the given Windows DMPAPER enum value windowsId.

If there is no matching PageSizeId then Custom is returned.


@staticmethod
id(QSize, matchPolicy: SizeMatchPolicy = FuzzyMatch) → PageSizeId

Returns the standard PageSizeId of the given pointSize in points using the given matchPolicy.

If using FuzzyMatch then the point size of the PageSizeId returned may not exactly match the pointSize you passed in. You should call QPageSize::sizePoints() using the returned PageSizeId to find out the actual point size of the PageSizeId before using it in any calculations.


@staticmethod
id(QSizeF, Unit, matchPolicy: SizeMatchPolicy = FuzzyMatch) → PageSizeId

Returns the standard PageSizeId of the given size in units using the given matchPolicy.

If using FuzzyMatch then the unit size of the PageSizeId returned may not exactly match the size you passed in. You should call QPageSize::size() using the returned PageSizeId to find out the actual unit size of the PageSizeId before using it in any calculations.


isEquivalentTo(QPageSize) → bool

Returns true if this page is equivalent to the other page, i.e. if the page has the same size regardless of other attributes like name.


isValid() → bool

Returns true if this page size is valid.

The page size may be invalid if created with an invalid PageSizeId, or a negative or invalid QSize or QSizeF, or the null constructor.


key() → str

Returns the unique key of the page size.

By default this is the PPD standard mediaOption keyword for the page size, or the PPD custom format key. If the QPageSize instance was obtained from a print device then this will be the key provided by the print device and may differ from the standard key.

If the QPageSize is invalid then the key will be an empty string.

This key should never be shown to end users, it is an internal key only. For a human-readable name use name().

See also

name().


@staticmethod
key(PageSizeId) → str

Returns the PPD mediaOption keyword of the standard pageSizeId.

If the QPageSize is invalid then the key will be empty.


name() → str

Returns a localized human-readable name for the page size.

If the QPageSize instance was obtained from a print device then the name used is that provided by the print device. Note that a print device may not support the current default locale language.

If the QPageSize is invalid then the name will be an empty string.


@staticmethod
name(PageSizeId) → str

Returns the localized name of the standard pageSizeId.

If the QPageSize is invalid then the name will be empty.


__ne__(QPageSize) → bool

TODO


rect(Unit) → QRectF

Returns the page rectangle in the required units.

If the QPageSize is invalid then the QRect will be invalid.


rectPixels(int) → QRect

Returns the page rectangle in Device Pixels at the given resolution.

If the QPageSize is invalid then the QRect will be invalid.


rectPoints() → QRect

Returns the page rectangle in Postscript Points (1/72 of an inch).

If the QPageSize is invalid then the QRect will be invalid.


size(Unit) → QSizeF

Returns the size of the page in the required units.

If the QPageSize is invalid then the QSizeF will be invalid.


@staticmethod
size(PageSizeId, Unit) → QSizeF

Returns the size of the standard pageSizeId in the requested units.


sizePixels(int) → QSize

Returns the size of the page in Device Pixels at the given resolution.

If the QPageSize is invalid then the QSize will be invalid.


@staticmethod
sizePixels(PageSizeId, int) → QSize

Returns the size of the standard pageSizeId in Device Pixels for the given resolution.


sizePoints() → QSize

Returns the size of the page in Postscript Points (1/72 of an inch).

If the QPageSize is invalid then the QSize will be invalid.


@staticmethod
sizePoints(PageSizeId) → QSize

Returns the size of the standard pageSizeId in Points.


swap(QPageSize)

TODO


windowsId() → int

Returns the Windows DMPAPER enum value for the page size.

Not all valid PPD page sizes have a Windows equivalent, in which case 0 will be returned.

If the QPageSize is invalid then the Windows ID will be 0.

See also

id().


@staticmethod
windowsId(PageSizeId) → int

Returns the Windows DMPAPER enum value of the standard pageSizeId.

Not all valid PPD page sizes have a Windows equivalent, in which case 0 will be returned.