Tk (software)

From Wikipedia, the free encyclopedia
(Redirected from Tk (computing))
Jump to navigation Jump to search

Tk
Original authorJohn Ousterhout
DeveloperTcl Core Team[1]
Initial release1991; 35 years ago (1991)
Repository
  • {{URL|example.com|optional display text}}Lua error in Module:EditAtWikidata at line 29: attempt to index field 'wikibase' (a nil value).
Written inC
Engine
    Lua error in Module:EditAtWikidata at line 29: attempt to index field 'wikibase' (a nil value).
    Operating systemCross-platform
    PlatformCross-platform
    TypeWidget toolkit
    LicenseBSD-style[2]
    Websitetcl.tk

    Tk is a cross-platform widget toolkit that provides a library of basic elements of GUI widgets for building a graphical user interface (GUI) in many programming languages. It is free and open-source software released under a BSD-style software license.

    Tk provides many widgets commonly needed to develop desktop applications, such as button, menu, canvas, text, frame, label, etc. Tk has been ported to run on most flavors of Linux, macOS, Unix, and Microsoft Windows. Like Tcl, Tk supports Unicode within the Basic Multilingual Plane, but it has not yet been extended to handle the current extended full Unicode (e.g., UTF-16 from UCS-2 that Tk supports).

    Tk was designed to be extended, and a wide range of extensions are available that offer new widgets or other capabilities.[3][4]

    Since Tcl/Tk 8, it offers "native look and feel" (for instance, menus and buttons are displayed in the manner of "native" software for any given platform).[5] Highlights of version 8.5 include a new theming engine, originally called Tk Tile,[6] but it is now generally referred to as "themed Tk", as well as improved font rendering.[7] Highlights of version 8.6 include PNG support and angled text.[8]

    History

    [edit | edit source]

    Tk was developed by John Ousterhout as an extension for the Tcl scripting language. It was first publicly released in 1991.[9] Tk versioning was done separately from Tcl until version 8.0.

    Tk was written originally for Unix/X11, and proved extremely popular with programmers in the 1990s by virtue of its being easier to learn and use than Motif and other X11 toolkits of the time.[10] Tk was also ported to Microsoft Windows and Macintosh platforms, starting with Tk 4.2 and improved with native look and feel in Tk 8.0 (released 1997). To mark the popularity and significance of Tk in the 1990s, Ousterhout was given the ACM Software System Award in 1997 for Tcl/Tk:[11]

    ACM Software System Award Winner: John K Ousterhout

    For the Tcl scripting language which allows developers to create complex systems from pre-existing components. The embedded Tk provides a simple mechanism for creating graphical user interfaces. Together they make a powerful addition to the software repertoire.

    Interest in Tk waned significantly from the late 1990s and onward. The default look and feel on Unix still emulated Motif, despite the mainstream replacement of Motif by toolkits such as FLTK, Qt, and GTK.[12] Widgets that became commonly used in applications (e.g. trees, combo boxes, tabbed notebooks) were not available in the Tk core, but only via multiple, often competing add-ons.[13]

    Tk 8.5, released in late 2007, corrected some of these problems by adding missing widgets to the core, introducing a new theming engine and modernizing the look and feel on Unix.[7] However, because some code changes were required to incorporate these advancements, many existing applications retain the older Motif-inspired feel that Tk had become known for.[14]

    Architecture

    [edit | edit source]

    Tk is a platform-independent GUI framework developed for Tcl. From a Tcl shell (tclsh), Tk may be invoked using the command package require Tk. The program wish (WIndowing SHell) provides a way to run a tclsh shell in a graphical window as well as providing Tk.[15]

    Tk has the following characteristics:

    • Platform-independent: Like Tcl, Tk is interpreted. It has been ported to multiple platforms and can easily run on all of them without modification.[16]
    • Customizable: Almost all the features of a widget in Tk are customizable through options during the creation of the widget or later on through the configure command.[17]
    • Configurable: Many of the options can be stored in an option database, making it very easy to parameterize the look of an application (such as the color scheme). This also means that storing the application-specific options is only a matter of saving the option add commands and executing them on loading the application.[18]

    Language bindings

    [edit | edit source]

    A library written in one programming language may be used in another language if bindings are written; Tk is integrated with the Tcl language. Various other languages have bindings for Tk, a partial list of which is on the Tk website.[19] Bindings exist for additional languages which might not be listed, including Ada (called TASH),[20] Go (through [21]), Haskell (called HTk),[22] Perl, Python (called Tkinter), R (through the standard package: tcltk), Ruby, Rexx, and Common Lisp.

    There are several ways to use Tk from Perl: the Tcl::Tk and Tkx Perl modules,[23] both of which use Tcl as a bridge to access Tk, and Perl/Tk,[24] which provides native Perl access to Tk structures. The Python binding uses Tcl as a bridge to Tk.[25]

    Features

    [edit | edit source]

    Tk provides various widgets.[26] Basic widgets are embedded into toplevel widgets, which in turn are usually hosted by the operating system in floating windows that can be moved around on the screen.[27]

    Basic widgets

    [edit | edit source]
    • button
    • canvas
    • checkbutton
    • combobox
    • entry
    • frame
    • label
    • labelframe
    • listbox
    • menu
    • menubutton
    • message
    • notebook
    • panedwindow
    • progressbar
    • radiobutton
    • scale
    • scrollbar
    • separator
    • sizegrip
    • spinbox
    • text
    • tk_optionMenu
    • treeview

    Top-level widgets

    [edit | edit source]
    • tk_chooseColor – pops up a dialog box for the user to select a color.
    • tk_chooseDirectory – pops up a dialog box for the user to select a directory.
    • tk_dialog – creates a modal dialog and waits for a response.
    • tk_getOpenFile – pops up a dialog box for the user to select a file to open.
    • tk_getSaveFile – pops up a dialog box for the user to select a file to save.
    • tk_messageBox – pops up a message window and waits for a user response.
    • tk_popup – posts a popup menu.
    • toplevel – creates and manipulates toplevel widgets.

    Geometry managers

    [edit | edit source]

    Basic widgets are arranged in toplevel windows using geometry managers:[28]

    • place – positions widgets at absolute locations
    • grid – arranges widgets in a grid
    • pack – packs widgets into a cavity

    See also

    [edit | edit source]

    Lua error in mw.title.lua at line 392: bad argument #2 to 'title.new' (unrecognized namespace name 'Portal').

    References

    [edit | edit source]
    1. ^ Lua error in Module:Citation/CS1/Configuration at line 2172: attempt to index field '?' (a nil value).
    2. ^ Lua error in Module:Citation/CS1/Configuration at line 2172: attempt to index field '?' (a nil value).
    3. ^ Writing a Tk Widget in C, Chapter 46 in Practical Programming in Tcl and Tk, Lua error in Module:Citation/CS1/Configuration at line 2172: attempt to index field '?' (a nil value).
    4. ^ Lua error in Module:Citation/CS1/Configuration at line 2172: attempt to index field '?' (a nil value).
    5. ^ Lua error in Module:Citation/CS1/Configuration at line 2172: attempt to index field '?' (a nil value).
    6. ^ Lua error in Module:Citation/CS1/Configuration at line 2172: attempt to index field '?' (a nil value).
    7. ^ a b Lua error in Module:Citation/CS1/Configuration at line 2172: attempt to index field '?' (a nil value).
    8. ^ Lua error in Module:Citation/CS1/Configuration at line 2172: attempt to index field '?' (a nil value).
    9. ^ Lua error in Module:Citation/CS1/Configuration at line 2172: attempt to index field '?' (a nil value).
    10. ^ Lua error in Module:Citation/CS1/Configuration at line 2172: attempt to index field '?' (a nil value).
    11. ^ Lua error in Module:Citation/CS1/Configuration at line 2172: attempt to index field '?' (a nil value).
    12. ^ Lua error in Module:Citation/CS1/Configuration at line 2172: attempt to index field '?' (a nil value).
    13. ^ Lua error in Module:Citation/CS1/Configuration at line 2172: attempt to index field '?' (a nil value).
    14. ^ Lua error in Module:Citation/CS1/Configuration at line 2172: attempt to index field '?' (a nil value).
    15. ^ Lua error in Module:Citation/CS1/Configuration at line 2172: attempt to index field '?' (a nil value).
    16. ^ Lua error in Module:Citation/CS1/Configuration at line 2172: attempt to index field '?' (a nil value).
    17. ^ Lua error in Module:Citation/CS1/Configuration at line 2172: attempt to index field '?' (a nil value).
    18. ^ Lua error in Module:Citation/CS1/Configuration at line 2172: attempt to index field '?' (a nil value).
    19. ^ Lua error in Module:Citation/CS1/Configuration at line 2172: attempt to index field '?' (a nil value).
    20. ^ Lua error in Module:Citation/CS1/Configuration at line 2172: attempt to index field '?' (a nil value).
    21. ^ Lua error in Module:Citation/CS1/Configuration at line 2172: attempt to index field '?' (a nil value).
    22. ^ Lua error in Module:Citation/CS1/Configuration at line 2172: attempt to index field '?' (a nil value).
    23. ^ Lua error in Module:Citation/CS1/Configuration at line 2172: attempt to index field '?' (a nil value).
    24. ^ Perl/Tk Concepts, Chapter 1 in Mastering Perl/Tk, Lua error in Module:Citation/CS1/Configuration at line 2172: attempt to index field '?' (a nil value).
    25. ^ Tkinter, Chapter 2.4 in Modern Tkinter for Busy Python Developers, ASIN B0071QDNLO
    26. ^ Lua error in Module:Citation/CS1/Configuration at line 2172: attempt to index field '?' (a nil value).
    27. ^ Widgets, Chapter 17.2 in Tcl and the Tk Toolkit , Lua error in Module:Citation/CS1/Configuration at line 2172: attempt to index field '?' (a nil value).
    28. ^ Geometry Managers, Chapter 17.6 in Tcl and the Tk Toolkit , Lua error in Module:Citation/CS1/Configuration at line 2172: attempt to index field '?' (a nil value).

    Further reading

    [edit | edit source]
    • Lua error in Module:Citation/CS1/Configuration at line 2172: attempt to index field '?' (a nil value).
    • Lua error in Module:Citation/CS1/Configuration at line 2172: attempt to index field '?' (a nil value).
    • Brent B. Welch, Practical Programming in Tcl and Tk, Prentice Hall, Upper Saddle River, NJ, USA, Lua error in Module:Citation/CS1/Configuration at line 2172: attempt to index field '?' (a nil value)., 2003
    • J Adrian Zimmer, Tcl/Tk for Programmers Archived 4 April 2017 at the Wayback Machine, IEEE Computer Society, distributed by John Wiley and Sons, Lua error in Module:Citation/CS1/Configuration at line 2172: attempt to index field '?' (a nil value)., 1998
    • Mark Harrison and Michael McLennan, Effective Tcl/Tk Programming, Addison-Wesley, Reading, MA, USA, Lua error in Module:Citation/CS1/Configuration at line 2172: attempt to index field '?' (a nil value)., 1998
    • Bert Wheeler, Tcl/Tk 8.5 Programming Cookbook, Packt Publishing, Birmingham, England, UK, Lua error in Module:Citation/CS1/Configuration at line 2172: attempt to index field '?' (a nil value)., 2011
    • Clif Flynt Tcl/Tk, Third Edition: A Developer’s Guide, Lua error in Module:Citation/CS1/Configuration at line 2172: attempt to index field '?' (a nil value)., 2012
    [edit | edit source]

    Lua error in Module:Authority_control at line 153: attempt to index field 'wikibase' (a nil value).