/usr/lib/gcl-2.6.7-prof/gcl-tk/demos/mkItems.lisp is in gcl 2.6.7-98.
This file is owned by root:root, with mode 0o644.
The actual contents of the file can be viewed below.
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 147 148 149 150 151 152 153 154 155 156 157 158 159 160 161 162 163 164 165 166 167 168 169 170 171 172 173 174 175 176 177 178 179 180 181 182 183 184 185 186 187 188 189 190 191 192 193 194 195 196 197 198 199 200 201 202 203 204 205 206 207 208 209 210 211 212 213 214 215 216 217 218 219 220 221 222 223 224 225 226 227 228 229 230 231 232 233 234 235 236 237 238 239 240 241 242 243 244 245 246 247 248 249 250 251 252 253 254 255 256 257 258 259 260 261 262 263 264 265 266 267 268 269 270 271 272 273 274 275 276 277 278 279 280 281 282 283 284 285 286 287 288 289 290 291 292 293 294 295 296 297 298 299 300 301 302 303 304 305 306 307 308 309 310 311 312 313 314 315 316 317 318 319 320 321 322 323 324 325 326 327 328 329 330 331 332 333 334 335 336 337 338 339 340 341 342 343 344 345 346 347 348 349 350 351 352 353 354 355 356 357 358 | ;;# mkItems w
;;
;; Create a top-level window containing a canvas that displays the
;; various item types and allows them to be selected and moved. This
;; demo can be used to test out the point-hit and rectangle-hit code
;; for items.
;;
;; Arguments:
;; w - Name to use for new top-level window.
(in-package "TK")
(defvar *color-display* nil)
(defun mkItems (&optional (w '.citems))
(declare (special c tk_library))
(if (winfo :exists w :return 'boolean)
(destroy w))
(if (winfo :exists w :return 'boolean) (destroy w))
(toplevel w)
(dpos w)
(wm :title w "Canvas Item Demonstration")
(wm :iconname w "Items")
(wm :minsize w 100 100)
(setq c (conc w '.frame2.c))
(message (conc w '.msg) :font :Adobe-Times-Medium-R-Normal--*-180-* :width "13c"
:bd 2 :relief "raised" :text #u"This window contains a canvas widget with examples of the various kinds of items supported by canvases. The following operations are supported:\n Button-1 drag:\tmoves item under pointer.\n Button-2 drag:\trepositions view.\n Button-3 drag:\tstrokes out area.\n Ctrl+f:\t\tprints items under area.")
(frame (conc w '.frame2) :relief "raised" :bd 2)
(button (conc w '.ok) :text "OK" :command (tk-conc "destroy " w))
(pack (conc w '.msg) :side "top" :fill "x")
(pack (conc w '.frame2) :side "top" :fill "both" :expand "yes")
(pack (conc w '.ok) :side "bottom" :pady 5 :anchor "center")
(scrollbar (conc w '.frame2.vscroll) :relief "sunken" :command (tk-conc c " yview"))
(scrollbar (conc w '.frame2.hscroll) :orient "horiz" :relief "sunken" :command (tk-conc c " xview"))
(canvas c :scrollregion "0c 0c 30c 24c" :width "15c" :height "10c"
:relief "sunken" :borderwidth 2
:xscrollcommand (tk-conc w ".frame2.hscroll set") :yscrollcommand (tk-conc w ".frame2.vscroll set"))
(pack (conc w '.frame2.hscroll) :side "bottom" :fill "x")
(pack (conc w '.frame2.vscroll) :side "right" :fill "y")
(pack c :in (conc w '.frame2) :expand "yes" :fill "both")
;; Display a 3x3 rectangular grid.
(funcall c :create "rect" "0c" "0c" "30c" "24c" :width 2)
(funcall c :create "line" "0c" "8c" "30c" "8c" :width 2)
(funcall c :create "line" "0c" "16c" "30c" "16c" :width 2)
(funcall c :create "line" "10c" "0c" "10c" "24c" :width 2)
(funcall c :create "line" "20c" "0c" "20c" "24c" :width 2)
(setq font1 :Adobe-Helvetica-Medium-R-Normal--*-120-*)
(setq font2 :Adobe-Helvetica-Bold-R-Normal--*-240-*)
(if (> (winfo :depth c :return 'number) 1)
(progn
(setq *color-display* t)
(setq blue "DeepSkyBlue3")
(setq red "red")
(setq bisque "bisque3")
(setq green "SeaGreen3"))
(progn
(setq blue "black")
(setq red "black")
(setq bisque "black")
(setq green "black")))
;; Set up demos within each of the areas of the grid.
(funcall c :create "text" "5c" ".2c" :text "Lines" :anchor "n")
(funcall c :create "line" "1c" "1c" "3c" "1c" "1c" "4c" "3c" "4c" :width "2m" :fill blue
:cap "butt" :join "miter" :tags "item")
(funcall c :create "line" "4.67c" "1c" "4.67c" "4c" :arrow "last" :tags "item")
(funcall c :create "line" "6.33c" "1c" "6.33c" "4c" :arrow "both" :tags "item")
(funcall c :create "line"
"5c" "6c" "9c" "6c" "9c" "1c" "8c" "1c" "8c" "4.8c" "8.8c" "4.8c" "8.8c" "1.2c"
"8.2c" "1.2c" "8.2c" "4.6c" "8.6c" "4.6c" "8.6c" "1.4c" "8.4c" "1.4c" "8.4c" "4.4c" :fill "red"
:width 3 :tags "item")
(funcall c :create "line" "1c" "5c" "7c" "5c" "7c" "7c" "9c" "7c"
:width ".5c"
:stipple "@" : *tk-library* : "/demos/images/gray25.bmp"
:arrow "both" :arrowshape "15 15 7" :tags "item")
(funcall c :create "line" "1c" "7c" "1.75c" "5.8c" "2.5c" "7c" "3.25c"
"5.8c" "4c" "7c" :width ".5c"
:cap "round" :join "round" :tags "item")
(funcall c :create "text" "15c" ".2c" :text "Curves (smoothed :lines)" :anchor "n")
(funcall c :create "line" "11c" "4c" "11.5c" "1c" "13.5c" "1c" "14c"
"4c" :smooth "on"
:fill blue :tags "item")
(funcall c :create "line" "15.5c" "1c" "19.5c" "1.5c" "15.5c" "4.5c"
"19.5c" "4c" :smooth "on"
:arrow "both" :width 3 :tags "item")
(funcall c :create "line" "12c" "6c" "13.5c" "4.5c" "16.5c" "7.5c" "18c" "6c"
"16.5c" "4.5c" "13.5c" "7.5c" "12c" "6c" :smooth "on" :width "3m" :cap "round"
:stipple "@" : *tk-library* : "/demos/images/gray25.bmp" :fill red :tags "item")
(funcall c :create "text" '25c ".2c" :text "Polygons" :anchor "n")
(funcall c :create "polygon" "21c" "1.0c" "22.5c" "1.75c" "24c" "1.0c"
"23.25c" "2.5c"
"24c" "4.0c" "22.5c" "3.25c" "21c" "4.0c" "21.75c" "2.5c"
:fill green :tags
"item")
(funcall c :create "polygon" "25c" "4c" "25c" "4c" "25c" "1c" "26c" "1c" "27c" "4c" "28c" "1c"
"29c" "1c" "29c" "4c" "29c" "4c" :fill red :smooth "on" :tags "item")
(funcall c :create "polygon" "22c" "4.5c" "25c" "4.5c" "25c" "6.75c" "28c" "6.75c"
"28c" "5.25c" "24c" "5.25c" "24c" "6.0c" "26c" "6c" "26c" "7.5c" "22c" "7.5c"
:stipple "@" : *tk-library* : "/demos/images/gray25.bmp" :tags "item")
(funcall c :create "text" "5c" "8.2c" :text "Rectangles" :anchor "n")
(funcall c :create "rectangle" "1c" "9.5c" "4c" "12.5c" :outline red :width "3m" :tags "item")
(funcall c :create "rectangle" "0.5c" "13.5c" "4.5c" "15.5c" :fill green :tags "item")
(funcall c :create "rectangle" "6c" "10c" "9c" "15c" :outline ""
:stipple "@" : *tk-library* : "/demos/images/gray25.bmp" :fill blue :tags "item")
(funcall c :create "text" "15c" "8.2c" :text "Ovals" :anchor "n")
(funcall c :create "oval" "11c" "9.5c" "14c" "12.5c" :outline red :width "3m" :tags "item")
(funcall c :create "oval" "10.5c" "13.5c" "14.5c" "15.5c" :fill green :tags "item")
(funcall c :create "oval" "16c" "10c" "19c" "15c" :outline ""
:stipple "@" : *tk-library* : "/demos/images/gray25.bmp" :fill blue :tags "item")
(funcall c :create "text" "25c" "8.2c" :text "Text" :anchor "n")
(funcall c :create "rectangle" "22.4c" "8.9c" "22.6c" "9.1c")
(funcall c :create "text" "22.5c" "9c" :anchor "n" :font font1 :width "4c"
:text "A short string of text, word-wrapped, justified left, and anchored north (at :the top). The rectangles show the anchor points for each piece of text." :tags "item")
(funcall c :create "rectangle" "25.4c" "10.9c" "25.6c" "11.1c")
(funcall c :create "text" "25.5c" "11c" :anchor "w" :font font1 :fill blue
:text #u"Several lines,\n each centered\nindividually,\nand all anchored\nat the left edge."
:justify "center" :tags "item")
(funcall c :create "rectangle" "24.9c" "13.9c" "25.1c" "14.1c")
(funcall c :create "text" "25c" "14c" :font font2 :anchor "c" :fill red
:stipple "@" : *tk-library* : "/demos/images/gray25.bmp"
:text "Stippled characters" :tags "item")
(funcall c :create "text" "5c" "16.2c" :text "Arcs" :anchor "n")
(funcall c :create "arc" "0.5c" "17c" "7c" "20c" :fill green :outline "black"
:start 45 :extent 270 :style "pieslice" :tags "item")
(funcall c :create "arc" "6.5c" "17c" "9.5c" "20c" :width "4m" :style "arc"
:fill blue :start -135 :extent 270
:stipple "@" : *tk-library* : "/demos/images/gray25.bmp" :tags "item")
(funcall c :create "arc" "0.5c" "20c" "9.5c" "24c" :width "4m" :style "pieslice"
:fill "" :outline red :start 225 :extent -90 :tags "item")
(funcall c :create "arc" "5.5c" "20.5c" "9.5c" "23.5c" :width "4m" :style "chord"
:fill blue :outline "" :start 45 :extent 270 :tags "item")
(funcall c :create "text" "15c" "16.2c" :text "Bitmaps" :anchor "n")
(funcall c :create "bitmap" "13c" "20c" :bitmap "@" : *tk-library* : "/demos/images/face.bmp" :tags "item")
(funcall c :create "bitmap" "17c" "18.5c"
:bitmap "@" : *tk-library* : "/demos/images/noletter.bmp" :tags "item")
(funcall c :create "bitmap" "17c" "21.5c"
:bitmap "@" : *tk-library* : "/demos/images/letters.bmp" :tags "item")
(funcall c :create "text" "25c" "16.2c" :text "Windows" :anchor "n")
(button (conc c '.button) :text "Press Me" :command `(butPress ',c ',red))
(funcall c :create "window" "21c" "18c" :window (conc c '.button) :anchor "nw" :tags "item")
(bind "Entry" "<Control-KeyPress>" '(emacs-move %W %A ))
(bind "Entry" "<Control-Key-d>" "")
(entry (conc c '.entry) :width 20 :relief "sunken")
(funcall (conc c '.entry) :insert "end" "Edit this text")
(funcall c :create "window" "21c" "21c" :window (conc c '.entry) :anchor "nw" :tags "item")
(scale (conc c '.scale) :from 0 :to 100 :length "6c" :sliderlength '.4c
:width ".5c" :tickinterval 0)
(funcall c :create "window" "28.5c" "17.5c" :window (conc c '.scale) :anchor "n" :tags "item")
(funcall c :create "text" "21c" "17.9c" :text "Button" :anchor "sw")
(funcall c :create "text" "21c" "20.9c" :text "Entry" :anchor "sw")
(funcall c :create "text" "28.5c" "17.4c" :text "Scale" :anchor "s")
;; Set up event bindings for canvas:
(funcall c :bind "item" "<Any-Enter>" `(itemEnter ',c))
(funcall c :bind "item" "<Any-Leave>" `(itemLeave ',c))
(bind c "<2>" (tk-conc c " scan mark %x %y"))
(bind c "<B2-Motion>" (tk-conc c " scan dragto %x %y"))
(bind c "<3>" `(itemMark ',c |%x| |%y|))
(bind c "<B3-Motion>" `(itemStroke ',c |%x| |%y|))
(bind c "<Control-f>" `(itemsUnderArea ',c))
(bind c "<1>" `(itemStartDrag ',c |%x| |%y|))
(bind c "<B1-Motion>" `(itemDrag ',c |%x| |%y|))
(bind w "<Any-Enter>" `(focus ',c))
)
;; Utility procedures for highlighting the item under the pointer:
(defvar *restorecmd* nil)
(defun itemEnter (c &aux type bg)
; (global :*restorecmd*)
(let ((current (funcall c :find "withtag" "current" :return 'string)))
(if (equal current "") (return-from itementer nil))
(itemleave nil)
(if (not *color-display*)
(progn
(itemLeave nil)
(return-from itementer nil)))
(setq type (funcall c :type current :return 'string))
(if (equal type "window")
(progn
(itemLeave nil)
(return-from itemEnter nil)))
(if (equal type "bitmap")
(progn
(setq bg (nth 4
(funcall c :itemconf current :background
:return 'list-strings)))
(push `(,c :itemconfig ',current :background ',bg) *restorecmd*)
(funcall c :itemconfig current :background "SteelBlue2")
(return-from itemEnter nil)))
(setq fill (nth 4 (funcall c :itemconfig current :fill
:return 'list-strings)))
(if (or (member type '("rectangle" "oval" "arg") :test 'equal)
(equal fill ""))
(progn
(setq outline (nth 4 (funcall c :itemconfig current :outline :return 'list-strings)))
(push `(,c :itemconfig ',current :outline ',outline) *restorecmd*)
(funcall c :itemconfig current :outline "SteelBlue2"))
(progn
(push `(,c :itemconfig ',current :fill ,fill) *restorecmd*)
(funcall c :itemconfig current :fill "SteelBlue2")))
)
)
(defun itemLeave (c)
; (global :*restorecmd*)
(let ((tem *restorecmd*))
(setq *restorecmd* nil)
(dolist (v tem)
(eval v))))
;; Utility procedures for stroking out a rectangle and printing what's
;; underneath the rectangle's area.
(defun itemMark (c x y)
; (global :areaX1 areaY1)
(setq areaX1 (funcall c :canvasx x :return 'string))
(setq areaY1 (funcall c :canvasy y :return 'string))
(funcall c :delete "area")
)
(defun itemStroke (c x y )
(declare (special areaX1 areaY1 areaX2 areaY2))
(or *recursive*
(let ((*recursive* t))
(setq x (funcall c :canvasx x :return 'string))
(setq y (funcall c :canvasy y :return 'string))
(progn
(setq areaX2 x)
(setq areaY2 y)
;; this next return 'stringis simply for TIMING!!!
;; to make it wait for the result before going into subsequent!!
(funcall c :delete "area" :return 'string)
(funcall c :addtag "area" "withtag"
(funcall c :create "rect" areaX1 areaY1 x y
:outline "black" :return 'string))
))))
(defun itemsUnderArea (c)
; (global :areaX1 areaY1 areaX2 areaY2)
(setq area (funcall c :find "withtag" "area" :return 'string))
(setq me c)
(setq items "")
(dolist (i
(funcall c :find "enclosed" areaX1 areaY1 areaX2 areaY2
:return 'list-strings))
(if (search "item" (funcall c :gettags i :return 'string))
(setq items (tk-conc items " " i))))
(print (tk-conc "Items enclosed by area: " items))
(setq items "")
(dolist (i
(funcall c :find "overlapping" areaX1 areaY1 areaX2 areaY2
:return 'list-strings))
(if (search "item" (funcall c :gettags i :return 'string))
(setq items (tk-conc items " " i))))
(print (tk-conc "Items overlapping area: " items))
(terpri)
(force-output)
)
(setq areaX1 0)
(setq areaY1 0)
(setq areaX2 0)
(setq areaY2 0)
;; Utility procedures to support dragging of items.
(defvar *lastX* 0)
(defvar *lastY* 0)
(defun itemStartDrag (c x y)
; (global :*lastX* *lastY*)
(setq *lastX* (funcall c :canvasx x :return 'number))
(setq *lastY* (funcall c :canvasy y :return 'number))
)
(defun itemDrag (c x y)
; (global :*lastX* *lastY*)
(setq x (funcall c :canvasx x :return 'number))
(setq y (funcall c :canvasy y :return 'number))
(funcall c :move "current" (- x *lastX*) (- y *lastY*))
(setq *lastX* x)
(setq *lastY* y)
)
(defvar *recursive* nil)
(defun itemDrag (c x y)
; (global :*lastX* *lastY*)
(cond (*recursive* )
(t (let ((*recursive* t))
(setq x (funcall c :canvasx x :return 'number))
(setq y (funcall c :canvasy y :return 'number))
(funcall c :move "current" (- x *lastX*) (- y *lastY*))
(setq *lastX* x)
(setq *lastY* y)))))
;; Procedure that's invoked when the button embedded in the "canvas"
;; is invoked.
(defun butPress (w color)
(setq i (funcall w :create "text" "25c" "18.1c" :text "Ouch!!"
:fill color :anchor "n" :return 'string))
(after 500 (tk-conc w " delete " i))
)
(defvar *last-kill* "")
;(bind ".citems.frame2.c.entry" "<Control-KeyPress>" '(emacs-move %W %A ))
(defun emacs-move (a key)
(let* ((win a)
;; if this window is from tcl it is not yet a lisp function.
;; steal it... build it into coerce-result...
(foo (or (fboundp win) (setf (symbol-function win)
(make-widget-instance win nil))))
(pos (funcall win :index "insert" :return 'number))
char
new)
(setq new
(case (setq char (aref key 0))
(#\^B (max 0 (- pos 1)))
(#\^F (max 0 (+ pos 1)))
(#\^A 0)
(#\^E "end")))
; (print (list a char key))
(cond (new
(funcall win :icursor new))
((eql char #\^D)
(funcall win :delete pos ))
((or (eql char #\^K)
(eql char #\v))
(setq *last-kill* (subseq (funcall win :get :return 'string) pos))
(funcall win :delete pos "end" ))
((eql char #\^Y)
(funcall win :insert pos *last-kill*))
(t (funcall win :insert pos key)))))
|