Index of /archives/X/opengroup/contrib/widgets/Xaw3d/R5

Icon  Name                                         Last modified      Size  Description
[PARENTDIR] Parent Directory - [TXT] laygram.h 1994-07-18 08:00 711 [TXT] README 1994-07-18 08:00 6.3K [TXT] xarchie3d.patch 1994-07-18 08:00 6.9K [TXT] aXe3d.patch 1994-07-18 08:00 9.9K [TXT] xterm.patch 1994-07-18 08:00 10K [TXT] R4.Xaw3d-0.6.patch 1994-07-18 08:00 15K [TXT] laylex.c 1994-07-18 08:00 18K [TXT] laygram.c 1994-07-18 08:00 25K [CMP] Xaw3d-0.6B.tar.Z 1994-07-18 08:00 430K

                   Three-D Athena Widgets (Xaw3d)
                          Kaleb S. Keithley
                             kaleb@x.org

Features:

This is Release 0.6B (17 Feb, 1993) of a set of 3-D widgets based on the 
R5 Athena Widget set.  The Three-D Athena may be used as a general 
replacement for the Athena (Xaw) Widget set.

In general, you may relink almost any Athena Widget based application with 
the Three-D Athena Widget set and obtain a three dimensional appearance.  
On systems with shared libraries, you can replace your shared libXaw with 
libXaw3d and obtain the three dimensional appearance without even relinking.

In this release, I have tested all of the clients distributed on the R5 MIT 
source tape, plus xfig-2.1.5, xarchie-1.3, and aXe-3.1.  All Xaw3d sources 
have been thoroughly delinted using Sun's /bin/lint and gcc using -traditional 
-pedantic -Wall and -ansi -pedantic -Wall.

Top and bottom shadow colors, shadow width, top and bottom shadow contrast
should be self explanatory, and may be set via the usual and customary 
methods, e.g. app-defaults, .Xdefaults, programmatically, with editres, 
etc.  The user data resource may be used to "hang" application specific 
data on a widget, and is only settable programmatically.


This release adds the following features:

    o The 0.6A release fixed a problem in the Imakefile and added comments
      to the README.  No changes were made to the Xaw3d sources.

    o The 0.6B release added a comment to the README.  No changes were
      make to the Xaw3d sources.

    o The Layout widget.  If I may borrow the phrase, this is an insanely
      great widget written by Keith Packard, and introduced at the '93
      X Technical Conference.  I have included it in Xaw3d, with Keith's
      permission, because Xaw has been in need of a versatile manager
      widget.  Subclassed from Constraint, the Layout widget uses TeX-
      like semantics to describe where to place children and how to do 
      geometry management.

    o Scrollbar with arrows.  This is an Athena-based arrowhead-style 
      Scrollbar written by Mitch Trachtenberg that is 100% compatible
      with the normal Athena Scrollbar.  Selection of the normal style
      or the arrow style Scrollbar is a compile-time option for Xaw3d.
      The arrow style scrollbar is available separately on export in 
      the file: /contrib/Xaw.Scrollbar.mta.Z

    o Bug fixes.  More bug fixes than you can shake a stick at.


Known problems:

    o You won't be able to replace shared libXaw with libXaw3d on systems
      with SVR3 style shared libraries.

    o On SVR4/386, I've had reports that replacing shared libXaw with 
      libXaw3d works, and I've had reports that it doesn't.  Try it and 
      see.

    o Xaw3d pixel allocation doesn't behave well when beNiceToColormap
      is False and the Default Colormap is full.

    o The samples in Layout.h are wrong and don't work.  Example programs
      written by Keith Packard that use the Layout widget are available
      on export in /contrib/Layout.tar.Z


aXe-3.1 and xarchie:

      aXe-3.1 and xarchie won't compile against Xaw3d because they subclass 
      the Xaw widgets themselves.  To solve this, I now have a pair of 
      patches for these programs.  See below for where to get these patches.

      Renaming/replacing shared libXaw with libXaw3d will definitely break 
      unpatched aXe-3.1 and xarchie.

      aXe-4.0 includes optional support for Xaw3d.  Consult the aXe README
      for more information.


xterm:

      A comment that appears in the xterm source:
         *
         * ...There be serious and nasty dragons here.
         *

      xterm is, well, xterm.  The auto-scroll in the arrow-style scrollbar 
      doesn't work in xterm because it relies on XtTimeouts.  xterm, perhaps 
      in the name of speed, circumvents XtAppNextEvent() and goes direct to 
      XNextEvent() to get it's XEvents, with the unfortunate side effect of 
      completely ignoring "other sources" like timeouts.  I have included a 
      patch for xterm to support the arrow-style scrollbar.  See below for 
      where to get this patch.


Getting:

Xaw3d may be found on export.lcs.mit.edu (18.24.0.12) and possibly other
sites; check archie.  On export, it may be found in the file:

    ~ftp/contrib/Xaw3d/R5/Xaw3d-0.6B.tar.Z

There is no patch file from 0.5 to 0.6 -- it's larger than the tar file.

Patches for xarchie-1.3, aXe-3.1, and xterm may be found in the files:

    ~ftp/contrib/Xaw3d/R5/xarchie3d.patch
    ~ftp/contrib/Xaw3d/R5/aXe3d.patch
    ~ftp/contrib/Xaw3d/R5/xterm.patch


Building:  

Untar the distribution from the base of your MIT source tree.  This will 
create the directory .../mit/lib/Xaw3d.  'cd' there and:

    'make Makefile; make includes; make depend; make; make install'.  

The Imakefile contains the line:

#    EXTRA_DEFINES = -DARROW_SCROLLBAR

If you want the arrow-scrollbar, then uncomment the line by deleting the '#'.

The Imakefile uses the Xaw symbols in .../mit/config, so if you have 
debugging, profiling, shared libs, etc. specified for Xaw, you'll get 
them in Xaw3d too.


Using:

Just relink your Xaw based application with -lXaw3d.

To obtain an appearance similar to another well know widget set, use the 
following resources:
    *background:        LightSkyBlue
    *shapeStyle:        Rectangle
    *beNiceToColormap:  False

By default, Label widgets do not have shadows drawn for them.  You can
force shadows to be drawn for specifying:
    *shadowWidth: 2

If you'd like the default behavior (i.e. not 3-D) on pulldown menus, use:
    *SmeBSB*shadowWidth: 0


Credits (in chronological order of their contribution):

          All the people at the X Consortium

          Achille Hui (eillihca@drizzle.stanford.edu)
          Robert Withrow (witr@rwwa.com)
          Malcolm Strickland (chuck-strickland@orl.mmc.com
          David Flanagan (david@ora.com)
          Jamie Zawinski (jwz%thalidomide@lucid.com
          Frank Terhaar-Yonkers (fty@bizarre.trpnc.epa.gov)
          Mike Schulze (mike@cs.curtin.edu.au)
          Gustaf Neumann (neumann@dec4.wu-wien.ac.at)
          Jerry Whelan (guru@stasi.bradley.edu)
          Mark Rawling (mwr@mel.dit.csiro.au)
          Tim Theisen (tim@cs.wisc.edu)
          Mitch Trachtenberg (mitch@mta.com)
          Keith Packard (keithp@ncd.com)


Comments, fixes, etc. to: 
          kaleb@x.org