Primitives Reference: Difference between revisions
Holly-Wood (talk | contribs) (Added right-angled triangular prisms) |
Holly-Wood (talk | contribs) No edit summary |
||
Line 4: | Line 4: | ||
They serve several purposes : | They serve several purposes : | ||
* To speed up parts authoring by providing a library of components which can be incorporated into several parts | |||
* To allow rendering software to make substitutions of curved components | |||
Within this reference material the available primitives are categorised into: | Within this reference material the available primitives are categorised into: | ||
Line 673: | Line 673: | ||
r=7 : 4-4ring7<br> | r=7 : 4-4ring7<br> | ||
r=11 : 4-4ring11<br> | r=11 : 4-4ring11<br> | ||
|- | |||
| '''n-faring.dat''' || '''Circular adaptor ring segment''' | |||
|- | |||
| [[File:2-4aring.png|200px|thumb|alt=2-4aring]] | |||
||This suite of primitives are used to interface between high resolution (48-segment) circular primitives and normal resolution (16-segment) circluar primitives. | |||
''Currently available primitives:''<br> | |||
Regular resolution (n-faring): 4-4<br> | |||
High resolution (n-faring): 1-4 | |||
|} | |||
{| class="wikitable" | |||
|+ Caption text | |||
|- | |||
=== Three dimensional === | |||
| '''n-fcyli.dat'''<br>'''n-fcyli2.dat''' || '''Circular cylinder''' | |||
|- | |||
| [[File:4-4cyli.png |200px|thumb|alt=4-4cyli]] | |||
||This suite of primitives are used to generate cylinders or part cylinders. These are provided in two forms - with conditional lines (n-fcyli) or without conditional lines (n-fcyli2). In almost all circumstances the "cyli" version should be used. The "cyli2" versions are for very special cases and their use for the rounded corners of stickers is no longer appropriate. | |||
''Currently available primitives - with conditional lines:''<br> | |||
Regular resolution (n-fcyli): 1-16, 1-8, 3-16, 1-4, 5-16, 3-8, 7-16, 2-4, 5-8, 11-16, 3-4, 7-8, 4-4<br> | |||
High resolution (n-fcyli): 1-48, 1-24, 1-16, 1-12, 5-48, 1-8, 7-48, 1-6, 3-16, 5-24, 1-4, 7-24, 1-3, 3-8, 5-12, 7-16, 11-24, 2-4, 5-8, 2-3, 3-4, 7-8, 4-4<br> | |||
''Currently available primitives - without conditional lines:''<br> | |||
Regular resolution (n-fcyli2): 3-16, 1-4, 5-16, 2-4, 3-8, 4-4<br> | |||
High resolution (n-fcyli2): 1-4, 2-4, 4-4 | |||
|- | |||
| '''n-fcylo.dat''' || '''Circular cylinder with Open End''' | |||
|- | |||
| [[File:4-4cylo.png |200px|thumb|alt=4-4cylo]] | |||
||This suite of primitives are used to generate cylinders or part cylinders with edges around the lower and upper surfaces. | |||
''Currently available primitives:''<br> | |||
Regular resolution (n-fcylo): 1-16, 1-8, 3-16, 1-4, 5-16, 3-8, 7-16, 2-4, 5-8, 3-4, 7-8, 4-4<br> | |||
High resolution (n-fcylo): 1-48, 1-24, 1-16, 1-12, 5-48, 1-8, 7-48, 3-16, 5-24, 1-4, 1-3, 2-4, 4-4 | |||
|- | |||
| '''n-fcylc.dat''' <br> '''n-fcylc2.dat''' <br> '''n-fcylc3.dat''' || '''Circular cylinder with Closed End''' | |||
|- | |||
| [[File:4-4cylc.png |200px|thumb|alt=4-4cylc]] | |||
||This suite of primitives are used to generate cylinders or part cylinders with the upper surface closed. | |||
''Currently available primitives - with conditional lines and top edge line:''<br> | |||
Regular resolution (n-fcylc): 1-4, 2-4, 3-4, 4-4<br> | |||
High resolution (n-fcylc): 2-4, 4-4<br> | |||
''Currently available primitives - without conditional lines or top or bottom edge line:''<br> | |||
Regular resolution (n-fcylc2): 1-4, 4-4<br> | |||
High resolution (n-fcylc2): 4-4<br> | |||
''Currently available primitives - with conditional lines, but without top and bottom edge lines:''<br> | |||
Regular resolution (n-fcylc3): 1-4, 4-4<br> | |||
High resolution (n-fcylc3): | |||
|} | |} |
Revision as of 13:27, 1 December 2023
LDraw Primitives Reference
This page is a source of reference for the LDraw primitives in the \LDraw\p directory. Primitives are defined as highly re-usable components of LEGO parts modelled for LDraw. They serve several purposes :
- To speed up parts authoring by providing a library of components which can be incorporated into several parts
- To allow rendering software to make substitutions of curved components
Within this reference material the available primitives are categorised into:
Each section contains an overview of the characteristics common to all primitives within that category. Primitives are grouped into classes within each category - one class of primitive serving a similar purpose at different sizes or resolutions. For each class of primitive, a brief description of the purpose of the primitive is provided, with notes on its co-ordinate origin, default size and rules for scaling. A list of the available primitives is shown.
An understanding of the orientation of the co-ordinate axes is essential for authoring a part for LDraw. For reference within this page the axes and their direction is shown in this diagram.
Rectilinear primitives
These rectilinear elements may be scaled in the {x}, {y} and {z} dimensions to make elements of any size. For example
1 16 0 0 0 40 0 0 0 1 0 0 0 20 rect.dat
would generate a 80LDu x 40LDu rectangle in the {x,z} plane.
Although the default orientation of the rect.dat primitive is in the {x,z} plane the LDraw language allows for this to be transformed
1 16 0 0 0 0 1 0 40 0 0 0 0 20 rect.dat
would generate a 80LDu x 40LDu rectangle in the {y,z} plane.
1 16 0 0 0 40 0 0 0 0 20 0 1 0 rect.dat
would generate a 80LDu x 40LDu rectangle in the {x,y} plane.
Curved primitives
LDraw represents curved surfaces as polygons. For circular components two series of primitives are provided.
All the circular primitives are orientated in the {x,z} plane with their origin at the centre of the circle and a default radius of 1 LDu. Primitives are provided for complete circles and for commonly used fractions of a complete circle. Where the naming convention includes a prefix of the form n-f this indicates the fraction (n/f) of the circle drawn by the primitive. Where this fraction is less than an entire circle, the primitive starts at {+x,0} and progresses in a conterclockwise direction when viewed from above {-y}.
To avoid rounding errors, it is preferable to use existing fractional circular primitives, or create a new primitive, rather than rotate an existing primitive by anything other than 90 or 180 degrees. For example, use 3-16XXXX.dat rather than combining 1-8XXXX.dat with 1-16XXXX.dat rotated by 22.5 degreees.
To avoid matrix arithmetic problems in some renderers, the third dimension ({y} in the default orientation) of two-dimensional primitives must be given a non-zero scaling factor. LDraw circles are normally formed of 16-sided polygons (hexdecagons) - the regular resolution. For larger elements, where scaling-up of hexadecagons would give too angular an appearance, a series of high resolution primitives based on a 48-sided polygon are available. These may also be used for parts not well suited to a 16-fold symmetry.
These circular elements may be scaled by the same factor in both the {x} and {z} dimensions to make circular elements of greater or less than 1LDu radius. For example
1 16 0 0 0 3 0 0 0 1 0 0 0 3 4-4edge.dat
would generate a circle in the {x,z} plane with a radius of 3LDu.
They may also be scaled asymmetrically in the x and z dimension to make ellipses.
Although the default orientation is in the {x,z} plane the LDraw language allows for these to be transformed
1 16 0 0 0 0 1 0 3 0 0 0 0 3 4-4edge.dat would generate a circle in the {y,z} plane
1 16 0 0 0 3 0 0 0 0 3 0 1 0 4-4edge.dat would generate a circle in the {x,y} plane