@header@
 
 
matplotlib.backends.backend_agg
index
/home/jdhunter/dev/lib64/python2.5/site-packages/matplotlib/backends/backend_agg.py

An agg http://antigrain.com/ backend
 
Features that are implemented
 
 * capstyles and join styles
 * dashes
 * linewidth
 * lines, rectangles, ellipses
 * clipping to a rectangle
 * output to RGBA and PNG
 * alpha blending
 * DPI scaling properly - everything scales properly (dashes, linewidths, etc)
 * draw polygon
 * freetype2 w/ ft2font
 
TODO:
 
  * allow save to file handle
 
  * integrate screen dpi w/ ppi and text

 
Modules
       
matplotlib._png
matplotlib
numpy
os
sys
weakref

 
Classes
       
matplotlib.backend_bases.FigureCanvasBase
FigureCanvasAgg
matplotlib.backend_bases.RendererBase
RendererAgg

 
class FigureCanvasAgg(matplotlib.backend_bases.FigureCanvasBase)
    The canvas the figure renders into.  Calls the draw and print fig
methods, creates the renderers, etc...
 
Public attribute
 
  figure - A Figure instance
 
  Methods defined here:
buffer_rgba(self, x, y)
copy_from_bbox(self, bbox)
draw(self)
Draw the figure using the renderer
get_default_filetype(self)
get_renderer(self)
print_png(self, filename_or_obj, *args, **kwargs)
print_raw(self, filename_or_obj, *args, **kwargs)
print_rgba = print_raw(self, filename_or_obj, *args, **kwargs)
restore_region(self, region)
tostring_argb(self)
tostring_rgb(self)

Methods inherited from matplotlib.backend_bases.FigureCanvasBase:
__init__(self, figure)
blit(self, bbox=None)
blit the canvas in bbox (default entire canvas)
button_press_event(self, x, y, button, guiEvent=None)
Backend derived classes should call this function on any mouse
button press.  x,y are the canvas coords: 0,0 is lower, left.
button and key are as defined in :class:`MouseEvent`.
 
This method will be call all functions connected to the
'button_press_event' with a :class:`MouseEvent` instance.
button_release_event(self, x, y, button, guiEvent=None)
Backend derived classes should call this function on any mouse
button release.
 
*x*
    the canvas coordinates where 0=left
 
*y*
    the canvas coordinates where 0=bottom
 
*guiEvent*
    the native UI event that generated the mpl event
 
 
This method will be call all functions connected to the
'button_release_event' with a :class:`MouseEvent` instance.
draw_cursor(self, event)
Draw a cursor in the event.axes if inaxes is not None.  Use
native GUI drawing for efficiency if possible
draw_event(self, renderer)
This method will be call all functions connected to the
'draw_event' with a :class:`DrawEvent`
draw_idle(self, *args, **kwargs)
:meth:`draw` only if idle; defaults to draw but backends can overrride
flush_events(self)
Flush the GUI events for the figure. Implemented only for
backends with GUIs.
get_supported_filetypes(self)
get_supported_filetypes_grouped(self)
get_width_height(self)
return the figure width and height in points or pixels
(depending on the backend), truncated to integers
idle_event(self, guiEvent=None)
call when GUI is idle
key_press_event(self, key, guiEvent=None)
This method will be call all functions connected to the
'key_press_event' with a :class:`KeyEvent`
key_release_event(self, key, guiEvent=None)
This method will be call all functions connected to the
'key_release_event' with a :class:`KeyEvent`
motion_notify_event(self, x, y, guiEvent=None)
Backend derived classes should call this function on any
motion-notify-event.
 
*x*
    the canvas coordinates where 0=left
 
*y*
    the canvas coordinates where 0=bottom
 
*guiEvent*
    the native UI event that generated the mpl event
 
 
This method will be call all functions connected to the
'motion_notify_event' with a :class:`MouseEvent` instance.
mpl_connect(self, s, func)
Connect event with string *s* to *func*.  The signature of *func* is::
 
  def func(event)
 
where event is a :class:`matplotlib.backend_bases.Event`.  The
following events are recognized
 
- 'button_press_event'
- 'button_release_event'
- 'draw_event'
- 'key_press_event'
- 'key_release_event'
- 'motion_notify_event'
- 'pick_event'
- 'resize_event'
- 'scroll_event'
 
For the location events (button and key press/release), if the
mouse is over the axes, the variable ``event.inaxes`` will be
set to the :class:`~matplotlib.axes.Axes` the event occurs is
over, and additionally, the variables ``event.xdata`` and
``event.ydata`` will be defined.  This is the mouse location
in data coords.  See
:class:`~matplotlib.backend_bases.KeyEvent` and
:class:`~matplotlib.backend_bases.MouseEvent` for more info.
 
Return value is a connection id that can be used with
:meth:`~matplotlib.backend_bases.Event.mpl_disconnect`.
 
Example usage::
 
    def on_press(event):
        print 'you pressed', event.button, event.xdata, event.ydata
 
    cid = canvas.mpl_connect('button_press_event', on_press)
mpl_disconnect(self, cid)
disconnect callback id cid
 
Example usage::
 
    cid = canvas.mpl_connect('button_press_event', on_press)
    #...later
    canvas.mpl_disconnect(cid)
onHilite(self, ev)
Mouse event processor which highlights the artists
under the cursor.  Connect this to the 'motion_notify_event'
using::
 
    canvas.mpl_connect('motion_notify_event',canvas.onHilite)
onRemove(self, ev)
Mouse event processor which removes the top artist
under the cursor.  Connect this to the 'mouse_press_event'
using::
 
    canvas.mpl_connect('mouse_press_event',canvas.onRemove)
pick(self, mouseevent)
pick_event(self, mouseevent, artist, **kwargs)
This method will be called by artists who are picked and will
fire off :class:`PickEvent` callbacks registered listeners
print_bmp = print_raw(self, *args, **kwargs)
print_emf(self, *args, **kwargs)
print_eps(self, *args, **kwargs)
print_figure(self, filename, dpi=None, facecolor='w', edgecolor='w', orientation='portrait', format=None, **kwargs)
Render the figure to hardcopy. Set the figure patch face and edge
colors.  This is useful because some of the GUIs have a gray figure
face color background and you'll probably want to override this on
hardcopy.
 
Arguments are:
 
*filename*
    can also be a file object on image backends
 
*orientation*
    only currently applies to PostScript printing.
 
*dpi*
    the dots per inch to save the figure in; if None, use savefig.dpi
 
*facecolor*
    the facecolor of the figure
 
*edgecolor*
    the edgecolor of the figure
 
*orientation*  '
    landscape' | 'portrait' (not supported on all backends)
 
*format*
    when set, forcibly set the file format to save to
print_pdf(self, *args, **kwargs)
print_ps(self, *args, **kwargs)
print_rgb = print_raw(self, *args, **kwargs)
print_svg(self, *args, **kwargs)
print_svgz(self, *args, **kwargs)
resize(self, w, h)
set the canvas size in pixels
resize_event(self)
This method will be call all functions connected to the
'resize_event' with a :class:`ResizeEvent`
scroll_event(self, x, y, step, guiEvent=None)
Backend derived classes should call this function on any
scroll wheel event.  x,y are the canvas coords: 0,0 is lower,
left.  button and key are as defined in MouseEvent.
 
This method will be call all functions connected to the
'scroll_event' with a :class:`MouseEvent` instance.
set_window_title(self, title)
Set the title text of the window containing the figure.  Note that
this has no effect if there is no window (eg, a PS backend).
start_event_loop(self, timeout)
Start an event loop.  This is used to start a blocking event
loop so that interactive functions, such as ginput and
waitforbuttonpress, can wait for events.  This should not be
confused with the main GUI event loop, which is always running
and has nothing to do with this.
 
This is implemented only for backends with GUIs.
start_event_loop_default(self, timeout=0)
Start an event loop.  This is used to start a blocking event
loop so that interactive functions, such as ginput and
waitforbuttonpress, can wait for events.  This should not be
confused with the main GUI event loop, which is always running
and has nothing to do with this.
 
This function provides default event loop functionality based
on time.sleep that is meant to be used until event loop
functions for each of the GUI backends can be written.  As
such, it throws a deprecated warning.
 
Call signature::
 
    start_event_loop_default(self,timeout=0)
 
This call blocks until a callback function triggers
stop_event_loop() or *timeout* is reached.  If *timeout* is
<=0, never timeout.
stop_event_loop(self)
Stop an event loop.  This is used to stop a blocking event
loop so that interactive functions, such as ginput and
waitforbuttonpress, can wait for events.
 
This is implemented only for backends with GUIs.
stop_event_loop_default(self)
Stop an event loop.  This is used to stop a blocking event
loop so that interactive functions, such as ginput and
waitforbuttonpress, can wait for events.
 
Call signature::
 
stop_event_loop_default(self)
switch_backends(self, FigureCanvasClass)
instantiate an instance of FigureCanvasClass
 
This is used for backend switching, eg, to instantiate a
FigureCanvasPS from a FigureCanvasGTK.  Note, deep copying is
not done, so any changes to one of the instances (eg, setting
figure size or line props), will be reflected in the other

Data and other attributes inherited from matplotlib.backend_bases.FigureCanvasBase:
events = ['resize_event', 'draw_event', 'key_press_event', 'key_release_event', 'button_press_event', 'button_release_event', 'scroll_event', 'motion_notify_event', 'pick_event', 'idle_event']
filetypes = {'emf': 'Enhanced Metafile', 'eps': 'Encapsulated Postscript', 'pdf': 'Portable Document Format', 'png': 'Portable Network Graphics', 'ps': 'Postscript', 'raw': 'Raw RGBA bitmap', 'rgba': 'Raw RGBA bitmap', 'svg': 'Scalable Vector Graphics', 'svgz': 'Scalable Vector Graphics'}

 
class RendererAgg(matplotlib.backend_bases.RendererBase)
    The renderer handles all the drawing primitives using a graphics
context instance that controls the colors/styles
 
  Methods defined here:
__init__(self, width, height, dpi)
buffer_rgba(self, x, y)
clear(self)
draw_mathtext(self, gc, x, y, s, prop, angle)
Draw the math text using matplotlib.mathtext
draw_tex(self, gc, x, y, s, prop, angle)
draw_text(self, gc, x, y, s, prop, angle, ismath)
Render the text
get_canvas_width_height(self)
return the canvas width and height in display coords
get_text_width_height_descent(self, s, prop, ismath)
get the width and height in display coords of the string s
with FontPropertry prop
 
# passing rgb is a little hack to make cacheing in the
# texmanager more efficient.  It is not meant to be used
# outside the backend
option_image_nocomposite(self)
points_to_pixels(self, points)
convert point measures to pixes using dpi and the pixels per
inch of the display
tostring_argb(self)
tostring_rgb(self)

Data and other attributes defined here:
debug = 1
texd = {}

Methods inherited from matplotlib.backend_bases.RendererBase:
close_group(self, s)
Close a grouping element with label *s*
Is only currently used by :mod:`~matplotlib.backends.backend_svg`
draw_image(self, x, y, im, bbox, clippath=None, clippath_trans=None)
Draw the image instance into the current axes;
 
*x*
    is the distance in pixels from the left hand side of the canvas.
 
*y*
    the distance from the origin.  That is, if origin is
    upper, y is the distance from top.  If origin is lower, y
    is the distance from bottom
 
*im*
    the :class:`matplotlib._image.Image` instance
 
*bbox*
    a :class:`matplotlib.transforms.Bbox` instance for clipping, or
    None
draw_markers(self, gc, marker_path, marker_trans, path, trans, rgbFace=None)
Draws a marker at each of the vertices in path.  This includes
all vertices, including control points on curves.  To avoid
that behavior, those vertices should be removed before calling
this function.
 
*gc*
    the :class:`GraphicsContextBase` instance
 
*marker_trans*
    is an affine transform applied to the marker.
 
*trans*
     is an affine transform applied to the path.
 
This provides a fallback implementation of draw_markers that
makes multiple calls to :meth:`draw_path`.  Some backends may
want to override this method in order to draw the marker only
once and reuse it multiple times.
draw_path(self, gc, path, transform, rgbFace=None)
Draws a :class:`~matplotlib.path.Path` instance using the
given affine transform.
draw_path_collection(self, master_transform, cliprect, clippath, clippath_trans, paths, all_transforms, offsets, offsetTrans, facecolors, edgecolors, linewidths, linestyles, antialiaseds)
Draws a collection of paths, selecting drawing properties from
the lists *facecolors*, *edgecolors*, *linewidths*,
*linestyles* and *antialiaseds*. *offsets* is a list of
offsets to apply to each of the paths.  The offsets in
*offsets* are first transformed by *offsetTrans* before
being applied.
 
This provides a fallback implementation of
:meth:`draw_path_collection` that makes multiple calls to
draw_path.  Some backends may want to override this in order
to render each set of path data only once, and then reference
that path multiple times with the different offsets, colors,
styles etc.  The generator methods
:meth:`_iter_collection_raw_paths` and
:meth:`_iter_collection` are provided to help with (and
standardize) the implementation across backends.  It is highly
recommended to use those generators, so that changes to the
behavior of :meth:`draw_path_collection` can be made globally.
draw_quad_mesh(self, master_transform, cliprect, clippath, clippath_trans, meshWidth, meshHeight, coordinates, offsets, offsetTrans, facecolors, antialiased, showedges)
This provides a fallback implementation of
:meth:`draw_quad_mesh` that generates paths and then calls
:meth:`draw_path_collection`.
flipy(self)
Return true if y small numbers are top for renderer Is used
for drawing text (:mod:`matplotlib.text`) and images
(:mod:`matplotlib.image`) only
get_image_magnification(self)
Get the factor by which to magnify images passed to :meth:`draw_image`.
Allows a backend to have images at a different resolution to other
artists.
get_texmanager(self)
return the :class:`matplotlib.texmanager.TexManager` instance
new_gc(self)
Return an instance of a :class:`GraphicsContextBase`
open_group(self, s)
Open a grouping element with label *s*. Is only currently used by
:mod:`~matplotlib.backends.backend_svg`
start_rasterizing(self)
stop_rasterizing(self)
strip_math(self, s)

 
Functions
       
FT2Font(...)
FT2Font
fromarray(...)
fromarray
new_figure_manager(num, *args, **kwargs)
Create a new figure manager instance

 
Data
        LOAD_FORCE_AUTOHINT = 32L
backend_version = 'v2.2'
division = _Feature((2, 2, 0, 'alpha', 2), (3, 0, 0, 'alpha', 0), 8192)
rcParams = {'figure.subplot.right': 0.90000000000000002, 'm...persize': 'letter', 'svg.embed_char_paths': True}
verbose = <matplotlib.Verbose instance at 0x7fe18db42248>
@footer@