This is an old revision of the document!
Table of Contents
XL turtle geometry and graph construction
This tutorial is only on the static construction of a 3D model and the underlying graph. There is nothing chaining and there are not steps involved. Therefor our base code structure only requires the init function:
protected void init () [ Axiom ==> F; ]
This function is called very time you reset your model.(either with the rest button by recompiling/saving the code). The basic theory behind it is that the model always rests to the Axiom node and then runs the init function, if one is provided.
Turtle commands
That if we replace the Axiom with an F, a F node appears in the 2d graph is quite strait forward. The fact that this turns into a Cylinder in 3d is a bit more of a stretch. This is happening because 'F' is a so called turtle command.
Each turtle command is interpreted for the creation of the 3d model. We can imagine that a “turtle” starts at position (0,0,0) in the 3D scene and then follows the instructions given by the nodes in the graph. Reading the graph starts at the top at Node.0 and goes down through the nodes. The first two nodes (Node.0 and RGGRoot) have no effect on the turtle, but a F tells the turtle to draw a cylinder and move to the end of that cylinder. Therefore a second F would tell the turtle to do the same thing again:
protected void init () [ Axiom ==> F F; ]
Now looking at the list of turtle commands, we can see that F is suppose to have a parameter, which we did not give yet. If no parameter is provided most turtle commands will fall back to a default value, which means in the most cases that they do just nothing. Yet in the case of an F the default value is a length of 1 meter and a diameter of 10 cm.
Meaning Axiom ==> F(1,0.1) F(1,0.1);
would provide us with the exact same 3D model, but if you play around with this parameters you can change the dimensions of your cylinders.