Geometry and colors¶
Geometry¶
Transformations¶
-
class
djvu.decode.
AffineTransform
((x0, y0, w0, h0), (x1, y1, w1, h1))¶ The object represents an affine coordinate transformation that maps points from rectangle (x0, y0, w0, h0) to rectangle (x1, y1, w1, h1).
-
rotate
(n)¶ Rotate the output rectangle counter-clockwise by n degrees.
-
apply
((x, y))¶ -
apply
((x, y, w, h)) Apply the coordinate transform to a point or a rectangle.
-
inverse
((x, y))¶ -
inverse
((x, y, w, h)) Apply the inverse coordinate transform to a point or a rectangle.
-
mirror_x
()¶ Reverse the X coordinates of the output rectangle.
-
mirror_y
()¶ Reverse the Y coordinates of the output rectangle.
-
Pixel formats¶
-
class
djvu.decode.
PixelFormat
¶ Abstract base for all pixel formats.
Inheritance diagram:
-
rows_top_to_bottom
¶ Flag indicating whether the rows in the pixel buffer are stored starting from the top or the bottom of the image.
Default ordering starts from the bottom of the image. This is the opposite of the X11 convention.
-
y_top_to_bottom
¶ Flag indicating whether the y coordinates in the drawing area are oriented from bottom to top, or from top to bottom.
The default is bottom to top, similar to PostScript. This is the opposite of the X11 convention.
-
bpp
¶ Return the depth of the image, in bits per pixel.
-
dither_bpp
¶ The final depth of the image on the screen. This is used to decide which dithering algorithm should be used.
The default is usually appropriate.
-
gamma
¶ Gamma of the display for which the pixels are intended. This will be combined with the gamma stored in DjVu documents in order to compute a suitable color correction.
The default value is 2.2.
-
-
class
djvu.decode.
PixelFormatRgb
([byteorder='RGB'])¶ 24-bit pixel format, with:
- RGB (byteorder =
'RGB'
) or - BGR (byteorder =
'BGR'
)
byte order.
- RGB (byteorder =
-
class
djvu.decode.
PixelFormatRgbMask
(red_mask, green_mask, blue_mask, [xor_value, ]bpp=16)¶ -
class
djvu.decode.
PixelFormatRgbMask
(red_mask, green_mask, blue_mask, [xor_value, ]bpp=32) red_mask, green_mask and blue_mask are bit masks for color components for each pixel. The resulting color is then xored with the xor_value.
For example,
PixelFormatRgbMask(0xf800, 0x07e0, 0x001f, bpp=16)
is a highcolor format with:- 5 (most significant) bits for red,
- 6 bits for green,
- 5 (least significant) bits for blue.
-
class
djvu.decode.
PixelFormatGrey
¶ 8-bit, grey pixel format.
-
class
djvu.decode.
PixelFormatPalette
(palette)¶ Palette pixel format.
palette must be a dictionary which contains 216 (6 x 6 x 6) entries of a web color cube, such that:
- for each key
(r, g, b)
:r in range(0, 6)
,g in range(0, 6)
etc.; - for each value
v
:v in range(0, 0x100)
.
- for each key
-
class
djvu.decode.
PixelFormatPackedBits
(endianness)¶ Bitonal, 1 bit per pixel format with:
- most significant bits on the left (endianness =
'>'
) or - least significant bits on the left (endianness =
'<'
).
- most significant bits on the left (endianness =
Render modes¶
-
djvu.decode.
RENDER_COLOR
¶ Render color page or stencil.
-
djvu.decode.
RENDER_BLACK
¶ Render stencil or color page.
-
djvu.decode.
RENDER_COLOR_ONLY
¶ Render color page or fail.
-
djvu.decode.
RENDER_MASK_ONLY
¶ Render stencil or fail.
-
djvu.decode.
RENDER_BACKGROUND
¶ Render color background layer.
-
djvu.decode.
RENDER_FOREGROUND
¶ Render color foreground layer.