Provided by: perl-tk_804.036+dfsg1-1ubuntu3_amd64 
      
    
NAME
       Tk::Balloon - pop up help balloons.
SYNOPSIS
           use Tk::Balloon;
           ...
           $b = $top->Balloon(-statusbar => $status_bar_widget);
           # Normal Balloon:
           $b->attach($widget,
                      -balloonmsg => "Balloon help message",
                      -statusmsg => "Status bar message");
           # Balloon attached to entries in a menu widget:
           $b->attach($menu, -state => 'status',
                             -msg => ['first menu entry',
                                      'second menu entry',
                                      ...
                                     ],
                     );
           # Balloon attached to individual items in a canvas widget:
           $b->attach($canvas, -balloonposition => 'mouse',
                               -msg => {'item1' => 'msg1',
                                        'tag2'  => 'msg2',
                                         ...
                                       },
                     );
           # Balloon attached to items in a listbox widget:
           $b->attach($listbox, -balloonposition => 'mouse',
                                -msg => ['first listbox element',
                                         '2nd listbox element',
                                         ...
                                        ],
                     );
DESCRIPTION
       Balloon provides the framework to create and attach help balloons to various widgets so that when the
       mouse pauses over the widget for more than a specified amount of time, a help balloon is popped up.
   Balloons and Menus or Listboxes
       If the balloon is attached to a Menu or Listbox widget and the message arguments are array references,
       then each element in the array will be the message corresponding to a menu entry or listbox element.  The
       balloon message will then be shown for the entry which the mouse pauses over. Otherwise it is assumed
       that the balloon is to be attached to the Menu or Listbox as a whole. You can have separate status and
       balloon messages just like normal balloons.
   Balloons and Canvases
       If the balloon is attached to a Canvas widget and the message arguments are hash references, then each
       hash key should correspond to a canvas item ID or tag and the associated value will correspond to the
       message for that canvas item. The balloon message will then be shown for the current item (the one at the
       position of the mouse). Otherwise it is assumed that the balloon is to be attached to the Canvas as a
       whole.  You can have separate status and balloon messages just like normal balloons.
   Balloons and HLists
       If the balloon is attached to a HList widget and the message arguments are hash references, then each
       hash key should correspond to a HList path and the associated value will correspond to the message for
       that HList item. The balloon message will then be shown for the current item (the one at the position of
       the mouse). Otherwise it is assumed that the balloon is to be attached to the HList as a whole.  You can
       have separate status and balloon messages just like normal balloons.
   Balloon Position
       By default, the balloon pops up at the lower right side of the client.  If it would extend outside the
       lower screen border, it's positioned at the upper right side. If it would extend outside the right screen
       border it's shown on the lower left side of the client. If it would extend outside both the lower and the
       right screen border, it's positioned at the upper left side of the client. Thus, the little arrow always
       points to the attached client.
OPTIONS
       Balloon accepts all of the options that the Frame widget accepts. In addition, the following options are
       also recognized.
       -initwait
           Specifies  the amount of time to wait without activity before popping up a help balloon. Specified in
           milliseconds. Defaults to 350 milliseconds. This applies to both the popped up balloon and the status
           bar message.
       -state
           Can be one of 'balloon', 'status', 'both' or 'none' indicating that  the  help  balloon,  status  bar
           help,  both  or  none  respectively should be activated when the mouse pauses over the client widget.
           Default is 'both'.
       -statusbar
           Specifies the widget used to display the status message. This widget should accept the  -text  option
           and  is  typically a Label. If the widget accepts the -textvariable option and that option is defined
           then it is used instead of the -text option.
       -balloonposition
           Can be one of 'widget' or 'mouse'. It controls where the  balloon  will  popup.  'widget'  makes  the
           balloon appear at the lower right corner of the widget it is attached to (default), and 'mouse' makes
           the balloon appear below and to the right of the current mouse position.
       -postcommand
           This  option  takes a CODE reference which will be executed before the balloon and statusbar messages
           are displayed and should return a true or false value to indicate whether you want the balloon to  be
           displayed  or  not.  This  also  lets you control where the balloon is positioned by returning a true
           value that looks like X,Y (matches this regular expression: "/^(\d+),(\d+)$/").  If  the  postcommand
           returns  a value that matches that re then those coordinates will be used as the position to post the
           balloon. Warning: this subroutine should return quickly or the balloon response will appear slow.
       -cancelcommand
           This option takes a CODE reference which will be executed before the balloon and  statusbar  messages
           are  canceled  and should return a true or false value to indicate whether you want the balloon to be
           canceled or not. Warning: this subroutine should return quickly or the balloon response  will  appear
           slow.
       -motioncommand
           This  option  takes  a CODE reference which will be executed for any motion event and should return a
           true or false  value  to  indicate  whether  the  currently  displayed  balloon  should  be  canceled
           (deactivated).   If it returns true then the balloon will definitely be canceled, if it returns false
           then it may still be canceled depending the internal rules.  Note: a new balloon may be posted  after
           the  -initwait  time  interval,  use  the -postcommand option to control that behavior.  Warning: the
           subroutine should be extremely fast or the balloon response will appear slow and consume a lot of CPU
           time (it is executed every time the mouse moves over the widgets the balloon is attached to).
       -numscreens
           This option accepts an integer 1 or greater. This option should be used to avoid disjointed  balloons
           across  multiple  screens  in  single  logical  sceen  (SLS)  mode.  This only currently works in the
           horizontal direction.  Example: If you are running dual screens in SLS mode then you would  set  this
           value to 2. Default value is 1.
METHODS
       The Balloon widget supports only three non-standard methods:
   attach(widget, options)
       Attaches the widget indicated by widget to the help system. The allowed options are:
       -statusmsg
           The  argument is the message to be shown on the status bar when the mouse pauses over this client. If
           this is not specified, but -msg is specified then the message displayed on the status bar is the same
           as the argument for -msg. If you give it a scalar reference then  it  is  dereferenced  before  being
           displayed. Useful if the postcommand is used to change the message.
       -balloonmsg
           The  argument  is  the  message  to be displayed in the balloon that will be popped up when the mouse
           pauses over this client. As with -statusmsg if this is not specified, then it takes  its  value  from
           the  -msg  specification if any. If neither -balloonmsg nor -msg are specified, or they are the empty
           string then no balloon is popped up instead of an empty balloon. If you give it  a  scalar  reference
           then  it  is  dereferenced  before  being  displayed. Useful if the postcommand is used to change the
           message.
       -msg
           The catch-all for -statusmsg and -balloonmsg. This is a convenient way of specifying the same message
           to be displayed in both the balloon and the status bar for the client.
       -initwait
       -state
       -statusbar
       -balloonposition
       -postcommand
       -cancelcommand
       -motioncommand
           These options allow you to override the balloon's default value for those  option  for  some  of  the
           widgets  it  is  attached  to.  It accepts the same values as above and will default to the Balloon's
           value.
   detach(widget)
       Detaches the specified widget from the help system.
   destroy
       Destroys the specified balloon.
ADVERTISED SUBWIDGETS
       The balloon label is advertised as "message".
EXAMPLES
       See the balloon demo included with the widget demo script that came with the distribution for examples on
       various ways to use balloons.
NOTES
       Because of the overhead associated with each balloon you create (from tracking the mouse movement to know
       when to activate and deactivate them) you will see the best performance  (low  CPU  consumption)  if  you
       create  as few balloons as possible and attach them to as many widgets as you can.  In other words, don't
       create a balloon for each widget you want to attach one to.
CAVEATS
       Pressing any button will deactivate (cancel) the current balloon, if one exists. You can usually make the
       balloon reappear by moving the mouse a little. Creative use of the 3 command options  can  help  you  out
       also.  If  the  mouse  is over the balloon when a menu is unposted then the balloon will remain until you
       move off of it.
BUGS
       If using balloons attached to listbox entries or canvas items in a scrolled widget,  then  the  subwidget
       have to be used:
           $balloon->attach($w->Subwidget("scrolled"), -msg => ...);
AUTHORS
       Rajappa Iyer <rsi@earthling.net> did the original coding.
       Jason A. Smith <smithj4@rpi.edu> added support for menus and made some other enhancements.
       Slaven Rezic <srezic@cpan.org> added support for canvas items.
       Gerhard Petrowitsch <gerhard@petrowitsch.de> added intelligent positioning
       Jack  Dunnigan  <dunniganj@cpan.org>  Made  positioning  more  intelligent and added support for multiple
       monitors under single logical screen.
HISTORY
       The code and documentation was derived from Balloon.tcl from the  Tix4.0  distribution  by  Ioi  Lam  and
       modified by the above mentioned authors. This code may be redistributed under the same terms as Perl.
perl v5.38.2                                       2024-04-01                                       Balloon(3pm)