Template:Infobox website LDraw is a system of freeware tools and a 3D graphics file format standard for modeling Lego creations.

HistoryEdit

The LDraw file format and original program were written by James Jessiman,<ref>{{#invoke:citation/CS1|citation |CitationClass=web }}</ref> although the file format has since evolved and extended.<ref>{{#invoke:citation/CS1|citation |CitationClass=web }}</ref><ref>{{#invoke:citation/CS1|citation |CitationClass=web }}</ref><ref>{{#invoke:citation/CS1|citation |CitationClass=web }}</ref><ref>{{#invoke:citation/CS1|citation |CitationClass=web }}</ref><ref>{{#invoke:citation/CS1|citation |CitationClass=web }}</ref><ref>{{#invoke:citation/CS1|citation |CitationClass=web }}</ref><ref>{{#invoke:citation/CS1|citation |CitationClass=web }}</ref> He also modeled many of the original parts in the parts library, which is under continuous maintenance and extension by the LDraw community.

Following Jessiman's death in 1997,Template:Sfn<ref>{{#invoke:citation/CS1|citation |CitationClass=web }}</ref> a variety of programs have been written that use the LDraw parts library, and file format. LDraw models are frequently rendered in POV-Ray or Blender, free 3D ray tracers.

LDraw.orgEdit

In 2003, LDraw.org organization has been established, which main task is set to further develop LDraw file format and extend LDraw parts library. Organization is controlled by members of LDraw.org Steering Committee (LSC for short), elected by users of LDraw.org forum. Core members of LDraw.org are in close ties with James Jessiman's family, which is the owner of the LDraw™ registered trademark.

James Jessiman Memorial AwardEdit

Template:See also Template:Infobox award

Since 2001, LDraw.org project org's awards notable contributors with the James Jessiman Memorial Award.

Recipient is selected by LDraw.org Steering Committee, and approved after a consultation with Jessiman's family.<ref name=":72">{{#invoke:citation/CS1|citation |CitationClass=web }}</ref>

RecipientsEdit

  • 2001 – Steve Bliss
  • 2002 – not awarded
  • 2003 – Jacob Sparre Andersen
  • 2004 – Lars C. Hassing
  • 2005 – Michael Lachmann
  • 2006 – Orion Pobursky
  • 2007 – Kevin Clague
  • 2008 – Philippe Hurbain
  • 2009 – Tim Courtney
  • 2010 – not awarded
  • 2011 – Travis Cobbs
  • 2012 – Steffen Lohse
  • 2013 – Magnus Forsberg
  • 2014 – Sergio Reano
  • 2015 – Roland Melkert
  • 2016 – Nils Schmidt
  • 2017 – Chris Dee
  • 2018 – Michael 'Mike' Heidemann
  • 2019 – Gerald Lasser
  • 2020 – Lasse Deleuran
  • 2021 – Leonardo Zide,<ref name=":6">{{#invoke:citation/CS1|citation

|CitationClass=web }}</ref><ref>{{#invoke:citation/CS1|citation |CitationClass=web }}</ref><ref>Template:Cite news</ref> software engineer at Treyarch, author of LeoCAD (an open-source program for creatiing virtual Lego models with LDraw).

  • 2022 – Takeshi Takahashi
  • 2023 – Massimo Maso
  • 2024 – Evert-Jan Boer

File formatEdit

Template:Infobox file format LDraw file format describes "part" (representation of Lego brick) as a set of geometric primitives ("p") in a form of polygonal triangulated mesh.

LDraw "models" consists of LDraw "parts", same way as Lego models consists of Lego bricks.

LDraw file format is plain text file format, and uses comma-separated syntax definition of values.

UnitsEdit

File:Lego dimensions.svg
Lego brick (real) dimensions
File:LeoCAD ruler mm.png
Measuring LDraw parts size in LeoCAD with "ruler" part (ruler tick: 1 mm)

LDU (LDraw Units) — is a base distance unit used in the LDraw format, equals to 1/20 of pin step (distance between centers of 2 closest pins on plate), which in turn almost equals to 0.4 millimetre.

Units comparison table
1 = LDU mm LU Flat P Stud Brick in Comment
LDU 0.4 Template:Frac Template:Frac Template:Frac Template:Frac Template:Frac Template:Frac LDraw Unit<ref>{{#invoke:citation/CS1|citation CitationClass=web

}}</ref><ref>{{#invoke:citation/CS1|citation

CitationClass=web

}}</ref><ref>{{#invoke:citation/CS1|citation

CitationClass=web

}}</ref> — base unit

mm 2Template:Frac Template:Frac Template:Frac Template:Frac Template:Frac Template:Frac Template:Frac millimetre = 0.1 cm = 0.01 dm = 0.001 m
LU 4 1.6 Template:Frac Template:Frac Template:Frac Template:Frac Template:Frac Lego Unit<ref>{{#invoke:citation/CS1|citation CitationClass=web

}}</ref> = 1 p («plastic»<ref>{{#invoke:citation/CS1|citation

CitationClass=web

}}</ref>) — thickness of brick wall

Flat 8 3.2 2 Template:Frac Template:Frac Template:Frac Template:Frac plate height without pin — distance between edges of closest pins
P 20 8.0 5 2Template:Frac 1 Template:Frac Template:Frac pin step— distance between centers of two closest pins
Stud 20 8.0 5 2Template:Frac 1 Template:Frac Template:Frac 1x1 brick width (real width: P-0.2 mm = 7.8 mm)
Brick 24 9.6 6 3 1Template:Frac 1Template:Frac Template:Frac brick height without pin
in 64 25.4 16 8 3Template:Frac 3Template:Frac 3Template:Frac inch = Template:Frac feet = Template:Frac yard
Notes: dimension in and mm are approximated (in mm — rounded to the first decimaldigit)

Some editors (like, LeoCAD) displaying dimensions and coordinates using only LDU. For measuring and converting sizes from LDU to other units and vice versa, LDraw users created few parts in a form of ruler,<ref>{{#invoke:citation/CS1|citation |CitationClass=web }}</ref> that could be used directly in LDraw editors during visual modeling, that especially useful for scale model making.

ScaleEdit

LDraw, same as Lego, uses 1:42½ (Lego minifigure scale) as base for scaling real world object for scale modeling. Its may drift between 1:40 to 1:43, which are popular among other interests.

SpecificationEdit

The LDraw format can divide a model into steps so that the building instructions can be incorporated into the design, and also allows for steps that rotate the camera and even move parts around in an elementary fashion. It also allows for models to be incorporated in the construction of larger models to make design easier. This also makes the file format space efficient: instead of specifying the polygons of every single stud of a specific brick for example, a shared stud file is included multiple times with transformation applied.

Parts, models, sub-models and polygons are all treated the same and are not specific to Lego models (only the parts library is). The format could be used to store any type of 3D model. Some have created bricks of other building systems for use with LDraw.

The following main three filename extensions are used by LDraw:Template:Sfn

  • files implementing a part, subpart or primitive use .dat
  • a Lego model consisting of 1 or more bricks use .ldr
  • multiple .ldr files can be aggregated into files of type .mpd

The file format uses plain text data, and uses the charset UTF-8 without BOM.

Example File: 3003.dat, the implementation of a 2 x 2 brickEdit

<syntaxhighlight lang="text">0 Brick 2 x 2 0 Name: 3003.dat 0 Author: James Jessiman 0 !LDRAW_ORG Part UPDATE 2002-03 0 !LICENSE Redistributable under CCAL version 2.0 : see CAreadme.txt

0 BFC CERTIFY CCW

0 !HISTORY 2001-10-26 [PTadmin] Official Update 2001-01 0 !HISTORY 2002-05-07 [unknown] BFC Certification 0 !HISTORY 2002-06-11 [PTadmin] Official Update 2002-03 0 !HISTORY 2007-05-07 [PTadmin] Header formatted for Contributor Agreement 0 !HISTORY 2008-07-01 [PTadmin] Official Update 2008-01

1 16 0 4 0 1 0 0 0 -5 0 0 0 1 stud4.dat

0 BFC INVERTNEXT 1 16 0 24 0 16 0 0 0 -20 0 0 0 16 box5.dat

4 16 20 24 20 16 24 16 -16 24 16 -20 24 20 4 16 -20 24 20 -16 24 16 -16 24 -16 -20 24 -20 4 16 -20 24 -20 -16 24 -16 16 24 -16 20 24 -20 4 16 20 24 -20 16 24 -16 16 24 16 20 24 20

1 16 0 24 0 20 0 0 0 -24 0 0 0 20 box5.dat

1 16 10 0 10 1 0 0 0 1 0 0 0 1 stud.dat 1 16 -10 0 10 1 0 0 0 1 0 0 0 1 stud.dat 1 16 10 0 -10 1 0 0 0 1 0 0 0 1 stud.dat 1 16 -10 0 -10 1 0 0 0 1 0 0 0 1 stud.dat </syntaxhighlight>

The above code defines the basic 2×2 brick. It consists of a five-sided box (box5.dat, outside) and an inverted five-sided box (inside), the connection between those two, consisting of four quads (the four lines starting with 4), the four studs on top of it (stud.dat) and the long hollow stud in the inside (stud4.dat).

All lines in an LDraw file are either empty or start with a command number, where 0 means no command (though over time, some lines starting with 0 followed by specific text in capitals also got a meaning as meta commands).Template:Sfn The command 1 for example includes a subfile. It specifies the file's path and a transformation matrix that should be applied to it, as well as its color (where 16 means "use the color that was used when including the current file"). Command 4 specifies a four-sided polygon. There are also commands that define 2D lines. Such lines give the parts a clear contour even in non-shaded orthographic renderings.

Example File: pyramid.ldr, a Lego model of a pyramidEdit

The following code specifies a simple pyramid model with three layers made of 2 x 4 bricks (brick # 3001) with changing color and a 2 x 2 brick on top. <syntaxhighlight lang="text"> 0 Example Pyramid for Demonstration of LDRAW Library 0 Name: pyramid.ldr 0 Author: James Jessiman

1 1 -40 -24 60 1 0 0 0 1 0 0 0 1 3001.dat 1 1 40 -24 60 1 0 0 0 1 0 0 0 1 3001.dat 1 1 60 -24 0 0 0 1 0 1 0 -1 0 0 3001.dat 1 1 40 -24 -60 1 0 0 0 1 0 0 0 1 3001.dat 1 1 -40 -24 -60 1 0 0 0 1 0 0 0 1 3001.dat 1 1 -60 -24 0 0 0 1 0 1 0 -1 0 0 3001.dat

0 STEP

1 4 -20 -48 40 1 0 0 0 1 0 0 0 1 3001.dat 1 4 40 -48 20 0 0 1 0 1 0 -1 0 0 3001.dat 1 4 20 -48 -40 1 0 0 0 1 0 0 0 1 3001.dat 1 4 -40 -48 -20 0 0 1 0 1 0 -1 0 0 3001.dat

0 STEP

1 14 0 -72 20 1 0 0 0 1 0 0 0 1 3001.dat 1 14 0 -72 -20 1 0 0 0 1 0 0 0 1 3001.dat

0 STEP

1 0 0 -96 0 1 0 0 0 1 0 0 0 1 3003.dat

0 STEP </syntaxhighlight>

Other examplesEdit

See alsoEdit

ReferencesEdit

Template:Reflist

Further readingEdit

External linksEdit

Template:Lego