data:image/s3,"s3://crabby-images/abc1f/abc1f35727795ea11c021cd9ab224da614a78d77" alt="Next"
data:image/s3,"s3://crabby-images/3eb9b/3eb9b5063aa2aeb0eebb87e7cc74ef93d1df0221" alt="Prev"
data:image/s3,"s3://crabby-images/24ef5/24ef5fe2ccf743414fcba08ed303ad6737f56a3e" alt="Up"
data:image/s3,"s3://crabby-images/0fa9d/0fa9d5bf823ef811dd363e8b3c8c9ad3ffaaed7b" alt="Top"
data:image/s3,"s3://crabby-images/4c779/4c779b065c92c4639cda0fba048c82986427c7a2" alt="Contents"
5.6.1 Using Flipping Ink
(defun cmd-rubberband ()
(let ((x1 0) ; x1, y1 represents the fix point
(y1 0)
(x2 0) ; x2,y2 represents the point that is changing
(y2 0)
(mouse-button-press nil)
;; press to select pivot
(stream (get-frame-pane *application-frame* 'main)))
(tracking-pointer (stream)
(:pointer-button-press
(event x y )
(setf x1 x y1 y x2 x y2 y)
(draw-line* stream x1 y1 x2 y2
:ink +flipping-ink+)
(setf mouse-button-press t))
(:pointer-motion
(window x y)
(when Mouse-button-press
;;erase
(draw-line* stream x1 y1 x2 y2
:ink +flipping-ink+)
;; draw
(draw-line* stream x1 y1 x y
:ink +flipping-ink+)
(setf x2 x y2 y)))
(:pointer-button-release
(event x y )
(cond
((eq mouse-button-press t)
(return
(list x1 y1 x2 y2))))))))
CommonLisp Interface Manager 2.0 User's Guide - 18 Mar 2005
data:image/s3,"s3://crabby-images/abc1f/abc1f35727795ea11c021cd9ab224da614a78d77" alt="Next"
data:image/s3,"s3://crabby-images/3eb9b/3eb9b5063aa2aeb0eebb87e7cc74ef93d1df0221" alt="Prev"
data:image/s3,"s3://crabby-images/24ef5/24ef5fe2ccf743414fcba08ed303ad6737f56a3e" alt="Up"
data:image/s3,"s3://crabby-images/0fa9d/0fa9d5bf823ef811dd363e8b3c8c9ad3ffaaed7b" alt="Top"
data:image/s3,"s3://crabby-images/4c779/4c779b065c92c4639cda0fba048c82986427c7a2" alt="Contents"