NAME Curses::UI::Volume - Create and manipulate volume widgets. CLASS HIERARCHY Curses::UI::Containter Curses::UI::Widget | +----Curses::UI::ContainerWidget | +----Curses::UI::Volume SYNOPSIS use Curses::UI; my $win = $cui->add('window_id', 'Window'); my $volume = $win->add( 'myvolume', 'Curses::UI::Volume', -volume => 50, ); $volume->draw; DESCRIPTION Curses::UI::Volume is a widget that shows a volume number in graphic form. Precision is 8 stays in one character. STANDARD OPTIONS "-parent", "-x", "-y", "-width", "-height", "-pad", "-padleft", "-padright", "-padtop", "-padbottom", "-ipad", "-ipadleft", "-ipadright", "-ipadtop", "-ipadbottom", "-title", "-titlefullwidth", "-titlereverse", "-onfocus", "-onblur". For an explanation of these standard options, see Curses::UI::Widget. REMOVED OPTIONS "-text". WIDGET-SPECIFIC OPTIONS * "-bg" < COLOR > Background color. Possible values are defined in Curses::UI::Color. Default value is 'black'. * "-fg" < COLOR > Foreground color. Possible values are defined in Curses::UI::Color. Default value is 'white'. * "-volume" < PERCENT_NUMBER > If PERCENT_NUMBER is set, text on the label will be drawn as volume level for this percent number. Volume number is checked for 0 - 100% value. Default value is 0. STANDARD METHODS "layout", "draw", "intellidraw", "focus", "onFocus", "onBlur". For an explanation of these standard methods, see Curses::UI::Widget. WIDGET-SPECIFIC METHODS * "new(%parameters)" Constructor. Create widget with volume in graphic form, defined by -volume number. Returns object. * "volume([$volume])" Get or set volume number. In set mode volume number is checked for 0 - 100% value. Returns volume number (0-100%). EXAMPLE1 use strict; use warnings; use Curses::UI; # Object. my $cui = Curses::UI->new; # Main window. my $win = $cui->add('window_id', 'Window'); # Add volume. $win->add( undef, 'Curses::UI::Volume', '-volume' => 50, ); # Binding for quit. $win->set_binding(\&exit, "\cQ", "\cC"); # Loop. $cui->mainloop; # Output like: # █▌ EXAMPLE2 use strict; use warnings; use Curses::UI; # Object. my $cui = Curses::UI->new( -color_support => 1, ); # Main window. my $win = $cui->add('window_id', 'Window'); # Add volume. my $vol = $win->add( undef, 'Curses::UI::Volume', '-border' => 1, '-volume' => 0, '-title' => 'foo', '-width' => 10, ); # Binding for quit. $win->set_binding(\&exit, "\cQ", "\cC"); # Time. $cui->set_timer( 'timer', sub { my $act = $vol->volume; $act += 5; if ($act > 100) { $act = 0; } $vol->volume($act); return; }, 1, ); # Loop. $cui->mainloop; # Output like: # ┌ foo ───┐ # │▊ │ # └────────┘ DEPENDENCIES Curses, Curses::UI::Common, Curses::UI::ContainerWidget, Curses::UI::Label, Curses::UI::Widget, Encode, Readonly. SEE ALSO Task::Curses::UI Install the Curses::UI modules. REPOSITORY <https://github.com/michal-josef-spacek/Curses-UI-Volume> AUTHOR Michal Josef Špaček <mailto:skim@cpan.org> <http://skim.cz> LICENSE AND COPYRIGHT © 2014-2023 Michal Josef Špaček BSD 2-Clause License VERSION 0.04