File: bitmap.tex

package info (click to toggle)
pyx 0.10-2
  • links: PTS
  • area: main
  • in suites: squeeze
  • size: 2,316 kB
  • ctags: 2,779
  • sloc: python: 16,243; ansic: 131; makefile: 87; sh: 9
file content (140 lines) | stat: -rw-r--r-- 6,725 bytes parent folder | download | duplicates (3)
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
129
130
131
132
133
134
135
136
137
138
139
140
\chapter{Bitmaps}
\section{Introduction}
\PyX{} focuses on the creation of scaleable vector graphics. However,
\PyX{} also allows for the output of bitmap images. Still, the support
for creation and handling of bitmap images is quite limited. On the
other hand the interfaces are built that way, that its trivial to
combine \PyX{} with the ``Python Image Library'', also known as
``PIL''.

The creation of a bitmap can be performed out of some unpacked binary
data by first creating image instances:
\begin{verbatim}
from pyx import *
image_bw = bitmap.image(2, 2, "L", "\0\377\377\0")
image_rgb = bitmap.image(3, 2, "RGB", "\77\77\77\177\177\177\277\277\277"
                                      "\377\0\0\0\377\0\0\0\377")
\end{verbatim}
Now \code{image_bw} is a $2\times2$ grayscale image. The bitmap data
is provided by a string, which contains two black (\code{"\e 0" ==
chr(0)}) and two white (\code{"\e 377" == chr(255)}) pixels. Currently
the values per (colour) channel is fixed to 8 bits. The coloured image
\code{image_rgb} has $3\times2$ pixels containing a row of 3 different
gray values and a row of the three colours red, green, and blue.

The images can then be wrapped into \code{bitmap} instances by:
\begin{verbatim}
bitmap_bw = bitmap.bitmap(0, 1, image_bw, height=0.8)
bitmap_rgb = bitmap.bitmap(0, 0, image_rgb, height=0.8)
\end{verbatim}
When constructing a \code{bitmap} instance you have to specify a
certain position by the first two arguments fixing the bitmaps lower
left corner. Some optional arguments control further properties. Since
in this example there is no information about the dpi-value of the
images, we have to specify at least a \code{width} or a \code{height}
of the bitmap.

The bitmaps are now to be inserted into a canvas:
\begin{verbatim}
c = canvas.canvas()
c.insert(bitmap_bw)
c.insert(bitmap_rgb)
c.writeEPSfile("bitmap")
\end{verbatim}
Figure~\ref{fig:bitmap} shows the resulting output.
\begin{figure}[ht]
\centerline{\includegraphics{bitmap}}
\caption{An introductory bitmap example.}
\label{fig:bitmap}
\end{figure}

\section{Bitmap module}
\declaremodule{}{bitmap}
\modulesynopsis{Bitmap support}

\begin{classdesc}{image}{width, height, mode, data, compressed=None}
  This class is a container for image data. \var{width} and
  \var{height} are the size of the image in pixel. \var{mode} is one
  of \code{\textquotedbl L\textquotedbl}, \code{\textquotedbl
  RGB\textquotedbl} or \code{\textquotedbl CMYK\textquotedbl} for
  grayscale, rgb, or cmyk colours, respectively. \var{data} is the
  bitmap data as a string, where each single character represents a
  colour value with ordinal range \code{0} to \code{255}. Each pixel
  is described by the appropriate number of colour components
  according to \var{mode}. The pixels are listed row by row one after
  the other starting at the upper left corner of the image.

  \var{compressed} might be set to \code{\textquotedbl
  Flate\textquotedbl} or \code{\textquotedbl DCT\textquotedbl} to
  provide already compressed data. Note that those data will be passed
  to PostScript without further checks, \emph{i.e.} this option is for
  experts only.
\end{classdesc}

\begin{classdesc}{jpegimage}{file}
  This class is specialized to read data from a JPEG/JFIF-file.
  \var{file} is either an open file handle (it only has to provide a
  \method{read()} method; the file should be opened in binary mode) or
  a string. In the latter case \class{jpegimage} will try to open a
  file named like \var{file} for reading.

  The contents of the file is checked for some JPEG/JFIF format
  markers in order to identify the size and dpi resolution of the
  image for further usage. These checks will typically fail for
  invalid data. The data are not uncompressed, but directly inserted
  into the output stream (for invalid data the result will be invalid
  PostScript). Thus there is no quality loss by recompressing the data
  as it would occur when recompressing the uncompressed stream with
  the lossy jpeg compression method.
\end{classdesc}

\begin{classdesc}{bitmap}{xpos, ypos, image, width=None, height=None,
  ratio=None, storedata=0, maxstrlen=4093, compressmode="Flate",
  flatecompresslevel=6, dctquality=75, dctoptimize=1,
  dctprogression=0}
  \var{xpos} and \var{ypos} are the position of the lower left corner
  of the image. This position might be modified by some additional
  transformations when inserting the bitmap into a canvas. \var{image}
  is an instance of \class{image} or \class{jpegimage} but it can also
  be an image instance from the ``Python Image Library''.

  \var{width}, \var{height}, and \var{ratio} adjust the size of the
  image. At least \var{width} or \var{height} needs to be given, when
  no dpi information is available from \var{image}.

  \var{storedata} is a flag indicating, that the (still compressed)
  image data should be put into the printers memory instead of writing
  it as a stream into the PostScript file. While this feature consumes
  memory of the PostScript interpreter, it allows for multiple usage
  of the image without including the image data several times in the
  PostScript file.

  \var{maxstrlen} defines a maximal string length when \var{storedata}
  is enabled. Since the data must be kept in the PostScript
  interpreters memory, it is stored in strings. While most
  interpreters do not allow for an arbitrary string length (a common
  limit is 65535 characters), a limit for the string length is set.
  When more data need to be stored, a list of strings will be used.
  Note that lists are also subject to some implementation limits. Since
  a typical value is 65535 entries, in combination a huge amount of
  memory can be used.

  Valid values for \var{compressmode} currently are
  \code{\textquotedbl Flate\textquotedbl} (zlib compression),
  \code{\textquotedbl DCT\textquotedbl} (jpeg compression), or
  \code{None} (disabling the compression). The zlib compression makes
  use of the zlib module as it is part of the standard Python
  distribution. The jpeg compression is available for those
  \var{image} instances only, which support the creation of a
  jpeg-compressed stream, \emph{e.g.} images from the ``Python Image
  Library'' with jpeg support installed. The compression must be
  disabled when the image data is already compressed.

  \var{flatecompresslevel} is a parameter of the zlib compression.
  \var{dctquality}, \var{dctoptimize}, and \var{dctprogression} are
  parameters of the jpeg compression. Note, that the progression
  feature of the jpeg compression should be turned off in order to
  produce valid PostScript. Also the optimization feature is known to
  produce errors on certain printers.
\end{classdesc}