bggen(l) MachTen Programmer’s Manual bggen(l)
NAME
bggen - generates colored backgrounds on X11 displays
SYNTAX
bggen [-d display] [-g geometry] [-G rptgeom] [-r rot]
[-a] [-w width] [-h height] [-b bits] <color-spec>
[<color-spec> ...]
DESCRIPTION
bggen is a program that generates a rectangular 24-bit
image, with a smooth vertical gradient between the listed
colors. (If you only specify one color, the image will be
a single solid color.) The top of the image will be in
color (r1,g1,b1), and the bottom of the image will be in
color (rn,gn,bn). Intermediate positions in the image are
interpolated between these colors. If you specify more
than 2 colors, the gradient passes through all the speci-
fied colors, in the order specified.
The ’-d’ option lets
you specify what display to connect
to. bggen only connects to the display to find out the
size of the screen (and hence, the default size for the
generated image).
The ’-g’ option lets
you control the size of the image, as
a standard X geometry specification. (ie, something like
"512x348")
The ’-G’ option lets
you control the tile size, as a stan-
dard X geometry specification. (ie, something like
"32x32") Normally, (if you don’t give a -G
option), the
gradient fills the entire image. If you specify a -G
option, the gradient will fill a portion of the image, and
that portion will be ’center-tiled’ to fill the
rest of
the image.
The ’-r’ option lets
you rotate the gradient counter-
clockwise by the specified number of degrees.
The ’-a’ option lets
you force bggen to generate an image
in PPM ’Ascii’ format, rather than in PPM
’raw’ format.
The ’-w’ and
’-h’ options also let you set the size of the
image. They are provided only for backward
compatibility.
The ’-b’ option
specifies the number of significant bits
in the (output) color specifications. It must range
between 1 and 8, inclusive. Use values less than 8 (the
default) to limit color use by increasing the color granu-
larity. Since XV can do this sort of thing better, this
is of dubious value.
A <color-spec> can be
three integers separated by spaces,
forming an R,G,B triple ("0 255 0"). The values
should be
between 0 and 255.
A <color-spec> can also be
a standard X color specifica-
tion by name ("green") or value
("#00ff00"). This is
decidedly easier, and the ’three integer’ method
remains
mainly for backward compatibility. One note: the
’#’
character is treated specially by many shells, and should
probably be protected by putting a ’´ character
in front
of it, or wrapping the entire value with a pair of single-
quotes.
bggen doesn’t actually
affect your background directly.
bggen merely generates a PPM (Portable Pixmap Format)
datafile and dumps it to ’stdout’. It’s up
to some other
program (such as XV) to read this file and display it.
To use bggen, you should pipe
its output into an XV com-
mand, such as: "xv -root -quit -"
TRY THESE
Light Blue to Dark Blue
bggen 100 100 255 0 0 100 | xv -root -quit -
RGB Rainbow
bggen red green blue | xv -root -quit -
Green Cylinders
bggen black green black -h 128 | xv -root -quit -
Blue to Magenta
bggen blue magenta | xv -root -quit -
Full Rainbow
bggen black red yellow green blue purple black | xv -root
-quit -
Repeating Rainbow
bggen red yellow green blue purple red -h 256 | xv -root
-quit -
Green Tiles
bggen green black -r 30 -g 32x32 | xv -root -quit -
Red Balls
bggen red black -r 45 -g 32x32 | xv -root -quit -rmode 3 -
Red+Yellow Diamonds
bggen red yellow -r 45 -g 32x32 | xv -root -quit -rmode 3
-
AUTHOR
John Bradley - bradley@dccs.upenn.edu
MachTen 2