tutorials:xl-turtle-geometry
Differences
This shows you the differences between two versions of the page.
Both sides previous revisionPrevious revisionNext revision | Previous revision | ||
tutorials:xl-turtle-geometry [2024/11/29 11:13] – [Transformation] tim | tutorials:xl-turtle-geometry [2024/12/18 10:02] (current) – [3D objects] Tim | ||
---|---|---|---|
Line 54: | Line 54: | ||
The **moving** part is already covered by the M node for now. | The **moving** part is already covered by the M node for now. | ||
- | You can **rotate** the turtle along the three axes x, y and z. We can see an example of the rotation tool on the right with the possible rotations in colors: x=red, y=blue and z=green. In the turtle geometry we can rotate these axes with the commands '' | + | You can **rotate** the turtle along the three axes x, y and z. We can see an example of the rotation tool on the right with the possible rotations in colors: x=red, y=blue and z=green. In the turtle geometry we can rotate these axes with the commands '' |
Following up on our little example above you could think about rotation the short cylinder 30 degrees up like: | Following up on our little example above you could think about rotation the short cylinder 30 degrees up like: | ||
Line 65: | Line 65: | ||
|{{: | |{{: | ||
- | || | + | |The result of rotating the second cylinder up 30 degrees| |
- | ===== Local transformation ===== | + | |
- | ===== Modules ===== | + | You can try this also with the RL command and will a very similar result, with RH on the other hand you will see nothing because a cylinder is round and you cant see if it is rotated on the head axes. |
- | ==== Instantiation rules ==== | + | That brings us to the next step: **combining transformations**, |
+ | <code java> | ||
+ | protected void init () | ||
+ | [ | ||
+ | | ||
+ | ] | ||
+ | </ | ||
- | ===== Edge types ===== | + | |{{: |
+ | |The result of rotating the turtle first on the head axes and then rotate it up| | ||
- | ==== Branches ==== | + | You can now try to switch the order of the commands to '' |
- | ==== Decomposition & custom ==== | + | Looking at the list of turtle commands, you can see that there are more rotations such as RV or RD you can explore. |
+ | |||
+ | There are also more computer graphics oriented approaches embedded in the GroIMP turtle commands: Translate(x, | ||
+ | |||
+ | **Translate** is moving the turtle for the given values on the local x,y,z axes: | ||
+ | <code java> | ||
+ | protected void init () | ||
+ | [ | ||
+ | Axiom ==> F Translate(3, | ||
+ | ] | ||
+ | </ | ||
+ | |{{: | ||
+ | |||
+ | Similarly the **Rotation** command is rotating around all 3 local axes at the same time. They do not influence each other that way so a rotation on the head axes would once again be not that impressive in our case. | ||
+ | |||
+ | <code java> | ||
+ | protected void init () | ||
+ | [ | ||
+ | Axiom ==> F Rotate(20, | ||
+ | ] | ||
+ | </ | ||
+ | |{{: | ||
+ | |||
+ | Finally the **scale** command can be used to change the size of all following commands, either proportionally or depending on the axes. For example if you want your howl model to be halve the size without chaining any parameter you could just add a Scale(0.5) in the beginning: | ||
+ | <code java> | ||
+ | protected void init () | ||
+ | [ | ||
+ | Axiom ==> Scale(0.5) F Rotate(20, | ||
+ | ] | ||
+ | </ | ||
+ | This will give us the same result as before only a smaller... | ||
+ | Additionally, | ||
+ | <code java> | ||
+ | protected void init () | ||
+ | [ | ||
+ | Axiom ==> F Rotate(20, | ||
+ | ] | ||
+ | </ | ||
+ | |||
+ | |{{: | ||
+ | |||
+ | ===== 3D objects ===== | ||
+ | |||
+ | As mentioned above in GroIMP we are not limited to the turtle commands but we can also use geometrical objects. | ||
+ | |||
+ | |||
+ | <code java> | ||
+ | protected void init () | ||
+ | [ | ||
+ | Axiom ==> F Sphere(1); | ||
+ | ] | ||
+ | </ | ||
tutorials/xl-turtle-geometry.1732875199.txt.gz · Last modified: 2024/11/29 11:13 by tim