ttknote.tcl 2.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657
  1. # ttknote.tcl --
  2. #
  3. # This demonstration script creates a toplevel window containing a Ttk
  4. # notebook widget.
  5. if {![info exists widgetDemo]} {
  6. error "This script should be run from the \"widget\" demo."
  7. }
  8. package require Tk
  9. set w .ttknote
  10. catch {destroy $w}
  11. toplevel $w
  12. wm title $w "Ttk Notebook Widget"
  13. wm iconname $w "ttknote"
  14. positionWindow $w
  15. ## See Code / Dismiss
  16. pack [addSeeDismiss $w.seeDismiss $w] -side bottom -fill x
  17. ttk::frame $w.f
  18. pack $w.f -fill both -expand 1
  19. set w $w.f
  20. ## Make the notebook and set up Ctrl+Tab traversal
  21. ttk::notebook $w.note
  22. pack $w.note -fill both -expand 1 -padx 2 -pady 3
  23. ttk::notebook::enableTraversal $w.note
  24. ## Popuplate the first pane
  25. ttk::frame $w.note.msg
  26. ttk::label $w.note.msg.m -font $font -wraplength 4i -justify left -anchor n -text "Ttk is the new Tk themed widget set. One of the widgets it includes is the notebook widget, which provides a set of tabs that allow the selection of a group of panels, each with distinct content. They are a feature of many modern user interfaces. Not only can the tabs be selected with the mouse, but they can also be switched between using Ctrl+Tab when the notebook page heading itself is selected. Note that the second tab is disabled, and cannot be selected."
  27. ttk::button $w.note.msg.b -text "Neat!" -underline 0 -command {
  28. set neat "Yeah, I know..."
  29. after 500 {set neat {}}
  30. }
  31. bind $w <Alt-n> "focus $w.note.msg.b; $w.note.msg.b invoke"
  32. ttk::label $w.note.msg.l -textvariable neat
  33. $w.note add $w.note.msg -text "Description" -underline 0 -padding 2
  34. grid $w.note.msg.m - -sticky new -pady 2
  35. grid $w.note.msg.b $w.note.msg.l -pady {2 4}
  36. grid rowconfigure $w.note.msg 1 -weight 1
  37. grid columnconfigure $w.note.msg {0 1} -weight 1 -uniform 1
  38. ## Populate the second pane. Note that the content doesn't really matter
  39. ttk::frame $w.note.disabled
  40. $w.note add $w.note.disabled -text "Disabled" -state disabled
  41. ## Popuplate the third pane
  42. ttk::frame $w.note.editor
  43. $w.note add $w.note.editor -text "Text Editor" -underline 0
  44. text $w.note.editor.t -width 40 -height 10 -wrap char \
  45. -yscroll "$w.note.editor.s set"
  46. ttk::scrollbar $w.note.editor.s -orient vertical -command "$w.note.editor.t yview"
  47. pack $w.note.editor.s -side right -fill y -padx {0 2} -pady 2
  48. pack $w.note.editor.t -fill both -expand 1 -pady 2 -padx {2 0}