123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175 |
- # ruler.tcl --
- #
- # This demonstration script creates a canvas widget that displays a ruler
- # with tab stops that can be set, moved, and deleted.
- if {![info exists widgetDemo]} {
- error "This script should be run from the \"widget\" demo."
- }
- package require Tk
- # rulerMkTab --
- # This procedure creates a new triangular polygon in a canvas to
- # represent a tab stop.
- #
- # Arguments:
- # c - The canvas window.
- # x, y - Coordinates at which to create the tab stop.
- proc rulerMkTab {c x y} {
- upvar #0 demo_rulerInfo v
- set newTab [$c create polygon $x $y \
- [expr {$x+$v(size)}] [expr {$y+$v(size)}] \
- [expr {$x-$v(size)}] [expr {$y+$v(size)}]]
- set fill [$c itemcget $newTab -outline]
- $c itemconfigure $newTab -fill $fill -outline {}
- set v(normalStyle) "-fill $fill"
- return $newTab
- }
- set w .ruler
- catch {destroy $w}
- toplevel $w
- wm title $w "Ruler Demonstration"
- wm iconname $w "ruler"
- positionWindow $w
- set c $w.c
- label $w.msg -font $font -wraplength 5i -justify left -text "This canvas widget shows a mock-up of a ruler. You can create tab stops by dragging them out of the well to the right of the ruler. You can also drag existing tab stops. If you drag a tab stop far enough up or down so that it turns dim, it will be deleted when you release the mouse button."
- pack $w.msg -side top
- ## See Code / Dismiss buttons
- set btns [addSeeDismiss $w.buttons $w]
- pack $btns -side bottom -fill x
- canvas $c -width 14.8c -height 2.5c
- pack $w.c -side top -fill x
- set demo_rulerInfo(grid) .25c
- set demo_rulerInfo(left) [winfo fpixels $c 1c]
- set demo_rulerInfo(right) [winfo fpixels $c 13c]
- set demo_rulerInfo(top) [winfo fpixels $c 1c]
- set demo_rulerInfo(bottom) [winfo fpixels $c 1.5c]
- set demo_rulerInfo(size) [winfo fpixels $c .2c]
- # Main widget program sets variable tk_demoDirectory
- if {[winfo depth $c] > 1} {
- set demo_rulerInfo(activeStyle) "-fill red -stipple {}"
- set demo_rulerInfo(deleteStyle) [list -fill red \
- -stipple @[file join $tk_demoDirectory images gray25.xbm]]
- } else {
- set demo_rulerInfo(activeStyle) "-fill black -stipple {}"
- set demo_rulerInfo(deleteStyle) [list -fill black \
- -stipple @[file join $tk_demoDirectory images gray25.xbm]]
- }
- $c create line 1c 0.5c 1c 1c 13c 1c 13c 0.5c -width 1
- for {set i 0} {$i < 12} {incr i} {
- set x [expr {$i+1}]
- $c create line ${x}c 1c ${x}c 0.6c -width 1
- $c create line $x.25c 1c $x.25c 0.8c -width 1
- $c create line $x.5c 1c $x.5c 0.7c -width 1
- $c create line $x.75c 1c $x.75c 0.8c -width 1
- $c create text $x.15c .75c -text $i -anchor sw
- }
- $c addtag well withtag [$c create rect 13.2c 1c 13.8c 0.5c \
- -fill [lindex [$c config -bg] 4]]
- $c addtag well withtag [rulerMkTab $c [winfo pixels $c 13.5c] \
- [winfo pixels $c .65c]]
- $c bind well <Button-1> "rulerNewTab $c %x %y"
- $c bind tab <Button-1> "rulerSelectTab $c %x %y"
- bind $c <B1-Motion> "rulerMoveTab $c %x %y"
- bind $c <ButtonRelease-1> "rulerReleaseTab $c"
- # rulerNewTab --
- # Does all the work of creating a tab stop, including creating the
- # triangle object and adding tags to it to give it tab behavior.
- #
- # Arguments:
- # c - The canvas window.
- # x, y - The coordinates of the tab stop.
- proc rulerNewTab {c x y} {
- upvar #0 demo_rulerInfo v
- $c addtag active withtag [rulerMkTab $c $x $y]
- $c addtag tab withtag active
- set v(x) $x
- set v(y) $y
- rulerMoveTab $c $x $y
- }
- # rulerSelectTab --
- # This procedure is invoked when mouse button 1 is pressed over
- # a tab. It remembers information about the tab so that it can
- # be dragged interactively.
- #
- # Arguments:
- # c - The canvas widget.
- # x, y - The coordinates of the mouse (identifies the point by
- # which the tab was picked up for dragging).
- proc rulerSelectTab {c x y} {
- upvar #0 demo_rulerInfo v
- set v(x) [$c canvasx $x $v(grid)]
- set v(y) [expr {$v(top)+2}]
- $c addtag active withtag current
- eval "$c itemconf active $v(activeStyle)"
- $c raise active
- }
- # rulerMoveTab --
- # This procedure is invoked during mouse motion events to drag a tab.
- # It adjusts the position of the tab, and changes its appearance if
- # it is about to be dragged out of the ruler.
- #
- # Arguments:
- # c - The canvas widget.
- # x, y - The coordinates of the mouse.
- proc rulerMoveTab {c x y} {
- upvar #0 demo_rulerInfo v
- if {[$c find withtag active] == ""} {
- return
- }
- set cx [$c canvasx $x $v(grid)]
- set cy [$c canvasy $y]
- if {$cx < $v(left)} {
- set cx $v(left)
- }
- if {$cx > $v(right)} {
- set cx $v(right)
- }
- if {($cy >= $v(top)) && ($cy <= $v(bottom))} {
- set cy [expr {$v(top)+2}]
- eval "$c itemconf active $v(activeStyle)"
- } else {
- set cy [expr {$cy-$v(size)-2}]
- eval "$c itemconf active $v(deleteStyle)"
- }
- $c move active [expr {$cx-$v(x)}] [expr {$cy-$v(y)}]
- set v(x) $cx
- set v(y) $cy
- }
- # rulerReleaseTab --
- # This procedure is invoked during button release events that end
- # a tab drag operation. It deselects the tab and deletes the tab if
- # it was dragged out of the ruler.
- #
- # Arguments:
- # c - The canvas widget.
- # x, y - The coordinates of the mouse.
- proc rulerReleaseTab c {
- upvar #0 demo_rulerInfo v
- if {[$c find withtag active] == {}} {
- return
- }
- if {$v(y) != $v(top)+2} {
- $c delete active
- } else {
- eval "$c itemconf active $v(normalStyle)"
- $c dtag active
- }
- }
|