X-Git-Url: http://repo.macrolet.net/gitweb/?a=blobdiff_plain;f=gtk%2Fgtk.demo.lisp;h=d0c3645ec4b97c58c593f2c9d225abe945b1956f;hb=c5a046da8c5ca824b266ff48034a860790dc1aa3;hp=14ef3ecb6e476a619b5d51165a55e6d9921e55b8;hpb=313c905391ae6cfdcb15a0a341db2bd0951e489e;p=cl-gtk2.git diff --git a/gtk/gtk.demo.lisp b/gtk/gtk.demo.lisp index 14ef3ec..d0c3645 100644 --- a/gtk/gtk.demo.lisp +++ b/gtk/gtk.demo.lisp @@ -28,7 +28,10 @@ #:test-custom-window #:test-assistant #:test-entry-completion - #:test-ui-markup)) + #:test-ui-markup + #:test-list-store + #:test-tree-store + #:test-gdk)) (in-package :gtk-demo) @@ -51,12 +54,12 @@ (lambda (widget event) (declare (ignore widget event)) (let* ((gdk-window (widget-window window)) - (gc (gdk-gc-new gdk-window)) + (gc (graphics-context-new gdk-window)) (layout (widget-create-pango-layout window (format nil "X: ~F~%Y: ~F" x y)))) - (gdk-draw-layout gdk-window gc 0 0 layout) - (gdk-gc-set-rgb-fg-color gc (make-color :red 65535 :green 0 :blue 0)) + (draw-layout gdk-window gc 0 0 layout) + (setf (graphics-context-rgb-fg-color gc) (make-color :red 65535 :green 0 :blue 0)) (multiple-value-bind (x y) (drawable-get-size gdk-window) - (gdk-draw-line gdk-window gc 0 0 x y))))) + (draw-line gdk-window gc 0 0 x y))))) (g-signal-connect window "configure-event" (lambda (widget event) (declare (ignore widget event)) @@ -638,7 +641,7 @@ (save)) (object-destroy d)))) (cut (&rest args) (declare (ignore args)) - (text-buffer-cut-clipboard (text-view-buffer text-view) (get-clipboard "CLIPBOARD"))) + (text-buffer-cut-clipboard (text-view-buffer text-view) (get-clipboard "CLIPBOARD") t)) (copy (&rest args) (declare (ignore args)) (text-buffer-copy-clipboard (text-view-buffer text-view) (get-clipboard "CLIPBOARD"))) (paste (&rest args) (declare (ignore args)) @@ -959,3 +962,151 @@ (text-buffer-insert (text-view-buffer tv) (entry-text entry)))) (widget-show w))))) + +(defun test-list-store () + "Demonstrates usage of list store" + (within-main-loop + (let-ui (gtk-window + :type :toplevel + :title "GtkListStore" + :default-width 600 + :default-height 400 + :var w + (v-box + (label :label "A GtkListStore") :expand nil + (scrolled-window + :hscrollbar-policy :automatic + :vscrollbar-policy :automatic + (tree-view :var tv)))) + (let ((l (make-instance 'list-store :column-types '("gint" "gchararray")))) + (iter (for i from 0 below 100) + (for n = (random 10000000)) + (for s = (format nil "~R" n)) + (list-store-insert-with-values l i n s)) + (setf (tree-view-model tv) l) + (let ((column (make-instance 'tree-view-column :title "Number" :sort-column-id 0)) + (renderer (make-instance 'cell-renderer-text :text "A text"))) + (tree-view-column-pack-start column renderer) + (tree-view-column-add-attribute column renderer "text" 0) + (tree-view-append-column tv column)) + (let ((column (make-instance 'tree-view-column :title "As string" :sort-column-id 1)) + (renderer (make-instance 'cell-renderer-text :text "A text"))) + (tree-view-column-pack-start column renderer) + (tree-view-column-add-attribute column renderer "text" 1) + (tree-view-append-column tv column)) + (connect-signal tv "row-activated" + (lambda (w path column) + (declare (ignore w column)) + (let* ((iter (tree-model-iter-by-path l path)) + (n (tree-model-value l iter 0)) + (dialog (make-instance 'message-dialog + :title "Clicked" + :text (format nil "Number ~A was clicked" n) + :buttons :ok))) + (dialog-run dialog) + (object-destroy dialog))))) + (widget-show w)))) + +(defun test-tree-store () + "Demonstrates usage of tree store" + (within-main-loop + (let-ui (gtk-window + :type :toplevel + :title "GtkListStore" + :default-width 600 + :default-height 400 + :var w + (v-box + (label :label "A GtkListStore") :expand nil + (scrolled-window + :hscrollbar-policy :automatic + :vscrollbar-policy :automatic + (tree-view :var tv)))) + (let ((l (make-instance 'tree-store :column-types '("gint" "gchararray")))) + (iter (for i from 0 below 100) + (for n = (random 10000000)) + (for s = (format nil "~R" n)) + (for it = (tree-store-insert-with-values l nil i n s)) + (iter (for j from 0 below 10) + (for n2 = (random 10000000)) + (for s2 = (format nil "~R" n2)) + (tree-store-insert-with-values l it j n2 s2))) + (setf (tree-view-model tv) l) + (let ((column (make-instance 'tree-view-column :title "Number" :sort-column-id 0)) + (renderer (make-instance 'cell-renderer-text :text "A text"))) + (tree-view-column-pack-start column renderer) + (tree-view-column-add-attribute column renderer "text" 0) + (tree-view-append-column tv column)) + (let ((column (make-instance 'tree-view-column :title "As string" :sort-column-id 1)) + (renderer (make-instance 'cell-renderer-text :text "A text"))) + (tree-view-column-pack-start column renderer) + (tree-view-column-add-attribute column renderer "text" 1) + (tree-view-append-column tv column)) + (connect-signal tv "row-activated" + (lambda (w path column) + (declare (ignore w column)) + (let* ((iter (tree-model-iter-by-path l path)) + (n (tree-model-value l iter 0)) + (dialog (make-instance 'message-dialog + :title "Clicked" + :text (format nil "Number ~A was clicked" n) + :buttons :ok))) + (dialog-run dialog) + (object-destroy dialog))))) + (widget-show w)))) + +(defun test-gdk-expose (gdk-window) + (let* ((gc (graphics-context-new gdk-window))) + (multiple-value-bind (w h) (drawable-get-size gdk-window) + (setf (graphics-context-rgb-bg-color gc) (make-color :red 0 :green 0 :blue 0)) + (draw-polygon gdk-window gc t (list (make-point :x 0 :y 0) + (make-point :x (truncate w 2) :y 0) + (make-point :x w :y (truncate h 2)) + (make-point :x w :y h) + (make-point :x (truncate w 2) :y h) + (make-point :x 0 :y (truncate h 2)))) + (setf (graphics-context-rgb-fg-color gc) (make-color :red 65535 :green 0 :blue 0)) + (draw-point gdk-window gc 20 10) + (setf (graphics-context-rgb-fg-color gc) (make-color :red 0 :green 65535 :blue 0)) + (draw-points gdk-window gc (list (make-point :x 15 :y 20) (make-point :x 35 :y 40))) + (setf (graphics-context-rgb-fg-color gc) (make-color :red 0 :green 0 :blue 65535)) + (draw-line gdk-window gc 60 30 40 50) + (setf (graphics-context-rgb-fg-color gc) (make-color :red 65535 :green 65535 :blue 0)) + (draw-lines gdk-window gc (list (make-point :x 10 :y 30) (make-point :x 15 :y 40) + (make-point :x 15 :y 50) (make-point :x 10 :y 56))) + (setf (graphics-context-rgb-fg-color gc) (make-color :red 0 :green 65535 :blue 65535)) + (draw-segments gdk-window gc (list (make-segment :x1 35 :y1 35 :x2 55 :y2 35) + (make-segment :x1 65 :y1 35 :x2 43 :y2 17))) + (setf (graphics-context-rgb-fg-color gc) (make-color :red 65535 :green 0 :blue 65535) + (graphics-context-rgb-bg-color gc) (make-color :red 32767 :green 0 :blue 32767)) + (draw-arc gdk-window gc nil 70 30 75 50 (* 64 75) (* 64 200)) + (draw-polygon gdk-window gc nil (list (make-point :x 20 :y 40) + (make-point :x 30 :y 50) + (make-point :x 40 :y 70) + (make-point :x 30 :y 80) + (make-point :x 10 :y 55))) + (setf (graphics-context-rgb-fg-color gc) (make-color :red 16384 :green 16384 :blue 65535)) + (draw-trapezoids gdk-window gc (list (make-trapezoid :y1 50.0d0 :y2 70.0d0 + :x11 30.0d0 :x12 45.0d0 + :x21 70.0d0 :x22 50.0d0)))))) + +(defun test-gdk () + "Test various gdk primitives" + (within-main-loop + (let ((window (make-instance 'gtk-window :type :toplevel :app-paintable t))) + (g-signal-connect window "destroy" (lambda (widget) + (declare (ignore widget)) + (leave-gtk-main))) + (g-signal-connect window "destroy" (lambda (widget) + (declare (ignore widget)) + (leave-gtk-main))) + (g-signal-connect window "expose-event" + (lambda (widget event) + (declare (ignore widget event)) + (test-gdk-expose (widget-window window)))) + (g-signal-connect window "configure-event" + (lambda (widget event) + (declare (ignore widget event)) + (widget-queue-draw window))) + (widget-show window) + (push :pointer-motion-mask (gdk-window-events (widget-window window))))))