Skip to content


Subversion checkout URL

You can clone with
Download ZIP
Branch: master
Fetching contributors…

Cannot retrieve contributors at this time

99 lines (82 sloc) 3.63 KB
from __future__ import with_statement
from kiva.constants import FILL
# Relative imports
from abstract_window import AbstractWindow
from base import bounding_coordinates, coordinates_to_bounds
from kiva_graphics_context import GraphicsContext
class EnableGCMixin(object):
Subclass of Kiva GraphicsContext that provides a few more utility methods.
Most importantly, it provides a pointer back to the window that this
GC is being drawn to.
This will eventually be deprecated as the follow methods are folded into
Kiva or their use is discontinuted in Enable.
# The window that this GraphicsContext is being drawn to. It is OK to leave
# this as None if the graphics context is used as a backbuffer; however, in
# such cases, it is more appropriate to use a GC from Kiva directly as opposed
# to using the Enable one, as some draw methods may need to parent controls
# or dialogs from the Window.
window = None #Instance(AbstractWindow)
def __init__(self, *args, **kwargs):
if kwargs.has_key("window"):
self.window = kwargs.pop("window")
super(EnableGCMixin, self).__init__(*args, **kwargs)
def clip_to_rect(self, x, y, width, height):
if getattr(self, "corner_pixel_origin", True):
super(EnableGCMixin, self).clip_to_rect(x-0.5, y-0.5, width+1, height+1)
super(EnableGCMixin, self).clip_to_rect(x, y, width, height)
def clear_clip(self, color, coordinates):
"Clip and clear a Kiva graphics context to a specified area and color"
bounds = coordinates_to_bounds(coordinates)
self.draw_rect(bounds, FILL)
def clear_clip_region(self, color, update_region):
"Clip and clear a Kiva graphics context to a specified region and color"
bounds = coordinates_to_bounds(bounding_coordinates(update_region))
for coordinates in update_region:
bounds = coordinates_to_bounds(coordinates)
def alpha(self, alpha):
raise NotImplementedError, \
"The alpha() method is not compatible with DisplayPDF; use clear() instead."
def stretch_draw(self, image, x, y, dx, dy):
"Draws an image 'stretched' to fit a specified area"
idx = image.width()
idy = image.height()
with self:
self.clip_to_rect(x, y, dx, dy)
cx, cy, cdx, cdy = x, y, dx, dy
yt = cy + cdy
xr = cx + cdx
x += (int(cx - x) / idx) * idx
y += (int(cy - y) / idy) * idy
while y < yt:
x0 = x
while x0 < xr:
self.draw_image(image,(x0, y, idx, idy))
x0 += idx
y += idy
# Define a GraphicsContextEnable that subclasses whatever the Kiva backend's
# GraphicsContext is.
class GraphicsContextEnable(EnableGCMixin, GraphicsContext):
# Define an ImageGraphicsContextEnable that is guaranteed to be a subclass of
# an ImageGraphicsContext, regardless of the actual Kiva backend. If the kiva
# backend is already the GraphicsContextImage, then just create an alias.
from kiva.image import GraphicsContext as GraphicsContextImage
if isinstance(GraphicsContext, GraphicsContextImage):
ImageGraphicsContextEnable = GraphicsContextEnable
class ImageGraphicsContextEnable(EnableGCMixin, GraphicsContextImage):
Jump to Line
Something went wrong with that request. Please try again.