Seth Woolley's Man Viewer

menubutton(n) - menubutton, menubutton - Create and manipulate menubutton widgets - man n menubutton

([section] manual, -k keyword, -K [section] search, -f whatis)
man plain no title

menubutton(n)                Tk Built-In Commands                menubutton(n)



NAME
       menubutton - Create and manipulate menubutton widgets

SYNOPSIS
       menubutton   pathName   ?options?   -activebackground   -font     -pady
       -activeforeground   -foreground    -relief    -anchor   -highlightback-
       ground     -takefocus   -background    -highlightcolor     -text  -bit-
       map   -highlightthickness -textvariable                        -border-
       width   -image    -underline -cursor   -justify  -wraplength -disabled-
       foreground -padx

WIDGET-SPECIFIC OPTIONS
       Specifies whether the menubutton should display both an image and text,
       and  if(3,n)  so,  where  the  image  should be placed relative to the text.
       Valid values for this option are bottom, center, left, none, right  and
       top.   The default value is none, meaning that the menubutton will dis-
       play either an image or text, depending on the values of the -image and
       -bitmap  options.   Specifies  where  the menu(3x,n,n tk_menuSetFocus) is going to be popup up.
       above tries to pop the menu(3x,n,n tk_menuSetFocus) above the menubutton. below  tries  to  pop
       the  menu(3x,n,n tk_menuSetFocus)  below the menubutton. left tries to pop the menu(3x,n,n tk_menuSetFocus) to the left
       of the menubutton. right tries to pop the menu(3x,n,n tk_menuSetFocus) to the right of the menu(3x,n,n tk_menuSetFocus)
       button.  flush(8,n) pops the menu(3x,n,n tk_menuSetFocus) directly over the menubutton.  Specifies a
       desired height for the menubutton.  If an image or bitmap is being dis-
       played in(1,8) the menubutton then the value is in(1,8) screen units(1,7) (i.e. any of
       the forms acceptable to Tk_GetPixels); for text it is in(1,8) lines of text.
       If this option isn't specified, the menubutton's desired height is com-
       puted from the size of the image or bitmap or text being  displayed  in(1,8)
       it.   The  value  must be a proper boolean value.  If it is true then a
       small indicator rectangle will be displayed on the right  side  of  the
       menubutton  and  the default menu(3x,n,n tk_menuSetFocus) bindings will treat this as an option
       menubutton.  If false then no indicator will be  displayed.   Specifies
       the  path  name  of the menu(3x,n,n tk_menuSetFocus) associated with this menubutton.  The menu(3x,n,n tk_menuSetFocus)
       must be a child of the menubutton.  Specifies one of three  states  for
       the  menubutton:   normal,  active,  or  disabled.  In normal state the
       menubutton is displayed using the foreground  and  background  options.
       The  active  state  is  typically  used  when  the  pointer is over the
       menubutton.  In active state the  menubutton  is  displayed  using  the
       activeForeground  and  activeBackground  options.  Disabled state means
       that the menubutton should be insensitive:  the default  bindings  will
       refuse to activate the widget and will ignore mouse button presses.  In
       this state the disabledForeground and background options determine  how
       the button is displayed.  Specifies a desired width for the menubutton.
       If an image or bitmap is being displayed in(1,8)  the  menubutton  then  the
       value  is  in(1,8) screen units(1,7) (i.e. any of the forms acceptable to Tk_Get-
       Pixels); for text it is in(1,8) characters.  If this option isn't specified,
       the  menubutton's  desired width is computed from the size of the image
       or bitmap or text being displayed in(1,8) it.


INTRODUCTION
       The menubutton command creates a new  window  (given  by  the  pathName
       argument)  and  makes it into a menubutton widget.  Additional options,
       described above, may be specified on the command line or in(1,8) the  option
       database  to  configure  aspects  of the menubutton such as its colors,
       font, text, and initial relief.  The  menubutton  command  returns  its
       pathName argument.  At the time(1,2,n) this command is invoked, there must not
       exist a window named(5,8) pathName, but pathName's parent must exist.

       A menubutton is a widget that displays a  textual  string(3,n),  bitmap,  or
       image  and  is associated with a menu(3x,n,n tk_menuSetFocus) widget.  If text is displayed, it
       must all be in(1,8) a single font, but it can occupy multiple lines  on  the
       screen  (if(3,n)  it  contains newlines or if(3,n) wrapping occurs because of the
       wrapLength option) and one of the characters may optionally  be  under-
       lined using the underline option.  In normal usage, pressing mouse but-
       ton 1 over the menubutton causes the associated menu(3x,n,n tk_menuSetFocus) to be posted  just
       underneath  the menubutton.  If the mouse is moved over the menu(3x,n,n tk_menuSetFocus) before
       releasing the mouse button, the button release  causes  the  underlying
       menu(3x,n,n tk_menuSetFocus)  entry  to  be  invoked.  When the button is released, the menu(3x,n,n tk_menuSetFocus) is
       unposted.

       Menubuttons are typically organized into groups called menu(3x,n,n tk_menuSetFocus)  bars  that
       allow  scanning:  if(3,n)  the  mouse  button is pressed over one menubutton
       (causing it to post its menu(3x,n,n tk_menuSetFocus)) and  the  mouse  is  moved  over  another
       menubutton  in(1,8)  the  same  menu(3x,n,n tk_menuSetFocus) bar without releasing the mouse button,
       then the menu(3x,n,n tk_menuSetFocus) of the first menubutton is unposted and the menu(3x,n,n tk_menuSetFocus)  of  the
       new menubutton is posted instead.

       There  are several interactions between menubuttons and menus;  see the
       menu(3x,n,n tk_menuSetFocus) manual entry for information on various menu(3x,n,n tk_menuSetFocus) configurations,  such
       as pulldown menus and option menus.


WIDGET COMMAND
       The  menubutton  command  creates a new Tcl command whose name is path-
       Name.  This command may be used to invoke  various  operations  on  the
       widget.   It  has  the following general form: pathName option ?arg arg
       ...?  Option and the args determine the exact behavior of the  command.
       The following commands are possible for menubutton widgets:

       pathName cget option
              Returns  the  current value of the configuration option given by
              option.  Option may have any  of  the  values  accepted  by  the
              menubutton command.

       pathName configure ?option? ?value option value ...?
              Query  or modify the configuration options of the widget.  If no
              option is specified, returns a list describing all of the avail-
              able  options for pathName (see Tk_ConfigureInfo for information
              on the format of this list).  If option  is  specified  with  no
              value,  then the command returns a list describing the one named(5,8)
              option (this list will be identical to the corresponding sublist
              of  the  value  returned  if(3,n) no option is specified).  If one or
              more option-value pairs are specified, then the command modifies
              the  given widget option(s) to have the given value(s);  in(1,8) this
              case the command returns an empty string.  Option may  have  any
              of the values accepted by the menubutton command.


DEFAULT BINDINGS
       Tk  automatically creates class bindings for menubuttons that give them
       the following default behavior:

       [1]    A menubutton activates whenever the mouse  passes  over  it  and
              deactivates whenever the mouse leaves it.

       [2]    Pressing  mouse button 1 over a menubutton posts the menubutton:
              its relief changes to raised and its associated menu(3x,n,n tk_menuSetFocus)  is  posted
              under  the  menubutton.   If  the mouse is dragged down into the
              menu(3x,n,n tk_menuSetFocus) with the button still down, and if(3,n) the mouse button is then
              released  over  an entry in(1,8) the menu(3x,n,n tk_menuSetFocus), the menubutton is unposted
              and the menu(3x,n,n tk_menuSetFocus) entry is invoked.

       [3]    If button 1 is pressed over a menubutton and then released  over
              that menubutton, the menubutton stays posted: you can still move(3x,7,3x curs_move)
              the mouse over the menu(3x,n,n tk_menuSetFocus) and click button 1 on an entry to invoke
              it.   Once a menu(3x,n,n tk_menuSetFocus) entry has been invoked, the menubutton unposts
              itself.

       [4]    If button 1 is pressed over a menubutton and then  dragged  over
              some  other  menubutton,  the original menubutton unposts itself
              and the new menubutton posts.

       [5]    If button 1 is pressed over a menubutton  and  released  outside
              any  menubutton or menu(3x,n,n tk_menuSetFocus), the menubutton unposts without invoking
              any menu(3x,n,n tk_menuSetFocus) entry.

       [6]    When a menubutton is posted,  its  associated  menu(3x,n,n tk_menuSetFocus)  claims  the
              input focus to allow keyboard traversal of the menu(3x,n,n tk_menuSetFocus) and its sub-
              menus.  See the menu(3x,n,n tk_menuSetFocus) manual entry for details on these bindings.

       [7]    If the underline option has been specified for a menubutton then
              keyboard traversal may be used to post  the  menubutton:  Alt+x,
              where x is the underlined character (or its lower-case or upper-
              case equivalent), may be typed in(1,8) any window under the  menubut-
              ton's toplevel to post the menubutton.

       [8]    The  F10  key  may  be  typed  in(1,8)  any  window to post the first
              menubutton under its toplevel window that isn't disabled.

       [9]    If a menubutton has the input focus, the space and  return  keys
              post the menubutton.

       If  the  menubutton's  state is disabled then none of the above actions
       occur:  the menubutton is completely non-responsive.

       The behavior of menubuttons can be changed by defining new bindings for
       individual widgets or by redefining the class bindings.


KEYWORDS
       menubutton, widget



Tk                                    4.0                        menubutton(n)

References for this manual (incoming links)