scx/scheme/xlib/graphics.scm

141 lines
4.3 KiB
Scheme

;; Copyright (c) 2001-2003 by Norbert Frese, David Frese
;; *** copy areas ****************************************************
(import-lambda-definition copy-area
(display src dest gc src-x src-y width height dest-x dest-y)
"scx_Copy_Area")
(import-lambda-definition copy-plane
(display src dest gc src-x src-y width height dest-x dest-y plane)
"scx_Copy_Plane")
;; *** draw points ***************************************************
(define-enumerated-type coord-mode :coord-mode
coord-mode? coord-modes coord-mode-name coord-mode-index
(origin previous))
(define-exported-binding "scx-coord-mode" :coord-mode)
(import-lambda-definition draw-point (display drawable gc x y)
"scx_Draw_Point")
;; points has to be a list of (x . y) pairs
(import-lambda-definition draw-points (display drawable gc points mode)
"scx_Draw_Points")
;; *** draw lines, polygons ******************************************
(import-lambda-definition draw-line (display drawable gc x1 y1 x2 y2)
"scx_Draw_Line")
;; points has to be a list of (x . y) pairs
(import-lambda-definition draw-lines (display drawable gc points mode)
"scx_Draw_Lines")
(import-lambda-definition draw-segments (display drawable gc segments)
"scx_Draw_Segments")
(define-record-type segment :segment
(make-segment x1 y1 x2 y2)
segment?
(x1 segment:x1 set-segment:x1!)
(y1 segment:y1 set-segment:y1!)
(x2 segment:x2 set-segment:x2!)
(y2 segment:y2 set-segment:y2!))
(define-exported-binding "scx-segment" :segment)
;; *** draw rectangles ***********************************************
(import-lambda-definition draw-rectangle
(display drawable gc x y width height)
"scx_Draw_Rectangle")
(define-record-type rectangle :rectangle
(make-rectangle x y width height)
rectangle?
(x rectangle:x set-rectangle:x!)
(y rectangle:y set-rectangle:y!)
(width rectangle:width set-rectangle:width!)
(height rectangle:height set-rectangle:height!))
(define-record-discloser :rectangle
(lambda (r)
`(Rectangle ,(rectangle:x r) ,(rectangle:y r)
,(rectangle:width r) ,(rectangle:height r))))
(define-exported-binding "scx-rectangle" :rectangle)
(import-lambda-definition draw-rectangles (display drawable gc rectangles)
"scx_Draw_Rectangles")
;; *** draw arcs *****************************************************
(import-lambda-definition draw-arc
(display drawable gc x y width height angle1 angle2)
"scx_Draw_Arc")
(define-record-type arc :arc
(make-arc x y width height angle1 angle2)
arc?
(x arc:x set-arc:x!)
(y arc:y set-arc:y!)
(width arc:width set-arc:width!)
(height arc:height set-arc:height!)
(angle1 arc:angle1 set-arc:angle1!)
(angle2 arc:angle2 set-arc:angle2!))
(define-exported-binding "scx-arc" :arc)
(import-lambda-definition draw-arcs (display drawable gc arcs)
"scx_Draw_Arcs")
;; *** fill rectangles, polygons, or arcs ****************************
(import-lambda-definition fill-rectangle
(display drawable gc x y width height)
"scx_Fill_Rectangle")
(import-lambda-definition fill-rectangles (display drawable gc rectangles)
"scx_Fill_Rectangles")
(define-enumerated-type polygon-shape :polygon-shape
polygon-shape? polygon-shapes polygon-shape-name polygon-shape-index
(complex non-convex convex))
(define-exported-binding "scx-polygon-shape" :polygon-shape)
(import-lambda-definition fill-polygon (display drawable gc points shape mode)
"scx_Fill_Polygon")
(import-lambda-definition fill-arc
(display drawable gc x y width height angle1 angle2)
"scx_Fill_Arc")
;; arcs has to be a list of (x y width height angle1 angle2) lists.
(import-lambda-definition fill-arcs (display drawable gc arcs)
"scx_Fill_Arcs")
;; *** auxiliary functions *******************************************
(define (bounds x1 y1 x2 y2)
(make-rectangle x1 y1 (- x2 x1) (- y2 y1)))
(define (grow-rectangle r dw dh . maybe-centric?)
(if (or (null? maybe-centric?) (not (car maybe-centric?)))
(make-rectangle (rectangle:x r) (rectangle:y r)
(+ (rectangle:width r) dw)
(+ (rectangle:height r) dh))
(make-rectangle (- (rectangle:x r) (quotient dw 2))
(- (rectangle:y r) (quotient dh 2))
(+ (rectangle:width r) dw)
(+ (rectangle:height r) dh))))
(define (move/resize-rectangle r dx dy dw dh)
(make-rectangle (+ (rectangle:x r) dx)
(+ (rectangle:y r) dy)
(+ (rectangle:width r) dw)
(+ (rectangle:height r) dh)))