NAME xart - easy to use still-image pixel-based paint program for X. PAGEDATE 19980404 SYNOPSIS xart [ -size " WIDTH" x HEIGHT ] [ -12 ] [ -24 ] [ -rcFile " file"] [ -popped ] [ -nowarn ] [ -help ] [ filenames "... ] DESCRIPTION xart is a color image editing tool which features most basic paint program options, as well as image processing algorithms, rgb reductions, and the quill tool does mouse motion smoothing, which should be a big advantage for freehand sketching. xart allows for the editing of multiple images simultaneously and supports various formats, including PPM, XBM, TIFF, JPEG, GIF etc. It is hoped that xart will be found to be highly self-documenting. xart is derived from XPaint. The functionality of xart is divided into a toolbox area for selecting the current paint operation and canvas windows for modifying/creating images. There are also zoom windows, a brush shape window, and various transient windows. Each canvas window has access to its own color palette and set of patterns, although the paint operation in use is globally selected for all windows. xart runs on a variety of X displays. It should be noted that saving images will adapt them to the current display type (i.e. a color image loaded on a greyscale screen will be saved as a grey image). There is also an extensive on-line help system available, the text of which is appended to this manpage. xart has no hooks for animations, does not do channels or layers, does not have "marching ants", and there is no way to blend pixels from two images. xart will not preserve image information greater than the current X display, since xart derives much of it's functionality from X itself. I consider a "translucent paste" of some kind to be xart's most needed addition. xart's other shortcomings don't bother me as much (r.h.). OPTIONS In addition to being able to specify image files to open, the following options are available on the command line: -size "w" x h Default width and height for new images. -12 Use a 12 bit PseudoColor visual. -24 Use a 24 bit TrueColor visual. -rcFile " file" Load file instead of the default RC file specified at compile time. See also the section RC FILE FORMAT below. -popped Popup an empty canvas on startup. -nowarn Do not emit warnings about possible data loss due to different depth of display and image. This is a good one to add to an alias. -help Give a summary of the available options. TOOLBOX The toolbox window is displayed when xart is started. The toolbox is used to select an operation which can then be applied to any image area presented (painting window, fat bits, pattern editor, etc.). The window has a selection of painting operations (as icons) and several pull down menus. PAINTING WINDOW The painting window holds a canvas area for painting the displayed image, menus for performing operations on this image, and primary and secondary color/pattern palettes along with buttons for adding to these. RC FILE FORMAT The RC file can be used to customize the color/pattern palettes. If a system-wide RC file is specified with the -rcFile option, that file is read first; otherwise, the defaults specified at compile time are loaded. Then, the file .XPaintrc is searched for first in the user's home directory and then in the current directory. Any settings specified here are appended to the one in the system-wide RC file. Any time a new canvas is created, the .XPaintrc file is read again if it has changed. The RC file can contain any of the following entries, in any order: # or ! at the start of a line initiates a comment. The rest of the line is ignored. solid " color" where color is a color in standard X11 format (eg. GoldenRod1 , #a2b5cd - see also X(1)) adds a solid color to the palette. "pattern BeginData" " bitmap " EndData where bitmap is a bitmap specification in XBM or XPM format, adds a fill pattern to the palette. Note that there must be a newline after BeginData , and that EndData must appear on a line by itself. pattern " filename" where filename is a file containing a bitmap in XBM or XPM format, also adds a pattern to the palette. The squares in the palette have a default size of 12 by 12 pixels. This can be changed by setting the XPaint.patternsize resource to a number between 4 and 64. ( Maybe. There's also a note on this in the DefaultRC file. r.h.) AUTHORS David Koblas, koblas@netcom.com. I am interested in how this program is used, if you find any bugs, I'll fix them. If you notice any rough spots, or think of some way in which it could be better, feel free to drop me a message. ( Koblas seems to have lost interest. Hohensee, 1998) Torsten Martinsen, torsten@danbbs.dk, is to blame for any (mis)features added in XPaint release 2.2 and following releases. Many people, too numerous to mention, have contributed to the development of XPaint. See the file Doc/CHANGES in the source distribution for details. #BEGIN introduction "Introduction" "$Id: Help.txt,v 1.10 1997/05/02 05:54:04 torsten Exp $" This is the help text for xart 19980404 Rick Hohensee, humbubba@cqi.com re-worked XPaint 2.5.1 into xart. ############################################ From here down is the text file for the xart on-line help features, as of the above PAGEDATE. xart is a color image-editing tool that features many standard paint program options and some unique features. xart is compact, versatile, uses only standard X libraries, works well with X, and reuse constraints are limited to simple authorship aknowledgement. It allows for the editing of multiple images simultaneously, pasting imported images, and supports various formats including PPM, XBM, TIFF, jpeg, GIF etc. xart is derived from Xpaint 2.5.1. xart is mouse driven. The main window of xart is the toolbox. It will have whatever widgets your window manager wraps it in. It consists of a menu bar and a field of icons. The icons in the scrollable area are the operators. They do the painting actions. You need something to paint ON. This is what the canvas item in the menu bar is for. When you load or initiate an image, you get a canvas window in addition to the toolbox window. I usually keep the toolbox just peeking over the canvas window. The canvas window is where many powerful features live, such as various filters, pattern grab and so on. Now that we have a canvas, we need to know how to use the various tools. The line menu bar item determines the line width for the tools that use the XDrawLine call, notably the pencil, box, oval and arc tools. The font toolbox menu bar is for the text tool. It gives you a choice of fonts that you're very likely to have, and an option to browse all the fonts your X server knows about. So much for the menu bar intro. The colored icons are representative of various hand-painting operators. Most icons were painted in part using the very tool they represent. These operators/tools are the methods for correlating mouse motion to changes in an image. That is, these are the freehand tools. Left-click ( button 1) on a tool icon. The icon border turns black. This is now the active tool for all open canvases. Right-click ( button 3) on a tool icon. You usually get a menu, which may just be the tool name and a tool-specific help prompt, or may have several options, which may each have options also. Make sure you try all 3 mouse buttons with the various tools, since some useful stuff is on the 2nd and third buttons, e.g. "remove pattern". There are more action widgets in the canvas window, and in windows that may pop up from them. The set of "things" these various actions can operate on includes canvases, selected "regions" within a canvas, the "clipboard" for cutting and pasting regions, the palette of each canvas, the current foreground and background of each palette, and the canvas background color. "pattern grab" can grab from anywhere on the screen. xart's concept of an image is limited by the current X display. xart doesn't do channels, layers or separations. xart does do rgb reductions. xart uses the TIFF image format internally, and patterns and brushes are XPMs. xart runs on a variety of X display types, or visuals. Saving images will adapt them to the current visual (e.g., a color image loaded on a greyscale screen will be saved as a grey image). This can result in the loss of data; see the Possible Data Loss section for details. #BEGIN data_loss "Possible Data Loss" xart uses the current X display format for storing image info while editing; the original image information is thrown away. This means that, in general, there will be image degradation if the X visual mode in use has lower color resolution than the original image. Also note that any ancillary information associated with the original image (embedded comments, time stamp, copyright, etc.) will always be lost. #BEGIN command "Command Line Options" xart [-popped] [-nowarn] [-size WIDTHxHEIGHT] [-rcFile FILE] [-12] [-24] [<files>...]", #NL - size default width and height for new images #NL - 12 use a 12-bit PseudoColor visual #NL - 24 use a 24-bit TrueColor visual #NL - popped pop up an empty canvas on startup #NL - nowarn skip data-loss warnings #NL -rcFile use FILE instead of default .XPaintrc #NL <files> image filenames to open #NL #BEGIN config "Configuring xart" See the TOUR file in the source directory. Quill get's it's initial palette from ~/.XPaintrc and from the compiled-in palette, which is file DefaultRC in the source. X resources, such as menu label text, is from the app-defaults/XPaint file, ~/.Xdefaults, and/or the XPaint.ad.in file in the source. #BEGIN toolbox "Toolbox" The toolbox is used to set those options that are applicable to all canvases opened by this instance of xart. The current tool, brush, line width and font are global (common to all open canvases). #PUSH #BEGIN tool_file "Canvas Menu" The canvas menu is used to create a new canvas or load an image from a file. New Canvas #NL Create a new blank canvas (default size: #NL 640x480). See "Command Line Options" for #NL changing the default size. New with Size... #NL Create a new canvas with the specified #NL dimensions. Open... #NL Open an image file for painting. Images can #NL be opened in a variety of formats. If none #NL of the specific formats is selected, xart #NL will attempt to perform a "Best Guess" as to #NL the image format. Unknown formats will result #NL in an error message. Load Clipboard... #NL Open an image file into the xart clipboard #NL for pasting. Images that have been saved in #NL a format supporting odd-shaped regions will be #NL loaded as they were selected, otherwise all #NL images are rectangular. See "Paste" and #NL "Save Region..." under the Edit and File menus #NL of a canvas window for more information. *POOF* #NL Exit xart, closing all windows. There will be an "are you sure?" if necessary. #BEGIN tool_line "Line Menu" The line menu sets the value of the line width. This value is used by all pencil family operations, including the borders of boxes, ovals and polygons. #BEGIN tool_font "Font Menu" This menu selects the current font to use for the text operation. There are a few specific fonts choices listed, but most of the fonts your X knows about are available through the font browser. The browser may not see all of the fonts you have installed, if they do not have canonical 13-part names. The X cursor font is an example, but is included in the top window font menu. Note: Changing a font while inserting will not allow backspacing over text in a previous font. See "Font Browser" for more information on its use. #PUSH #BEGIN font_browser "Font Browser" The font browser is designed to allow any available font to be used for painting with the text operation. A font is selected by choosing an item from each of the given lists until the font is displayed in the "selection" area. As items are selected, all lists will adjust to reflect existing fonts with the selected characteristics. Clicking in the blank area of a item list will reset that list to all available options (i.e., unselect the current one). The xart font browser supersedes xfontsel, since xfontsel has a dysfunctional file browser. xart even has a selection field for pasting a canonical fontname to some other text destination. If the X server supports variable sized fonts, the point size list will contain a "0" entry, which will use the value specified in the "Point Size" field. Getting an arbitrary point size working is tricky, but does work. Remember to keep the cursor over the canvas when trying to type. #POP #BEGIN tools "Painting Tools" The painting tool icons set the current painting operation for all canvases. Operations are selected with mouse button one. Pressing mouse button three while over any of the icons will bring up a menu of options available for that tool. Some icons also allow double-clicking as a faster method of bringing up style options. BRUSHES...... The brush family of operations is brush, erase and smear. They use the current brush for the shape of thier action area. The brush tool is the only tool with transparency, and that is only with solid colors. FILLS...... The fill operations all have the same area control options, as affected by thier menus and the 'select range' facility on each canvas window. Plain fill can fill using a pattern. SELECTIONS...... There are 3 types of selection, square/oval, polygon and freehand. They are the tool icons with Guy's face. Both may be sub- selected to or from color ranges in a manner similar to fills. Other tools may not be active when a selection is, so actions on selections are limited to filters and movements/resizes of the selection. The 'all of all' item in the clips menu on the canvas window selects every pixel of the canvas. PENCILS...... The shape drawing tools, arc, rays, dot pencil, straight, and pencil all use the line width specification from the line menu on the tool window. Lines are drawn using the Button 1 palette color or pattern, and filled items such as filled ovals are filled with the active secondary palette selection. OTHER...... The text, quill, dyn-pencil and spray tools is each a tool family unto itself, with it's own unique options. See the specific paint operation for more information. #PUSH #BEGIN arc "Arc" The arc operation paints an arc between two selected points in the primary color/pattern, using the current line width. Arcs are generally a quarter of an ellipse, but may be restricted to a quatrer-circle by pressing the shift key while painting. The different quadrants of the ellipse may be obtained by dragging out the arc in various directions. See "Line Menu" under the toolbox for more information about line width. #BEGIN box "Boxes" The box operations paint either rectangles or squares using the current line width. Pressing shift while moving the mouse after selecting the first point will constrain the box to a square. Selecting the 'pull from center' option from the menu found by pressing button three on the icon will define the first point as the center of the square with the second point being on the perimeter. Filled boxes are painted in the primary color/pattern and filled with the secondary color/pattern for the canvas. See "Line Menu" under the toolbox for more information about line width. #BEGIN brush "Brush" The brush operation uses the current brush to paint on the canvas(es). Painting is accomplished by holding down the mouse button and moving the mouse in the canvas area. Button one paints in the selected primary color/pattern, while button two uses the secondary one. If the 'transparent' option is selected from the menu found by pressing button three on the icon, the selected color is blended with the color already on the canvas. You can change the opacity of the brush using the 'Parameters..' option. Zero percent means that the canvas is not changed at all, while 100 percent gives the same result as using a non-transparent brush. Transparency only works with solid colors. The current brush style may be changed through the brush chooser available on the button three menu for either the brush or erase operation icons. #BEGIN cline "Connected Line" The connected line operation paints a series of straight lines connected at selected vertices. Each new vertex is selected using the first mouse button. The second mouse button ends this operation, without forming a new vertex. All painting is done in the primary color/pattern using the currently defined line width. See "Line Menu" under the toolbox for more information about line width. #BEGIN dotPencil "Dot Pencil" The dot pencil operation paints a series of dots on the canvas, following the cursor while the mouse button is pressed. Button one paints in the primary color/pattern, button two the secondary color/pattern. See "Pencil" for painting connected lines. #BEGIN erase "Erase" The erase operation is designed to either erase a section of the painting to the set background color for the canvas or to revert the erased area to the originally loaded image. (Note: This is not the last saved image!) The eraser is the shape of the current brush, and the brush selection window is accessible through the menu found by clicking mouse button three on either the erase or brush icons. See help on the "Brush" or on "Change Background..." under the Image menu of the Painting Window for more information. #BEGIN fill "Fill" The fill operation will paint an area around a selected pixel the current primary or secondary color/pattern (based on which mouse button used). The area is determined by matching adjacent pixel values until a variation is found. Diagonal pixels are not considered adjacent. Selecting the 'all of clicked color' option from the menu found by pressing button three on the icon will enter Change Mode. In this mode, all pixels in the image that have the same color as the selected one will be changed to the primary or secondary color. Selecting the 'all within variance' option causes xart to consider not only pixels of the exact same color as the selected one, but also pixels within the variance (delta) set from the color selector found under the 'Select Range...' popup menu item. #BEGIN tfill "Gradient Fill" The gradient fill operation will paint an area around a selected pixel with a range of colors obtained by mixing the primary and secondary colors. The area is determined by matching adjacent pixel values until a variation is found. Diagonal pixels are not considered adjacent. The 'Contiguous', 'All of clicked color' and 'all within variance' options in the popup menu work the same as for the ordinary fill operation. Linear, Radial, Conical or Square gradient fill can be selected by clicking mouse button three on the Gradient Fill icon. Also, several parameters can be adjusted using the 'Parameters' item here: Angle #NL Defines the tilting of the pattern. Valid range is #NL -360 to 360 degrees. Pad If this value is positive, the area where one color #NL blends into the other will be compressed, yielding #NL a sharper transition. If negative, the transition #NL will be smoother. Valid range is -49 % to 49 %. Horizontal/Vertical offset #NL Defines the center of the pattern. Valid range is #NL -100 % to 100 %. #NL This parameter has no effect for the Linear pattern. Steps #NL The maximum number of colors that will be used #NL for the transition from one color to the other. #NL For non-TrueColor displays, it can be useful to #NL limit the number of colors used to avoid running #NL out of palette entries. Very small numbers can #NL also be used to get a 'blocky' effect. Valid range #NL is 1 trough 300. #BEGIN ffill "Fractal Fill" The fractal fill operation will paint an area around a selected pixel with a range of colors obtained by mixing the primary and secondary colors. The area is determined by matching adjacent pixel values until a variation is found. Diagonal pixels are not considered adjacent. The 'Contiguous', 'all of clicked color' and 'all within variance' options in the popup menu work the same as for the ordinary fill operation. Several different fractal patterns can be selected by clicking mouse button three on the Fractal Fill icon. #BEGIN quill "the quill tool" Quill does mouse velocity emulation in near- realtime. It draws curves between mouse location sample points very similar to what the actual path of the mouse must have been. It has several nibs, each of which can be truncated to several sizes. It doesn't do patterns or transparent. Quill strokes are usually easy to fill though. Some filtering with edge-smooth or de-speckle may be helpful. #BEGIN smear "Smear" The smear operation paints each pixel under the brush the average color of all the pixels. Smearing is done by holding down the mouse button and moving the mouse in the canvas area. The current brush style may be changed through the brush chooser available on the button three menu. #BEGIN line "Line" The 'straight' operation paints a straight line in the primary color/pattern between two selected points on the canvas, using the global line width. This works nicely with the snap feature for rectilinear work, like diagrams. See "Line Menu" under the toolbox for more information about line width. Lines may also be restricted to increments of 45 degrees (i.e., horizontal, vertical, or diagonal) by holding down the shift key while painting. #BEGIN oval "Ovals" The oval operations paint either circles or ovals using the current line width. Ovals/circles are painted by selecting two points that inherently define a box around the area for the oval. Pressing shift while moving the mouse will constrain the oval to a circle. Selecting the 'pull from center' option from the menu found by pressing button three on the icon will define the first point as the center of the circle with the second point being the radius. Filled ovals and circles are painted in the primary color/pattern and filled with the secondary color/pattern for the canvas. The oval tool leaves a rectangular area around the drawn oval with the charachteristics of a selection. This may confuse you when working with selections. See "Line Menu" under the toolbox for more information about line width. #BEGIN pencil "Pencil" The pencil operation paints a connected line on the canvas, following the cursor while the mouse button is pressed. The global line width is used to determine the width of this line. The drawn line may show visible straight line segments. The quill tool is an alternative to this tool. Button one paints in the primary color/pattern, button two the secondary color/pattern. See "Line Menu" under the toolbox for more information about line width. #BEGIN poly "Polygons" Polygon operations paint polygons as defined by a series of straight lines between selected vertices. Each new vertex is selected using the first mouse button. Ending this operation (done through pressing the second mouse button) does not create a new vertex and results in the last created vertex being joined to the first. All painting is done in the primary color/pattern using the currently defined line width. Filled polygons are filled in the secondary color/pattern. See "Line Menu" under the toolbox for more information about line width. #BEGIN ray "Ray" The ray operation paints rays from the first selected point to all subsequent points in the primary color/pattern. Button two ends this operation without selecting a new ray point. Rays may also be restricted to slopes based on a 45 degree increment (i.e., horizontal, vertical, or diagonals) by pressing the shift key while painting. The width of the rays is determined by the global value for the line width, set via the "Line" menu. See "Line Menu" under the toolbox for more information about line width. #BEGIN select "Select Regions" There are three operations for selecting regions: Select Box, Lasso and Select Polygon. "Select Box" will select a rectangular or ellipse-shaped region (holding down shift while pressing the mouse button with constrain the region to a square or a circle, respectively). "Lasso" selects an arbitrary region. "Select Polygon" selects a region bounded by straight lines. The three possible modes used by these operations are set by the options on the button three menu for either icon: All Colors Select the entire region. #NL Omit Color Range Select the region, excluding the #NL specified range of colors. #NL Only Color Range Select only the specified color range #NL in the region. #NL See "Range Selection" for more information on choosing a range of colors for these operations. Operations that may be performed on selected regions include the ability to move and resize them. Resizing may be performed by dragging the black squares showing the overall borders of the selection, like in xv. Holding shift down during resizing will constrain the region to its original aspect ratio. Holding shift down during moving will constrain movement to horizontal or vertical. Note that moving a region will result in the original location being painted in the current background color. See "Background Color..." under the Resize/zoom/dbgc menu of the Paint Window for more information. You can also use the cursor keys to move the region one pixel at a time (hold down the Control key to move in larger steps). This is handy to see a complex selection, since oblique selections do not have highlighted borders, just the black squares at the overall rectangular limits of the selection area. Selections can also be loaded and saved, making the possibilities rather limitless. See the clips/undo menu on the canvas windows. If you're having trouble doing a color-specific selection, try a narrow color _range_ selection. #PUSH #BEGIN range_select "Range Selection" This window, which pops up when you click the "Select Color Range" button next to the palettes, is designed for selecting a range of colors for use with the select region operations. The color range is determined by setting a base color and the amount of variance in each of the RGB values around this color. Colors are considered in this range if they match a value based on the base color +/- the given variance. Default base color is white. The "Pixel Delta" button allows the user to choose another color that will be used to calculate the variance from the base color. More information on colors and the use of the color wheel may be found under the "Pattern Editor" on the "Painting Window". #POP #BEGIN blob "Shape" Shape operations allow the user to draw closed objects with a pencil-like operation. When the mouse button is released, the last drawn point is connected to the starting point. Painting can either be done in the primary color/pattern with button one or in the secondary color/pattern with button two. Filled shapes are filled in the other palette color/pattern. Border width is determined by the current setting for line width. See "Line Menu" under the toolbox for more information about line width. #BEGIN spray "Spray" The spray operation is designed to emulate a spray can. It will paint a random set of dots within a given radius. It is possible to change the attributes of the spray operation to achieve the desired effect. There are three parameters that will modify the configuration of the spray tool: #NL radius how large of a circle to fill #NL density number of dots in the given area #NL rate speed to fill the area in tenths of a second Additionally, it is possible to change the distribution of the dots to be either even or gaussian (usually only noticeable at large radii). These options are found in the menu brought up by clicking button three on the spray icon. As with many other operations, the spray operation can make use of either the primary or secondary color/pattern based on which button (one or two, respectively) is held down while painting on the canvas. #BEGIN text "Text" The text operation allows for typing in the currently selected font. Pressing mouse button two in the canvas area while inserting text will paste text from the X clipboard at the current insertion point. See the "Font Menu" for information on changing the selected font. Changing a font while inserting will not allow backspacing over text in a previous font. The mouse cursor must be in the canvas for typing of a font to occur. Hitting the return key with do a "carriage return" on the image, and backspace only works on the current line. #POP #POP #BEGIN canvas "Canvas Window" Several canvases may be opened by an instance of xart. An instance of xart has one tool window, but has a canvas window for each active canvas. xart may have one open brush shape window also. Each canvas window has 3 main sections, a menu bar at the top, a painting area for the canvas and optional zoom scope, and a palette area. The size of the canvas window and the size of the painting area and palette area are quite flexible, depending on your X window manager. The canvas window as a whole is a pane widget, and the border between the canvas area and the palette area has a small grip widget for moving the boundary. The canvas window menu bar has the controls for....... canvas, palette and clipboard loading/saving cut/paste of clippings movements of selected regions image filters such as "blur" The red/green/blue reductions zoom window and image resizing snap-to-grid paint input x-y constraint the default background color undo #PUSH #BEGIN fileMenu "storage Menu" The storge menu on the painting window is for saving information associated with the image displayed on the current paint canvas. xart runs on a variety of displays. Saving images will adapt them to the current display type (i.e., a color image loaded on a greyscale screen will be saved as a grey image). See "Image Formats" for a description of the image formats usable by xart. Save #NL Save the current image with the original #NL filename and format. If this is a new #NL image, perform the "Save As" operation. Save As #NL Save the current image with the specified #NL filename and format (default is TIFF). Save Region... #NL Save the selected region, in the original #NL form that it was selected (width, height and #NL rotation). Odd-shaped regions will be saved #NL as rectangles filled with the background #NL color. If the output format supports image #NL masks (e.g., TIFF, PNG, XPM), then this #NL information will also be saved. See "Load #NL Clipboard..." under the toolbox file menu #NL for more information about odd-shaped #NL images. Save Palette... #NL Save the current palette. See "Palette #NL Area" for more information on how #NL patterns are loaded. Revert to as-loaded... #NL Reloads the last saved image. This is #NL equivalent to closing without saving #NL and then opening the original file. #NL You are asked for confirmation. If #NL the image has not been changed since #NL the last save, this operation does #NL nothing. quit canvas #NL Close the current painting window, saving #NL the image if desired. #BEGIN editMenu "clip Menu" The clip menu provides for a set of operations that interact with the current selection and the paint clipboard. The six first items in this menu are also accessible through button three on the painting canvas. The clipboard is an off-screen image that is loaded either from a selected region via these operations or from a file. See "Load Clipboard..." on the toolbox "Canvas" menu for more information about loading images from a file and the "bg" menu for more information on the background color. Undo #NL Reverse the last performed operation. #NL Multiple undos are possible; see 'Undo Levels..' #NL in the 'Image' menu. Default is 4. They use memory. #NL If a region is selected, and you have not moved #NL or resized it, the last region operation is undone. #NL Redo #NL Cancel the effect of the last undo. #NL This must be done immediately after an undo or #NL redo (before drawing anything new on the canvas). #NL Cut #NL Load the originally selected region into both #NL the xart and X server clipboards and #NL change the area on the screen to the background #NL color. Copy #NL Load the originally selected region into the #NL xart and X server clipboards. Paste #NL Place the image in the clipboard onto the #NL canvas at the last position where button one #NL or two was pressed. Images are first searched #NL for in the X server clipboard and then the #NL internal xart clipboard. Clear #NL Remove the current selection from the paint #NL canvas. copy/paste #NL Perform both the copy and paste operations in one. #BEGIN regionMenu "Move Menu" The move menu provides operations that can be applied to the currently selected region. See the "Select Regions" item under the toolbox Painting tools for information on how to select regions. Note: the select all item is now here. It does not honor the color range parameter for selection, and is therefor re-named all-all. Note: The 'undo' operation found under the Edit menu does not work on these operations! Flip Horizontal #NL Flip the current region horizontally. Flip vertical #NL Flip the current region vertically. Rotate By #NL Rotate... #NL Both of these operations allow for rotating #NL the current image by a specified number of #NL degrees. Rotation may also be done #NL by pressing button two on the selection. #NL Pressing the Shift button while doing this #NL constrains the rotation to multiples of #NL 15 degrees. Crop to region... #NL Discard all portions of the image outside the region. #NL This operation cannot be undone; therefore, you are #NL required to confirm it. Tilt ........... tilt is an add-in, along with fractal fill. I haven't figured out how to use it yet ;o) (r.h.) Reset #NL Return the current image to its original #NL size and orientation. Note: None of the #NL image processing operations will be undone. #BEGIN filterMenu "Filters Menu" The filters menu provides a set of image processing operations that can be applied to the currently selected region. See the "Select Regions" item under the toolbox Painting tools for information on how to select regions. Repeat prev. #NL This applies the last filter you used again, without #NL querying for any parameters. Invert #NL Inverts the colors of the selected region #NL (e.g., black to white). Sharpen #NL Applies an image processing algorithm in an #NL attempt to increase the detail on the #NL selected region. blur #NL Attempts to blend the colors of the region #NL by averaging the pixel's color values with #NL those of its neighbors. Edge Smooth #NL Similar to blur, but avoids smearing edges #NL by applying a more sophisticated algorithm. #NL The effect is less pronounced than for blur. Despeckle... Tries to remove scanning artifacts etc. by replacing each pixel by the median of the pixels inside the n x n mask centered around that pixel. You are queried for the mask size; this must be odd and larger than 1. Edge Detect Performs an image processing edge detection. A gaudy effect. Emboss #NL Converts the selected region to a grey image #NL that is highlighted such that the details #NL appear to stand out from the screen. Oil paint... #NL Does an effect similar to a paint-by-numbers painting. #NL You are queried for the mask size, which must #NL be an odd integer. Recommended values range #NL from 3 to 15. Higher values result in a more #NL pronounced effect. Add Noise... #NL Modify the color of each pixel randomly. #NL You are queried for the maximum #NL noise value. Recommended values range from #NL 5 to 50. Higher values result in a more #NL pronounced effect. 255 is total randomness. Spread... #NL This operation swaps each pixel in the region with #NL a random pixel near it, giving an effect similar to #NL frosted glass. You are queried for the maximum #NL distance. Good values range from 1 to 10. #NL You can also specify how many iterations you want #NL performed. This is equivalent to manually selecting #NL the operation that many times. Pixelize... #NL Makes the image look low resolution. This works by #NL replacing each 'megapixel' with the average color #NL within that region. You are queried for the megapixel #NL size; this can be specified as square (e.g., '5') or #NL rectangular (e.g., '2x4'). Blend #NL This operation colors each pixel in the region #NL with a weighted average of the center color and #NL the color on the edge that intersects a line drawn #NL from the center to the pixel in question. #NL The result is to 'blend the region out of existence'. This seems geared to small regions, or very wild effects. It seems to find the edges or rectangles OK, but not e.g. ovals. Solarize... #NL Inverts pixels with a value larger than the #NL specified threshold. This simulates what happens #NL to a photographic film that is exposed to light #NL during development. Works best for greyscale #NL images. You are queried for the threshold (1-99 %). Contrast #NL Normalizes the contrast by forcing the lightest pixels #NL to white, the darkest pixels to black, and linearly #NL rescaling the ones in between. #NL You are queried for Black and White levels in %. #NL Pixels darker than the Black level will become black, #NL and pixels brighter than the White level will become #NL white. The pixels in between will be rescaled linearly. #NL '100 %' refers to the brightest pixel in the image. Quantize Colors... #NL Reduces the number of colors in the image. The #NL algorithm selects the set of colors that gives #NL the best result and then replaces the original #NL colors with the best match in the new color set. #NL You can choose the number of colors to use, #NL from 2 to 256. Turn into Greyscale #NL Converts all colors in the image to greyscale. Abuser is a clone of "sharpen", with some junk in the convolve matrix. It is provided if you want to play with the sourcecode without messing up the legit filters or having to write the menu hooks. In the source directory, just goof up the matrix in iprocess.c, make, and see what you get. Other filters have convolve matrices and so are examples. #BEGIN rgb "red/green/blue reductions" The red, green, or blue components of a selected area can be reduced by 3, 50 or 100 percent via this menu. Yes, white with no red is turquoise (cyan, actually). By the same token, these have no effect on black pixels. A "boost" option for these is a "TO DO". Go for it. #BEGIN imageMenu "size Menu" Items in the size menu change the dimensions of the canvas, and change how the canvas is displayed. Scope #NL Brings up the Fat Bits editor, which allows #NL for editing an enlarged area of the current #NL image without having to enlarge the entire #NL image. A small scope border can be dragged around the canvas, and an enlarged window of the scope area is displayed. Black Grid #NL Turns on and off a visible black grid #NL between the original pixels on images with a #NL scale greater than 1 (i.e., zoomed). This #NL grid is only for painting purposes. It does #NL not affect the actual image. Snap #NL Turns on/off restriction of the current x #NL and y position for most operations to an #NL invisible grid. This is great for schematics, diagrams and such. It causes some other funny effects, like sinusoids with the quill tool, brushes being centered on the grid points, etc.. Snap Spacing... #NL Sets the distance between points on the #NL invisible snap grid. Change Background color... #NL This operation changes the background color #NL for the current image (default color is #NL white). This is only used when a region is #NL erased or cut from the current image and #NL when odd-shaped regions are saved. See #NL "Color Wheel" under the "Pattern Editor" for #NL more information on selecting a color. Change Size... #NL Changes the size of the current canvas by #NL cutting away or adding area on the right and #NL lower sides. This operation affects #NL the actual image size. Undo Levels ( now in the UN menu)... #NL Changes the number of consecutive changes #NL that can be undone or redone. Note that each #NL undo level uses as much memory as the image #NL itself, so large numbers can use up a lot of #NL memory. Autocrop... #NL Changes the size of the current canvas by #NL cutting away any borders. The border color #NL is defined as the color common to at least #NL two corners. If no two corners have the same #NL color, nothing is done. #NL This operation is not reversible and #NL affects the actual image size. #NL Change Zoom... #NL Enlarges the working image by the specified #NL scale. This does not affect the size of the #NL image for saving, etc. There is only zoom "in". Scope might be better. #BEGIN patBox "Palette Area" There are 4 command buttons and a palette below the painting area. Commands allow picking a color or pattern from anywhere on the screen, and for modifying the color range of fills and selections. The palette has pots of colors and patterns. Solid color pots have colored borders. All pots are a button and a side button, which select the pot for button 1 and/or button 3, and for the interiors of filled shapes, such as the filled oval tool. Colors and patterns are loaded from information merged from the following files each time a canvas is created: #NL .XPaintrc in the user's home directory #NL .XPaintrc in the current directory A quick method for adding a new color is found by using the "pick from screen" button. This button allows the user to select any color visible on the X screen and will either locate it in the current palette or add it. Once the color is found in the palette, it is selected. If the color is already in the palette no new pot is created. This will happen a lot at low bitplane depths. All of the patterns and colors can be saved with the "Save Palette..." item in the file menu. #PUSH #BEGIN pattern "Pattern Editor" The pattern editor creates new patterns or modifies existing ones for use on the painting canvas. It is a paint window unto itself. The only way to select the painting color in this window is with the "pick" widget, but all the painting tools are available. The window contains the current pattern and (depending on display type) the current colormap and a color selection area. Patterns are by default 24x24 pixels in size, but may be set to any size up to 128x128 through the "Size" menu. The other menus available provide similar functionality to those in the paint window and pattern editing uses the normal paint operations. xart provides several default patterns of size 1xN or Nx1, which gives vertical or horizontal colorbars without using a huge amount of data. Patterns may be individually saved through the "Save As" option in the "load/save" menu of the pattern edit window, or saved with the palette. The pattern edit window is reached by right-clicking on a pattern. See "Save Palette..." under the Paint Window. When loading an individual pattern, only the portion of the pattern that fits in the pattern area will be included. The "Grab" button allows the user to select a portion of the current screen to fill the pattern area. #PUSH #BEGIN colormap "Colormap Area" When using a colormapped display, selecting a colormap entry will allow the user to change the value of that entry. This will change all pixels on the canvas that share this colormap index. The "pick from screen" button allows the user to select any color available on the screen and will locate the colormap entry for this color value. Note: Manipulating colormap entries effects the canvas immediately and does not revert when "Cancel" is chosen. #BEGIN colorwheel "Color Wheel" The xart color selection allows access to both the HSV or RGB color space models. The color wheel along with the value slider represents HSV, while the red, green, and blue sliders are for manipulating the color in an RGB space. Modifications in either of these color spaces will effect the other. Colors can be selected on the color wheel by using the mouse to drag the selection circle or to click on a desired color. Changes to value will determine the brightness of the chosen color. Colors can also be modified through the red, green, or blue sliders or by entering values in the text fields. The "pick" button will set the current color by allowing the user to select any color on the screen. The exact color will be determined using the colormap of the selected window. #POP #POP #POP #BEGIN fileformat "Image Formats" xart can support a variety of image file formats, based on library availability at compile time. Some of these formats may not be accessible in the current running version. The table below provides a short summary of the features of each image format and support provided by xart. Note that not all formats are supported for both read and write operations. Color depth is given in terms of the number of bits used to store the colors in the image. This means that a color depth of 1-bit can only store black/white images, while 24-bit color formats can store images containing up to 2**24 (or approx. 16 million) colors. Regardless of the image format, saved images always reflect the ability of current display type (i.e., a color image loaded on a greyscale screen will be saved as a grey image). See the Possible Data Loss section for more details. The image mask feature of an image format provides the ability to save/load odd-shaped regions (i.e., regions are not required to be rectangular and may have "holes" in them). See "Save Region" and "Load Clipboard..." for more information. Detailed information about each format is at the end of this section. Color Image #NL Read Write depth mask #NL GIF yes yes 8-bit no #NL JPEG yes yes 24-bit no #NL PNG yes yes 8, 24-bit yes #NL PPM yes yes 24-bit no #NL PS no yes 24-bit no #NL SGI yes yes 24-bit no #NL TIFF yes yes 8, 24-bit yes #NL XBM yes yes 1-bit no #NL XPM yes yes 8-bit yes #NL XWD yes yes 24-bit no GIF - Graphics Interchange Format #NL A popular image format used across a variety #NL of platforms, including PCs. JPEG - Joint Photographic Experts Group Format #NL A standardized, lossy format for storing #NL compressed color and greyscale images #NL of natural scenes. PNG - Portable Network Graphics Format #NL A new format designed to replace GIF and, #NL to some extent, TIFF. It has a better #NL compression engine than either GIF or TIFF #NL and is a lossless format (unlike JPEG). PPM - Portable PixMap Format #NL Image format provided by the PBMPlus/NetPBM #NL toolkit that allows for converting to a wide variety #NL of other formats. PS - PostScript Format #NL PostScript images are normally used by most #NL printers and text-processing packages. SGI - Silicon Graphics, Inc., Format #NL An SGI-specific image format, supported by the #NL libraries on SGI machines. This format is not #NL available on other platforms. TIFF - Tagged Image File Format #NL A large, complex image format used by xart #NL as its default format. XBM - X Window BitMap #NL A black and white image format used by the #NL X Window System. XPM - X Window PixMap #NL XPM images are stored in an ASCII text #NL format that can be included in C as arrays in the sourcecode. XWD - X Window Dump #NL Used for screen dumps by the X Window #NL System. #BEGIN gotcha's "gotcha's, bugs, klank and tips" The more powerful features sometimes have more prerequisites to work. Some tools have option variations that will do nothing, particularly as pertains to patterns and solids, e.g. transparent brush must be a solid. A tool that does not support patterns will paint in the last solid selected when a pattern is selected. Make sure you try all buttons on all widgets. jpegs use a "lossy" compression scheme and GIFs are 8-bit. Undo and certain selection/filter combinations don't always refresh correctly. Drag some other window across the canvas to force it to update if you think that's the case. The oval tool leaves a rectangular region around the oval that acts like a selection until it is changed. Pattern editing is buggy, but works. You have to select a pot or two before using add/edit pattern or you'll crash. In the pattern editing window you have to pick a color before editing the pattern image or the changes won't save. #BEGIN about "Whence xart" xart is derived from XPaint 2.5.1. #NL #NL NOTE: This (beta) version of XPaint is released and maintained by Torsten Martinsen (torsten@danbbs.dk), except for the PNG code, which is written and maintained by Greg Roelofs (newt@uchicago.edu). It is based on XPaint 2.1.1, which was written by David Koblas. Please do NOT send bug reports, etc., to David Koblas. The message below is the original 'About' message from version 2.1.1. ---------------------------- Hopefully, you find this software useful. If you find any bugs or have any comments, feel free to contact me. This software is created as DonateWare. If you enjoy using XPaint, it would be appreciated if you would make a donation to the author in the form of cookies, money, employment, or whatever. If you or your firm is looking to hire a skilled consultant, contact me for more details. David Koblas (koblas@netcom.com) #NL Extra Mile Consulting #NL PO Box 1352 #NL Mountain View, CA 94042-1352 USA #BEGIN copyright "Copyright Information" Copyright (C) 1993, David Koblas Copyright (C) 1995, 1996, Torsten Martinsen #NL Copyright (C) 1996, Greg Roelofs #NL xart is no longer XPaint. Martensen doesn't have time to go over all the changes in xart, and I believe he's also involved with the GIMP, so xart will be released as a separate thing. In my opinion, ( Hohensee) xart completely supercedes XPaint. xart lacks XPaint's revert menu item, because revert seems to have broken some palette editing features, and revert functionality is easily available by reloading the canvas. xart is a bit larger than XPaint, mostly due to additional default patterns and brushes. Otherwise, nothing has been lost and much has been added, including bugs. quillOp.c is Copyright 1998 Richard Allen Hohensee, and is released under ( what I believe are) Koblas' original release terms, which see below. Permission to use, copy, modify, and to distribute this software and its documentation for any purpose is hereby granted without fee, provided that the above copyright notice appear in all copies and that both that copyright notice and this permission notice appear in supporting documentation. There are no representations about the suitability of this software for any purpose. This software is provided "as is" without express or implied warranty.