
[ home | FAQ | download | troubleshooting | manual | cvs | mailing lists ]
Geometry and placement are computed using only active modules. Scale length and width adjustments are collected for all modules in order to find the global adjustments. The global adjustment is either the maximum of the local adjustments or the sum of them; for example, an MGM with vertical bars that are stacked horizontally (the bars are side-by-side), the global scale length adjustment is the maximum of the individual module length adjustment settings, and the global width adjustment is the sum of the individual width adjustments. Visualize this for a second until it's obvious why; the x size of the window described above is the sum of the widths of the graphs and the y size is as high as the tallest.
The same process is used to find the global minimum x and y sizes from the local minimum x and y specified by each module. MGM enforces at each step that the computed geometries are not less than the minimum settings specified by individual modules (unless the geometry is forced to a smaller-than-minimum size by frobbing the minx, miny or geometry resources).
After computing the global length and width adjustment settings, the adjustment values are mapped to actual pixel width and height by multiplying with the lendemand and widdemand values, dividing by 100, and mapping length/width to x and y depeneding on graph orientation (vertical bars will map width to x and length to y. Horizontal bars map length to x and width to y).
Module placement is determined after the global x and y sizes are known. MGM determines 'excess' x and y values by subtracting the global minimum x and y values from the actual mapped x and y values. This excess is then added to the minimum x and y settings of each module as determined by the scalelenadj and scalewidadj settings for that module. (remember that 'width' and 'length' map to x,y or y,x depending on graph orientation). For example, in a graph with vertical bars, the size of a specific module can be computed as follows:
module_x=(global_actual_x-global_minimum_x)/global_scalewidadj*
          local_scalewidadj
module_y=(global_actual_y-global_minimum_y)/global_scalelenadj*
          local_scalelenadj
One last note; the minimum actual length and width adjustments as used
internally are both 1; this prevents division by zero problems when
using a single module that uses adjustments of zero.It is possible to force each module to a specific, exact size completely overriding the automatic placement. This is done by setting the scalelenadj and scalewidadj to zero and specifying an exact size using minx and miny for each module.
 
MGM will not get your whites whiter or your colors brighter.  It will,
however, sit there and look spiffy while sucking down a major
honking wad of RAM. 
MGM, Xiphophorus and their logos are trademarks (tm) of
Xiphophorus.  These pages are
copyright (C) 1994-1999 Xiphophorus. All rights reserved.