Widget position and size in grid
Form items render as widgets in the window, at a given position and with a given size.
To render form items, grid-based rendering follows the layout rules described below:
- The position of the widgets in the virtual grid is defined by the
posX
andposY
AUI tree attributes. - The number of virtual grid cells occupied by a widget is defined by the
gridWidth
andgridHeight
AUI tree attributes. - The real size of a widget is defined by the
width
andheight
AUI tree attributes. Some form items allow to specify their size with theWIDTH
andHEIGHT
attributes. - Empty lines and empty columns in the form layout definition take a size of 0 pixels.
- The size of a cell in the virtual grid depends on the real size of the widgets inside the grid.
- A widget's minimum size is computed via its real size and the
SAMPLE
attribute. The minimum width can be forced by setting theSTRETCHMIN
attribute. - The preferred size of the widget is computed following the
SIZEPOLICY
attribute. - The final widget size is computed depending on the minimum and preferred size, to fill the cells in the grid.
- A small spacing is applied in non-empty cells.
Take this form file:
LAYOUT
GRID
{
First Name [fn ]
Last Name [ln ]
}
END
END
ATTRIBUTES
EDIT fn = FORMONLY.fname;
EDIT ln = FORMONLY.lname;
END
It will produce the virtual grid as follows:
data:image/s3,"s3://crabby-images/0d705/0d705963679fe44b9d8c8be78b7596ece3fda27b" alt="Grid layout rules"
By default, empty grid rows and empty grid columns get no size when rendered on the front-end. For example, in the above grid sample, the grid columns #10 and #11 are empty.
Visual result:
data:image/s3,"s3://crabby-images/8e31c/8e31c210f7a8ec78b0ec58a4f1e61d618998b8d2" alt="Grid layout rules in Genero form"