 
- Ruby - Home
- Ruby - Overview
- Ruby - Environment Setup
- Ruby - Syntax
- Ruby - Classes and Objects
- Ruby - Variables
- Ruby - Operators
- Ruby - Comments
- Ruby - IF...ELSE
- Ruby - Loops
- Ruby - Methods
- Ruby - Blocks
- Ruby - Modules
- Ruby - Strings
- Ruby - Arrays
- Ruby - Hashes
- Ruby - Date & Time
- Ruby - Ranges
- Ruby - Iterators
- Ruby - File I/O
- Ruby - Exceptions
- Ruby - Object Oriented
- Ruby - Regular Expressions
- Ruby - Database Access
- Ruby - Web Applications
- Ruby - Sending Email
- Ruby - Socket Programming
- Ruby - Ruby/XML, XSLT
- Ruby - Web Services
- Ruby - Tk Guide
- Ruby - Ruby/LDAP Tutorial
- Ruby - Multithreading
- Ruby - Built-in Functions
- Ruby - Predefined Variables
- Ruby - Predefined Constants
- Ruby - Associated Tools
- Ruby Useful Resources
- Ruby - Quick Guide
- Ruby - Cheatsheet
- Ruby - Useful Resources
- Ruby - Discussion
- Ruby - Ruby on Rails Tutorial
Ruby/TK - Checkbutton Widget
Description
A Checkbutton is like a regular button, except that not only can the user press it, which will invoke a command callback, but it also holds a binary value of some kind (i.e., a toggle). Checkbuttons are used all the time when a user is asked to choose between, e.g., two different values for an option.
A checkbutton can display a textual string, bitmap or image. If text is displayed, it must all be in a single font, but it can occupy multiple lines on the screen (if it contains newlines or if wrapping occurs because of the wraplength option) and one of the characters may optionally be underlined using the underline option.
A checkbutton has all of the behavior of a simple button, including the following: it can display itself in either of three different ways, according to the state option; it can be made to appear raised, sunken, or flat; it can be made to flash; and it invokes a Tcl command whenever mouse button 1 is clicked over the checkbutton.
Syntax
Here is a simple syntax to create this widget −
TkCheckButton.new(root) {
   .....Standard Options....
   .....Widget-specific Options....
}
Standard Options
- activebackground
- activeforeground
- anchor
- background
- bitmap
- borderwidth
- compound
- cursor
- disabledforeground
- font
- foreground
- highlightbackground
- highlightcolor
- highlightthickness
- image
- justify
- padx
- pady
- relief
- takefocus
- text
- textvariable
- underline
- wraplength
These options have been described in the previous chapter.
Widget Specific Options
| Sr.No. | Options & Description | 
|---|---|
| 1 | command => String Specifies a Ruby command to associate with the button. This command is typically invoked when mouse button 1 is released over the button window. Here you can associate a Ruby method to be executed against mouse click. Built in function which can be called using command option − 
 | 
| 2 | height => Integer Specifies a desired height for the button. | 
| 3 | indicatoron => Boolean Specifies whether or not the indicator should be drawn. Must be a proper boolean value. If false, the relief option is ignored and the widget's relief is always sunken if the widget is selected and raised otherwise. | 
| 4 | offvalue => Integer Specifies value to store in the button's associated variable whenever this button is deselected. Defaults to 0. | 
| 5 | onvalue   => Integer Specifies value to store in the button's associated variable whenever this button is selected. Defaults to 1. | 
| 6 | selectcolor => String Specifies a background color to use when the button is selected. If indicatoron is true, then the color applies to the indicator. If indicatoron is false, this color is used as the background for the entire widget, in place of background or activebackground, whenever the widget is selected. | 
| 7 | selectimage => Image Specifies an image to display (in place of the image option) when the checkbutton is selected. This option is ignored unless the image option has been specified. | 
| 8 | state => String Specifies one of three states for the button: normal, active, or disabled. In normal state the button is displayed using the foreground and background options. The active state is typically used when the pointer is over the button. In active state the button is displayed using the activeforeground and activebackground options. Disabled state means that the button should be insensitive. | 
| 9 | variable => Variable Specifies name of global variable to set to indicate whether or not this button is selected. Defaults to the name of the button within its parent. | 
| 10 | width => Integer Specifies a desired width for the button. | 
Event Bindings
Ruby/Tk automatically creates class bindings for checkbuttons that give them the following default behavior −
- A checkbutton activates whenever the mouse passes over it and deactivates whenever the mouse leaves the checkbutton. 
- When mouse button 1 is pressed over a checkbutton it is invoked (its selection state toggles and the command associated with the button is invoked, if there is one). 
- When a checkbutton has the input focus, the space key causes the checkbutton to be invoked. 
If the checkbutton's state is disabled then none of the above actions occur: the checkbutton is completely non-responsive.
Examples
require 'tk'
root = TkRoot.new
root.title = "Window"
CkhButton1 = TkCheckButton.new(root) do
   text "Orange"
   indicatoron "true"
   background  "red"
   relief "groove"
   height 2
   width 2
   onvalue 'Orange'
   place('height' => 25,'width'  => 100, 'x' => 10, 'y'=> 10)
   command (select)
end
CkhButton2 = TkCheckButton.new(root) do
   text "Banana"
   background  "red"
   relief "groove"
   height 2
   width 2
   onvalue 'Banana'
   place('height' => 25,'width' => 100, 'x' => 10, 'y'=> 40)
end
Tk.mainloop
This will produce the following result −
