Gtk2HsSource codeContentsIndex
Graphics.UI.Gtk.Misc.DrawingArea
Portabilityportable (depends on GHC)
Stabilityprovisional
Maintainergtk2hs-users@lists.sourceforge.net
Contents
Detail
Class Hierarchy
Types
Constructors
Methods
Description
A widget for custom user interface elements
Synopsis
data DrawingArea
class WidgetClass o => DrawingAreaClass o
castToDrawingArea :: GObjectClass obj => obj -> DrawingArea
toDrawingArea :: DrawingAreaClass o => o -> DrawingArea
drawingAreaNew :: IO DrawingArea
drawingAreaGetDrawWindow :: DrawingArea -> IO DrawWindow
drawingAreaGetSize :: DrawingArea -> IO (Int, Int)
Detail

The DrawingArea widget is used for creating custom user interface elements. It's essentially a blank widget; you can draw on the Drawable returned by drawingAreaGetWindow.

After creating a drawing area, the application may want to connect to:

  • Mouse and button press signals to respond to input from the user. (Use widgetAddEvents to enable events you wish to receive.)
  • The "realize" signal to take any necessary actions when the widget is instantiated on a particular display. (Create GDK resources in response to this signal.)
  • The "configure_event" signal to take any necessary actions when the widget changes size.
  • The "expose_event" signal to handle redrawing the contents of the widget.

Expose events are normally delivered when a drawing area first comes onscreen, or when it's covered by another window and then uncovered (exposed). You can also force an expose event by adding to the "damage region" of the drawing area's window; widgetQueueDrawArea and windowInvalidateRect are equally good ways to do this. You'll then get an expose event for the invalid region.

The available routines for drawing are documented on the GDK Drawing Primitives page. See also pixbufRenderToDrawable for drawing a Pixbuf.

To receive mouse events on a drawing area, you will need to enable them with widgetAddEvents. To receive keyboard events, you will need to set the CanFocus flag on the drawing area, and should probably draw some user-visible indication that the drawing area is focused.

Class Hierarchy
 |  GObject
 |   +----Object
 |         +----Widget
 |               +----DrawingArea
 |                     +----Curve
 
Types
data DrawingArea
show/hide Instances
class WidgetClass o => DrawingAreaClass o
show/hide Instances
castToDrawingArea :: GObjectClass obj => obj -> DrawingArea
toDrawingArea :: DrawingAreaClass o => o -> DrawingArea
Constructors
drawingAreaNew :: IO DrawingArea
Creates a new drawing area.
Methods
drawingAreaGetDrawWindow :: DrawingArea -> IO DrawWindow
Retrieves the Drawable part.
drawingAreaGetSize :: DrawingArea -> IO (Int, Int)

Returns the current size.

  • This information may be out of date if the user is resizing the window.
Produced by Haddock version 0.7