Looking for help!
NAME
X11::Muralis - Perl module to display wallpaper on your desktop.
VERSION
version 0.1003
SYNOPSIS
use X11::Muralis;
my $obj = X11::Muralis->new(%args);
DESCRIPTION
The X11::Muralis module (and accompanying script, 'muralis') displays a given image file on the desktop background (that is, the root window) of an X-windows display.
This tries to determine what size would best suit the image; whether to show it fullscreen or normal size, whether to show it tiled or centred on the screen. Setting the options overrides this behaviour.
One can also repeat the display of the last-displayed image, changing the display options as one desires.
This uses an external program (xloadimage, xsri, or feh) to display the image file.
This also depends on xwininfo to get information about the root window.
The Name
The name "muralis" comes from the Latin "muralis" which is the word from which "mural" was derived. I just thought it was a cool name for a wallpaper script.
METHODS
new
Create a new object, setting global values for the object.
my $obj = X11::Muralis->new(
config_dir=>"$ENV{HOME}/.muralis",
is_image => qr/.(gif|jpeg|jpg|tiff|tif|png|pbm|xwd|pcx|gem|xpm|xbm)/i,
);
get_backends
my @backends = $obj->list_backends();
Return which backends are available.
list_backends
$obj->list_backends();
List which backends are available.
list_images
$dr->list_images();
$dr->list_images(match=>'animals', list=>'fullname');
List all the images which match the match-string. (prints to STDOUT)
Arguments:
- match => string
-
Limit the images which match the given string.
- listformat => string
-
Give the list format. If not defined or empty or "normal", will do a "normal" listing, which gives the directory names followed by the files. If 'fullname' then it will list all the files with their full names (and doesn't list the directory names).
- outfile => filename
-
Print the list to the given file rather than to STDOUT.
provides
my %prov = $obj->provides($backend_name);
What does this backend provide?
display_image
$obj->display_image(%args);
Arguments:
- center=>1
-
Centre the image on the root window.
- colors=>num
-
Limit the number of colours used to display the image. This is useful for a 256-colour display.
- fullscreen=>1
-
The image will be zoomed to fit the size of the screen.
- match=>string
-
If using the --list or --random options, limit the image(s) to those which match the string.
- random=>1
-
Pick a random image to display. If --match is given, limit the selection to images in directories which match the match-string.
- repeat_last=>1
-
Display the last image which was displayed. This is useful to re-display an image while overriding the default display options.
- option=>string
-
Additional option or options to pass on to the backend.
- tile=>1
-
Tile the image to fill the root window.
- use=>backend
-
Use the given backend.
- verbose=>1
-
Print informational messages.
- zoom=>percent
-
Enlarge or reduce the size of the image by the given percent.
Private Methods
count_images
my $count = $dr->count_images();
my $count = $dr->count_images(match=>'animals');
Counts all the images.
Optional argument: match => string
Counts the images which match the string.
get_image_files
my @files = $self->get_image_files();
my @files = $self->get_image_files( match=>$match, exclude=>$exclude unseen=>1);
Get a list of matching image files.
If 'unseen' is true, then get the file names from the ~/.muralis/unseen file, if it exists.
get_dirs
my @dirs = $self->get_dirs();
Get the list of directories.
get_root_info
Get info about the root window. This uses xwininfo.
find_nth_file
Find the full name of the nth (matching) file starting the count from 1.
get_random_file
Get the name of a random file.
find_fullname
Find the full filename of an image file.
get_display_options
Use the options passed in or figure out the best default options. Return a string containing the options.
$options = $obj->get_display_options($filename, %args);
save_last_displayed
Save the name of the image most recently displayed. Also update the "unseen" file if 'unseen' is true.
REQUIRES
Image::Info
File::Basename
File::Find::Rule
Test::More
INSTALLATION
To install this module, run the following commands:
perl Build.PL
./Build
./Build test
./Build install
Or, if you're on a platform (like DOS or Windows) that doesn't like the "./" notation, you can do this:
perl Build.PL
perl Build
perl Build test
perl Build install
In order to install somewhere other than the default, such as in a directory under your home directory, like "/home/fred/perl" go
perl Build.PL --install_base /home/fred/perl
as the first step instead.
This will install the files underneath /home/fred/perl.
You will then need to make sure that you alter the PERL5LIB variable to find the modules, and the PATH variable to find the script.
Therefore you will need to change: your path, to include /home/fred/perl/script (where the script will be)
PATH=/home/fred/perl/script:${PATH}
the PERL5LIB variable to add /home/fred/perl/lib
PERL5LIB=/home/fred/perl/lib:${PERL5LIB}
SEE ALSO
perl(1).
BUGS
Please report any bugs or feature requests to the author.
AUTHOR
Kathryn Andersen (RUBYKAT)
perlkat AT katspace dot com
http://www.katspace.org/tools/muralis
COPYRIGHT AND LICENCE
Copyright (c) 2005-2006 by Kathryn Andersen
This program is free software; you can redistribute it and/or modify it under the same terms as Perl itself.