A window is the most generic window class of XPCE. Drawings are often displayed on a picture, which is a window with scrollbars. The drawing area of a window is two-dimensional and infinitely large (both positive and negative). The query below creates a picture and opens it on the screen.
1 ?- new(@p, picture('Demo Picture')),
     send(@p, open).
The following queries draw various primitive graphicals on this picture.
2 ?- send(@p, display,
          new(@bo, box(100,100))).
3 ?- send(@p, display,
          new(@ci, circle(50)), point(25,25)).
4 ?- send(@p, display,
          new(@bm, bitmap('32x32/books.xpm')), point(100,100)).
5 ?- send(@p, display,
          new(@tx, text('Hello')), point(120, 50)).
6 ?- send(@p, display,
          new(@bz, bezier_curve(point(50,100),
                                point(120,132),
                                point(50, 160),
                                point(120, 200)))).
XPCE's graphics infrastructure automatically takes care of the necessary repaint operations when graphical objects are manipulated. Try the queries below to appreciate this. The result is shown in figure 12.
7 ?- send(@bo, radius, 10). 8 ?- send(@ci, fill_pattern, colour(orange)). 9 ?- send(@tx, font, font(times, bold, 18)). 10 ?- send(@bz, arrows, both).
 
| Figure 12 : Example graphics | 
XPCE avoids unnecessary repaint operations and expensive computations involved in updating the screen. The screen is only updated after all available input has been processed or on an explicit request to update it. The following code illustrates this. Running ?- square_to_circle(@bo). will show the box immediately as a circle without showing any of the intermediate results.
:- require([between/3, forall/2]).
square_to_circle(Box) :-
        get(Box, height, H),
        MaxRadius is H // 2,
        forall(between(0, MaxRadius, Radius),
               send(Box, radius, Radius)).
To get the intended animating behaviour, use `graphical->flush' 
to explicitly force redraw right now:
:- require([between/3, forall/2]).
square_to_circle(Box) :-
        get(Box, height, H),
        MaxRadius is H // 2,
        forall(between(0, MaxRadius, Radius),
               (   send(Box, radius, Radius),
                   send(Box, flush)
               )).
An overview of the available primitive graphical classes is most easily obtained using the Class Hierarchy tool described in section 3.3.4. Table table 2 provides an overview of the primitive graphicals.
| arrow | Arrow-head. Normally used implicitly by class line. | 
| bezier | Bezier curve. Both quadratic and cubic Biezer curves are supported. | 
| bitmap | Visualisation of an image. Both monochrome and full-colour images are supported. Images can have shape. See section 10.10. | 
| pixmap | Subclass of bitmap only for coloured images. | 
| box | Rectangle. Can be rounded and filled. | 
| circle | Special case of ellipse. | 
| ellipse | Elliptical shape. May be filled. | 
| arc | Part of an ellipse. Can have arrows. Can show as pie-slice. | 
| line | Straight line segment. Can have arrows. | 
| path | Poly-line through multiple points. Can have arrows. Can be smooth. | 
| text | Visualisation of a string in some font. Can have various attributes, can be clipped, formatted, etc. | 
| Table 2 : Primitive graphical objects |