Provided by: xgterm_2.1+dfsg-1_amd64
NAME
xgterm - terminal emulator for X with graphics and imaging capability
SYNOPSIS
xgterm [-toolkitoption ...] [-option ...]
DESCRIPTION
The xgterm program is a terminal emulator for the X Window System based largely on xterm but with a completely new graphics and imaging widget. It provides DEC VT102 and Tektronix 4014 compatible terminals for programs that can't use the window system directly. XGterm also serves as a prototype for the Widget Server being developed by the IRAF Project at NOAO. The Object Manager Library it uses implements a window system toolkit as an interpreted window-object language, allowing application GUIs to be defined and executed at runtime without compiling any code, and with minimal dependence upon the underlying window system toolkit library. We will concentrate here, however, on it's use as a terminal emulator and a description of the new Gterm widget. The Gterm graphics window operates almost identically to the xterm Tek window, however there are extensions for implementing full-screen cursors, imaging, area fills, colors, graphics erasure, a "status line" and so on. Any graphics application capable of running under an xterm Tek window should also be able to use xgterm as well. Client programs wishing to make use of the extended features, or those wishing to implement a GUI, are advised to use the OBM (Object Manager) library supplied with the XGterm source as part of the X11IRAF package. This provides a much better programmatic interface to all of the features available; however, as of this writing it is not yet fully documented. Users are referred to the XImtool task as an example of a more complex application using the OBM Library and Gterm widget, as well as demo tasks in the guidemo directory of the X11IRAF sources. The VT102 text window is unchanged from the original xterm application. All of it's resources, command-line options and operation are identical to that used by xterm. The termcap(5) entry for xterm may be used for xgterm as well. See the xterm(1) man page for details.
OPTIONS
All xterm(1) and X Toolkit command line options are supported, there are no additional options.
RESOURCES
The program understands all of the core X Toolkit resource names and classes, all text window resources known to xterm(1), as well as the Gterm (graphics and imaging widget) resources. The proper Class name for all resources described here is Gterm. A table of available Gterm resources and their defaults may be found below, some of the more interesting resources are described here in detail: basePixel Base cell of the custom colormap. This essentially allows you to reserve basePixel colors in the global colormap for other applications. The default is 38, if changed you'll need to also enable the cmapInitialize resource to force the Gterm widget to update it's global colormap resource in the X server. cmapInitialize Initialize the ximtool colormap at startup. When resetting the basePixel resource or colormap this is required in order to force the Gterm widget to update it's global colormap resource in the X server. The default is False. cmapInterpolate Interpolate the colormap to the number of display colors. The default is True. cmapName Name used for private colormap. The default for all IRAF imaging applications is image. Gterm widget based imaging applications which have the same value of cmapName will share the same colormap, minimizing colormap flashing and allowing multiple applications to be run at the same time. color0 The widget background color. The default is black. color1 The widget foreground color. The default is white. color2 thru color9 Optional drawing colors. The line color used for graphics is set using an escape sequence to select the current color index. See Gterm I/O Escape Sequences below for more details. crosshairCursorColor Color of the full screen crosshair cursor. defaultMarker Default marker type. Options include text, line, polyline, rectangle, box, circle, ellipse, and polygon. The default is rectangle. deiconifyWindow De-iconify the Gterm graphics window when activated. The default is False. dialogBgColor Dialog box (i.e. the status line) background color. Dialog text is text which is drawn into the dialog area at the bottom of the gterm window, it is transient and is not a permanent part of the graphics being drawn. Dialog text is normally used to interact with the user or to display messages during program operation, without affecting the graphics being drawn. dialogFgColor Dialog box (i.e. status line) foreground color. ginmodeBlinkInterval Graphics cursor blink interval, time is specified in milliseconds. The default is 0. ginmodeCursor Graphics mode cursor type. The default is a full screen cursor custom to the widget. height Height of the Gterm window. The default is 480. idleCursor Cursor to use when not in graphics mode. The default is a plus sign. markerHighlightColor Highlight color for the active marker. When the pointer moves into a marker is it marked "active", the highlight color and width change to which marker is active. The default is green. markerHighlightWidth Highlight width for the active marker. The default is 2. maxColors The maximum number of colors to use in the private global colormap, the default is 216. Out of this number 10 colors (the color0 thru color9 values) are reserved by the widget as static colors, the remainder may be allocated for images. raiseWindow Raise the window when active. The default is False. warpCursor Warp the cursor to the window when active. The default is False. width Width of the Gterm window. The default is 640.
GTERM WIDGET RESOURCES
Class Hierarchy Core -> Gterm Resources When creating a Gterm widget instance, the following resources are retrieved from the arguments list or from the resource database:
Name Class Type Default Description
───────────────────────────────────────────────────────────────────────────────────────────────────────── markerFill Boolean False Flood fill marker area with markerFillColor edge required for translation actions for be in effect. vertex (i.e. knot) required for translation actions for be in effect.
GTERM WIDGET TRANSLATIONS AND ACTIONS
The default translations for a Gterm window are: <Btn1Down>: m_create() <Btn2Down>: crosshair(on) <Btn2Motion>: crosshair(on) <Btn2Up>: crosshair(off) <EnterWindow>: enter-window() <LeaveWindow>: leave-window() <KeyPress>: graphics-input() <Motion>: track-cursor() The available action procedures for a Gterm window are: ignore() Ignore an event. graphics-input() Handle a graphics input request. crosshair(on|off) Display a crosshair cursor. track-cursor() Track crosshair cursor position. enter-window() Handle an EnterWindow event. leave-window() Handle an LeaveWindow event. reset() Do a soft reset of the Gterm widget. m_create() Create a new marker. Valid types include text line polyline rectangle box circle ellipse polygon The default is rectangle, if no type is given the default type specified by the markerType resource will be used.
GTERM MARKER TRANSLATIONS AND ACTIONS
The default translations for a marker are: !Shift <Btn1Motion>: m_rotateResize() <Btn1Motion>: m_moveResize() !Shift <Btn1Down>: m_raise() m_markpos() <Btn1Down>: m_raise() m_markposAdd() <Btn1Up>: m_redraw() m_destroyNull() <Btn2Down>: m_lower() <Key>BackSpace: m_deleteDestroy() <Key>Delete: m_deleteDestroy() <KeyPress>: m_input() <Motion>: track-cursor() Translations affect only the currently active marker, the cursor must be within nearEdge pixels of a marker edge, or nearVertex pixels of a marker vertex to take effect. The available action procedures for a marker are m_create(type) Create a new marker. Valid types include text line polyline rectangle box circle ellipse polygon The default is rectangle, if no type is given the default type specified by the markerType resource will be used. m_destroy() Destroy the active marker. m_destroyNull() Destroy the active marker if it is null sized. m_set(attribute, value, ....) Set a marker attribute. Valid attributes include activated autoRedraw fill fillBgColor fillColor fillPattern fillStyle font height highlightColor imageText knotColor knotSize lineColor lineStyle lineWidth rotangle sensitive textBgColor textBorder textColor translations type visible width x y m_raise() Raise the active marker to the top of the display list. m_lower() Lower the active marker to the bottom of the display list. m_notify(event, event, ....) Notify any clients that have registered callbacks for the specified type of events. Recognized events include notify moveResize modify redraw destroy input focusIn focusOut constraint m_input() Notify any clients that have registered a input callback that a input event has occurred. m_markpos() Mark the current position of the marker, e.g., so that it can later be erased. m_markposAdd() Execute either the markpos or add action, depending upon the pointer location. If the pointer is over an active marker at a location where the add action can be executed this is done, otherwise the markpos action is executed. m_redraw() Redraw the active marker. m_addPt() Add a point (i.e. vertex knot). Polyline and polygon markers only. m_deletePt() Delete a point (i.e. vertex knot). m_movePt() Move a point (i.e. vertex knot). Polyline and polygon markers only. m_deleteDestroy() Delete a point or destroy a marker, depending upon the pointer position. m_move() Move a marker. m_resize() Resize a marker. m_moveResize() Move a point or marker, or resize a marker, depending upon the pointer position. m_rotate() Rotate a marker. m_rotateResize() Rotate or resize a marker. A marker is rotated if near a vertex know, or resized if near an edge.
GTERM I/O ESCAPE SEQUENCES
XGterm uses escape sequences to provide graphics emulation. This protocol is an extension of the Tektronix 4012 graphics protocol. The basic extensions are patterned after the Retrographics VT640 graphics terminal, using GS (octal \035, aka Ctrl-]) and CAN (octal \030, aka Ctrl-x) to switch between vt100 and graphics modes. Additional extensions are defined to support advanced features such as color, area fills, graphics erasure, setting the cursor location under program control, interactive dialog via the "status line", and so on. While these escape sequences can be used directly, the best programmatic interface is to use the OBM (Object Manager) library supplied with the XGterm source as part of the X11IRAF package. Any Tektronix-compatible graphics library will suffice for producing vector graphics, the added escape sequences used by the Gterm widget are required to make use of imaging, area fills, the status line, etc. All escape sequences begin with an ESC character (octal \033), followed by up to three characters defining the action to be taken. All strings in capital letters refer to the ASCII code (e.g. LF is the ASCII linefeed code), a three digit number preceded by a '´ refers to an octal code (e.g. " 12" is octal 12) , all others are characters in the escape code (e.g. "/bc" are the three characters '/', 'b', and 'c'). ESCAPE SEQUENCES US CR Switch to alpha mode. Characters are drawn in the graphics window at the "current" position (normally set beforehand with a GS/US vector move), using the alpha mode font. Receipt of any control code causes alpha mode to be exited. GS Switch to vector polyline mode. FS Switch to vector polypoint mode. RS Switch to vector mode, vertices are joined as a polygon. With all three codes, vertices and points are accumulated in a buffer and displayed when the buffer fills or when vector mode is terminated by receipt of any control code. A workstation open will be done if it hasn't already been opened, no-op sequences GS-CAN are filtered out, since they would only cause a pointless switch to the graphics frame and back without drawing. The open workstation sequence is GS,US, or by the xterm graphics start escape sequence "[?38h". EM Enter message mode. In message mode input text is accumulated in a buffer and eventually passed to the object manager, which delivers the message to the referenced object. Messages are used to download the user interface to be executed by the object manager. During execution, messages are used to set the values of user interface parameters to allow the UI to track the state of the client application. CAN Close workstation and enter command mode. BEL Ring the screen bell. ENQ Return terminal status. Returned values include the terminal mode, and alpha cursor x and y position. SUB Initiate a cursor read, values are returned in window coordinates. /SUB Return window cursor position in raster coordinates. FF Clear the screen. /f Set current cursor position. 0 Set character size 0. (Currently ignored). 1 Set character size 1. (Currently ignored). 2 Set character size 2. (Currently ignored). 3 Set character size 3. (Currently ignored). /0d Set color index. /1d Clear graphics screen. /2d Invert graphics screen ` Select line style 0. (Solid) a Select line style 1. (Dashed) b Select line style 2. (Dotted) c Select line style 3. (DashDot) d Select line style 4. (Dash3Dot) /0w Select line width 0. /1w Select line width 1. /2w Select line width 2. /nw Select line width 3. /0c Select line color 0. /1c Select line color 1. /2c Select line color 2. /3c Select line color 3. /4c Select line color 4. /5c Select line color 5. /6c Select line color 6. /7c Select line color 7. /8c Select line color 8. /9c Select line color 9. IMAGING ESCAPE SEQUENCES These are encoded as follows: ESC <code> [ P ; P ; ... ] <data> where code is a character sequence and P is an ASCII encoded parameter described below. /nc Select line color. Parameter is the color number in the range 0-9. sre Reset. Parameters are "reset-str". ssz Resize. Parameters are "resize-str". rir Initialize raster. rcr Create a raster. Parameters are raster number, type, width, height, and depth. Type is 1 for a normal (client) raster, 2 for cached in server memory, or 0 if you don't care. Depth may be 1, 8, 16, or 32. rde Destroy a raster. Parameter is raster number. rqr Query a raster. Parameter is raster number. Output parameters are status, type, width, height, and depth encoded in the string ""\033[5;%d;%d;%d;%d;%d]". rsr Select a raster. Parameter is raster number. rwr Write pixels to a rectangular region of a raster. Parameters are raster number, encoding type (not used), x1, y1, nx, ny, and depth followed by (nx*ny) data pixels. rrd Read from a rectangular region of a raster. Parameters are raster number, encoding type (not used), x1, y1, nx, ny, and depth followed by (nx*ny) data pixels. rrp Refresh raster pixels. Parameters are raster number, coordinate type (0 for pixel, 1 for NDC), x1, y1, nx, ny. rsp Set all the raster pixels in a region to a single color. Parameters are raster number, coordinate type (0 for pixel, 1 for NDC), x1, y1, nx, ny, color, and raster operand. If nx=ny=0 the entire raster will be written. Raster operands include transient (octal 020), refresh_all (octal 040), or refresh_none (octal 100). rco Copy a region of the source raster to a region of the destination raster. Parameters are raster operand, source raster number, source type, source x coord, source y coord, source width, source height, destination raster number, destination type, destination x coord, destination y coord, destination width, destination height, If the input and output regions are not the same size the subimage is automatically scaled to fit the destination region. If the destination extent DNX or DNY is negative, the image is flipped in that axis. The type of spatial scaling performed is determined by the scale factors (zoom, dezoom, or no scaling). The rasterop argument is used to exercise fine control over how the mapping is performed, e.g. to force a refresh, implement a transient mapping, or in the case of a dezoom (many-to-one) mapping, select the antialiasing technique to be used. rwc Write a colormap. Parameters are colormap number, first color and the number of colors followed by NC colors triples in the data. rrc Return the color assignments for a region of the named colormap. Parameters are colormap number, first color and the number of colors followed by NC colors triples in the data. rlc Load a colormap into the display, optionally scaling the colormap via a linear transformation in the process. Parameters are the colormap number, the offset value, and the cursor x and Y coordinates in NDC units. The colormap is unaffected if offset=0.5, scale=1.0. A negative scale inverts the image. If map=0 the linear transformation is applied directly to the display colormap. rfc Free a colormap. Parameter is the colormap number. rwo Write the IOmap. Parameters are the first color and the number of colors, followed by NC color triples in the data. An iomap is an optional lookup table used to isolate the client application from the color model used within the Gterm widget. To simplify color allocation the Gterm widget defines a logical color space where color 0 is the background, 1 the foreground, 2-N are statically allocated standard colors, and colors N+1 and above are dynamically allocated by the graphics application. Less-demanding applications use only the statically allocated, shared colors. The widget internally maps these logical colors to whatever the window system requires, but providing a well-defined logical color space isolates the client from the details of color allocation in the underlying window system. An iomap can be used to define a mapping between the color model of the client application and the Gterm color model (when we say color model here we mean color allocation schemes for 8 bit pseudocolor). By default the iomap is one-to-one. The use of an iomap frees the client from having to worry about color index translations, and allows color tables to be combined in the widget for greater efficiency when color tables are serially applied. The iomap applies to all color indices or pixel values passed in i/o operations between the client and the Gterm widget. rro Read the IOmap. Return values are the first color and the number of colors, followed by NC color triples in the data. rim Delete all mappings and initialize the mapping subsystem. rsm Define a new mapping function, or modify an old one. If a new mapping is defined it is merely enabled, and no refreshing of the screen takes place until either some mapped data is written to or the mapping is explicitly refreshed. If an existing mapping is modified the old and new mappings are examined and only those portions of the destination rect for which the mapping changed are updated. This permits minor changes to a mapping (e.g. moving an edge) without having to redraw the entire region. Regions of the destination drawable which were previously covered by the mapping but which were exposed by modifying the mapping are redrawn. rgm Return the external parameters of a mapping. Parameter is the mapping number, values returned (in the string "\033[6;%d;%d %d;%d;%d;%d;%d;%d %d;%d;%d;%d;%d;%d]") are the mapping number, rasterop, source mapping, type, x, y, width, height, and destination mapping, type, x, y, width and height. rem Enable a mapping. Parameters are the mapping number and an integer flag indicating whether to refresh the mapping. rdm Disable a mapping. Disabling a mapping does not affect the mapping definition, hence a disabled mapping may later be reenabled. Parameters are the mapping number and an integer flag indicating whether to erase the mapping. rrm Refresh a mapping. Parameter is the mapping number. rfm Free a mapping. Parameter is the mapping number.
MORE ON IMAGING
The imaging model of the Gterm widget defines the following key object or data types: rasters, mappings, and colors. raster A raster is a MxN array of pixels. At present pixels are 8 bits deep but hooks are built into the widget to expand this in the future. Pixel values are indices into the Gterm virtual colormap, with values starting at zero. A raster may be any size. A raster is merely a two-dimensional array in the graphics server; it is not displayed unless mapped. An exception is raster zero, which is the graphics window. Rasters are referred to by number, starting with zero. Initially only raster zero exists; new rasters are created with the create raster escape code rcr. Space for rasters may be allocated either in the graphics server, or in the X server. This has implications on performance but is otherwise transparent to the client. By default rasters are allocated in the graphics server, i.e., in the X client. mapping A mapping defines a projection of a rectangle of the source raster onto a rectangle of the destination raster. Mappings may be either enabled (active) or disabled. When a mapping is enabled, any change to a pixel in the source rect will cause the corresponding pixels in the destination rect to be updated. Mappings are referred to by number starting with one. Initially no mappings are defined. If the size of the input and output rect is not the same the input rect will be scaled by pixel replication or subsampling to fill the output rect. If the argument DW (destination width) or DH (destination height) of the destination rect is negative, the image will be flipped around the corresponding axis when copied to the destination; the region of the destination drawn into is the same in either case. Multiple mappings may reference the same source or destination raster. Mappings are refreshed in order by the mapping number. Modifying a mapping causes the changed regions of the destination rect to be refreshed. color The Gterm widget provides a fixed number of preassigned colors corresponding to pixel values 0 through 9. Zero is the background color, one is the foreground color, and 2-9 (8 colors) are arbitrary colors defined by Gterm widget resources. These static colors are normally used to draw the background, frame, axes, titles, etc. of a plot, or to draw color graphics within the drawing area. The advantage of static colors is that they are shared with other X clients, and the values of these colors may be assigned by the user to personalize the way plots look. The Gterm widget also allows any number (up to about 200 or so) additional colors to be defined at runtime by the client application. These color values start at pixel value 10 and go up to the maximum pixel value assigned by the client. The client application allocates colors with the write colormap escape code rwc. Attempts to overwrite the values of the static colors are ignored. The values of already allocated colors may be changed dynamically at runtime using write colormap code to write the desired range of color values. Applications should not assume that there are 10 static colors and 200 or so allocatable colors. The IRAF graphcap entry for the logical device in use, and resources set for the widget, defines these parameters for the device. Alternatively, the read colormap code may be used to dynamically determine how many colors the server has preallocated when the application starts up. An image may use either static and dynamic pixel values or both types of values, but in most cases imaging applications involve smoothly shaded surfaces hence will require dynamically assigned private colors. If for some reason the client application cannot use the Gterm widget color model, the IOMAP feature can be used to make the widget appear to have some externally defined (i.e., client defined) color model. The maximum number of rasters and maximum number of mappings is defined by the Gterm widget resources maxRaster and maxMappings (or in the GUI file) when the graphics application starts up. The maximum values should be much larger than most applications require. Applications should allocate raster or mapping numbers sequentially starting at 1 (more or less) to avoid running out of raster or mapping descriptors. The {read|write}pixels escape codes operate directly on raster pixels. The mapping escape codes support two alternative coordinate systems, raster pixels and NDC (normalized device coordinates), as indicated by the ST or DT argument (source or destination coordinate type). Note that the origin of the pixel coordinate system is the upper left corner of the display window (consistent with most graphics systems), whereas the origin of the NDC coordinate system is the lower left corner (consistent with IRAF). Pixel coordinates allow precise control of imaging but require the application to know the window size, and may result in complications e.g. if the window is resized. NDC coordinates pretty much guarantee that a mapping will involve sampling, hence are not the most efficient, but the graphics will be drawn correctly no matter how the window is resized and for most applications the performance difference is negligible. Most applications should use NDC coordinates for raster 0 (the display window), and pixel coordinates for rasters 1-N. Although the size of rasters 1 and higher are defined by the client application, the size of raster zero, the actual gterm display window, is subject to the constraints of the window system. The client can attempt to reset the size of the gterm window using create raster escape with raster=0, however the Gterm widget, UI containing the Gterm widget, and the window manager are all free to deny such a request. The query raster escape should be called to determine the actual size of the window one will be drawing into. AN EXAMPLE IMAGING APPLICATION An example of a simple imaging application might be one that downloads an image and displays it in the gterm window, filling the window. This could be done as follows (following a graphics open and other escape codes to prepare the drawing surface). create raster Create raster 1 the size of the pixel array to be displayed. This need not be the same as the size of the gterm display window. set mapping Define a mapping between raster 1 and raster 0, the display window, using NDC coordinates to define the region of the display window to be filled. The mapping number is arbitrary but mappings should normally be allocated starting with 1. The mapping is automatically enabled when first defined. write colormap (Optional). Define the pixel value to RGB color assignments for the image pixels. write pixels This escape is called one or more times to write pixels into raster 1. At most 32K pixels can be written in each call. As each write is made the affected region of the display window will be updated. Alternatively, one could write the pixels and then define the mapping to cause the entire image to be displayed at once. Note that the imaging escape can be combined with normal graphics to draw text and graphics around or on top of an image region. The order in which drawing operations occur is important, e.g., to draw graphics or text on top of an image the image should be drawn first.
MARKERS
Markers are a general feature of the Gterm widget and are used more extensively in other programs (e.g. the prototype IRAF science GUI applications), but they have no real use in xgterm when used as simply a graphics terminal. All markers share some of the same characteristics, so it is worthwhile learning basic marker manipulation keystrokes (as defined using the default marker translations), especially how to delete an accidentally created marker: o Delete or Backspace in a marker deletes it. o MB1 anywhere inside a marker may be used to drag the marker. o MB1 near a marker corner or edge, depending on the type of marker, resizes the marker. o Shift-MB1 on the corner of most markers will rotate the marker. o Markers stack, if you have several markers and you put one on top of the other. The active marker is highlighted to tell you which of the stacked markers is active. If the markers overlap, this will be marker "on top" in the stacking order. o MB2 in the body of a marker "lowers" the marker, i.e. moves it to the bottom of the stacking order.
ENVIRONMENT
XGterm sets the environment variables ``TERM'' and ``TERMCAP'' properly for the size window you have created. It also uses and sets the environment variable ``DISPLAY'' to specify which bit map display terminal to use. The environment variable ``WINDOWID'' is set to the X window id number of the xgterm window.
SEE ALSO
xterm(1), resize(1), X(1), pty(4), tty(4) Xterm Control Sequences (in the xterm source directory)
BUGS
Many of the same bugs affecting xterm also apply here. Xgterm is not normally installed with setuid permissions. On some Linux systems, for example, where the /dev/tty and /dev/pty devices have root ownership and permission 600 this can cause problems. Workarounds are to either install XGterm with setuid permissions or modify the /dev/tty and /dev/pty devices to have permission 666.
COPYRIGHT
Copyright(c) 1986 Association of Universities for Research in Astronomy Inc.