--- rxvt-unicode/src/perl/background 2012/06/07 13:22:06 1.30 +++ rxvt-unicode/src/perl/background 2012/06/07 16:30:58 1.33 @@ -1,8 +1,20 @@ #! perl #:META:X_RESOURCE:%.expr:string:background expression -#:META:X_RESOURCE:%.enable:boolean:some boolean -#:META:X_RESOURCE:%.extra.:value:extra config +#:META:X_RESOURCE:%.border.:boolean:respect the terminal border + +=head1 background - manage terminal background + +=head2 SYNOPSIS + + rxvt -background-expr 'background expression' + -background-border + +=head2 DESCRIPTION + +=head2 REFERENCE + +=cut our $EXPR; #$EXPR = 'move W * 0.1, -H * 0.1, resize W * 0.5, H * 0.5, repeat_none load "opensource.png"'; @@ -17,9 +29,7 @@ #$EXPR = 'blur move (root, -x, -y), 5, 5' #resize load "/root/pix/das_fette_schwein.jpg", w, h -use Safe; - -our ($bgdsl_self, $old, $new); +our ($self, $old, $new); our ($x, $y, $w, $h); # enforce at least this interval between updates @@ -30,6 +40,10 @@ =head2 PROVIDERS/GENERATORS +These functions provide an image, by loading it from disk, grabbing it +from the root screen or by simply generating it. They are used as starting +points to get an image you can play with. + =over 4 =item load $path @@ -37,24 +51,48 @@ Loads the image at the given C<$path>. The image is set to plane tiling mode. - +Loaded images will be cached for one cycle. =cut sub load($) { my ($path) = @_; - $new->{load}{$path} = $old->{load}{$path} || $bgdsl_self->new_img_from_file ($path); + $new->{load}{$path} = $old->{load}{$path} || $self->new_img_from_file ($path); } +=item root + +Returns the root window pixmap, that is, hopefully, the background image +of your screen. The image is set to extend mode. + +This function makes your expression root sensitive, that means it will be +reevaluated when the bg image changes. + +=cut + sub root() { $new->{rootpmap_sensitive} = 1; die "root op not supported, exg, we need you"; } - sub solid($;$$) { - my $img = $bgdsl_self->new_img (urxvt::PictStandardARGB32, $_[1] || 1, $_[2] || 1); - $img->fill ($_[0]); +=item solid $colour + +=item solid $width, $height, $colour + +Creates a new image and completely fills it with the given colour. The +image is set to tiling mode. + +If <$width> and C<$height> are omitted, it creates a 1x1 image, which is +useful for solid backgrounds or for use in filtering effects. + +=cut + + sub solid($$;$) { + my $colour = pop; + + my $img = $self->new_img (urxvt::PictStandardARGB32, $_[0] || 1, $_[1] || 1); + $img->fill ($colour); $img } @@ -62,8 +100,46 @@ =head2 VARIABLES +The following functions provide variable data such as the terminal +window dimensions. Most of them make your expression sensitive to some +events, for example using C (terminal width) means your expression is +evaluated again when the terminal is resized. + =over 4 +=item TX + +=item TY + +Return the X and Y coordinates of the terminal window (the terminal +window is the full window by default, and the character area only when in +border-respect mode). + +Using these functions make your expression sensitive to window moves. + +These functions are mainly useful to align images to the root window. + +Example: load an image and align it so it looks as if anchored to the +background. + + move -TX, -TY, load "mybg.png" + +=item TW + +Return the width (C) and height (C) of the terminal window (the +terminal window is the full window by default, and the character area only +when in border-respect mode). + +Using these functions make your expression sensitive to window resizes. + +These functions are mainly useful to scale images, or to clip images to +the window size to conserve memory. + +Example: take the screen background, clip it to the window size, blur it a +bit, align it to the window position and use it as background. + + clip move -TX, -TY, blur 5, root + =cut sub TX() { $new->{position_sensitive} = 1; $x } @@ -71,6 +147,30 @@ sub TW() { $new->{size_sensitive} = 1; $w } sub TH() { $new->{size_sensitive} = 1; $h } +=item now + +Returns the current time as (fractional) seconds since the epoch. + +Using this expression does I make your expression sensitive to time, +but the next two functions do. + +=item again $seconds + +When this function is used the expression will be reevaluated again in +C<$seconds> seconds. + +Example: load some image and rotate it according to the time of day (as if it were +the hour pointer of a clock). update this image every minute. + + again 60; rotate TW, TH, 50, 50, (now % 86400) * -720 / 86400, scale load "myclock.png" + +=item counter $seconds + +Like C, but also returns an increasing counter value, starting at +0, which might be useful for some simple animation effects. + +=cut + sub now() { urxvt::NOW } sub again($) { @@ -79,7 +179,7 @@ sub counter($) { $new->{again} = $_[0]; - $bgdsl_self->{counter} + 0 + $self->{counter} + 0 } =back @@ -213,7 +313,7 @@ #TODO: maximise, maximise_fill? - sub scale($$$) { + sub scale($;$;$) { my $img = pop; @_ == 2 ? $img->scale ($_[0] * $img->w * 0.01, $_[1] * $img->h * 0.01) @@ -294,30 +394,28 @@ # evaluate the current bg expression sub recalculate { - my ($self) = @_; + my ($arg_self) = @_; # rate limit evaluation - if ($self->{next_refresh} > urxvt::NOW) { - $self->{next_refresh_timer} = urxvt::timer->new->after ($self->{next_refresh} - urxvt::NOW)->cb (sub { - $self->recalculate; + if ($arg_self->{next_refresh} > urxvt::NOW) { + $arg_self->{next_refresh_timer} = urxvt::timer->new->after ($arg_self->{next_refresh} - urxvt::NOW)->cb (sub { + $arg_self->recalculate; }); return; } - $self->{next_refresh} = urxvt::NOW + $MIN_INTERVAL; + $arg_self->{next_refresh} = urxvt::NOW + $MIN_INTERVAL; # set environment to evaluate user expression - local $bgdsl_self = $self; + local $self = $arg_self; local $old = $self->{state}; local $new = my $state = $self->{state} = {}; - my $border = 0; #d# - ($x, $y, $w, $h) = - $self->background_geometry ($border); + $self->background_geometry ($self->{border}); # evaluate user expression @@ -374,7 +472,7 @@ $img = $img->sub_rect (0, 0, $w, $h) if $img->w != $w || $img->h != $h; - $self->set_background ($img, $border); + $self->set_background ($img, $self->{border}); $self->scr_recolour (0); $self->want_refresh; } @@ -382,7 +480,11 @@ sub on_start { my ($self) = @_; - $self->set_expr (parse_expr $EXPR); + my $expr = $self->x_resource ("background.expr") + or return; + + $self->set_expr (parse_expr $expr); + $self->{border} = $self->x_resource_boolean ("background.border"); () }