Tinkercad has brought coding to its 3D modeling platform with the introduction of the web app Codeblocks. Rather than drawing the design, as one might in a turtle art graphics environment, this is object-oriented programming, meaning that you place a predefined object on the workplane and then modify it. The basket in the example below consists of a six-sided torus shape that is repeatedly rotated up and around 27 times to form a circle.
data:image/s3,"s3://crabby-images/ccf59/ccf59038baa5a165589586cc87d2f5d343fcbfcd" alt="Code your 3D designs with Tinkercad’s new Codeblocks app"
Code your 3D designs with Tinkercad’s new Codeblocks app
Tinkercad released Codeblocks last June, and now that it's out of beta, Pioneer Pioneer Rob Morrill tells us how he uses it at St. Matthew's Episcopal Day School.
data:image/s3,"s3://crabby-images/cdbc6/cdbc6bde3374e3d5368e3622839f22103df50d95" alt="01 codeblocks design"
data:image/s3,"s3://crabby-images/bf95f/bf95fbcdd840853267f5bf5ddb2645b0b9bc9be9" alt="02 codeblocks project example 03"
In traditional Tinkercad, you build models by dragging basic shapes like a box, cone, or wedge onto the workplane. Codeblocks is similar, but rather than dragging a shape out to the workplane and then resizing it, you drag a block of code for an object whose parameters you can adjust.
data:image/s3,"s3://crabby-images/fd9ef/fd9ef8e52d8e1804329635e3aab86229ed643372" alt="03 solid 01"
Note that the shape loads on the workplane at X, Y, Z coordinates 0, 0, 0. This means that half of a 20 x 20 x 20 millimeter cube will be underneath the workplane. Red, green, and blue lines delineate X, Y, and Z respectively. Following the Add Box block with a purple Move block with a value of 10 for the Z axis will raise the cube to sit on the workplane.
data:image/s3,"s3://crabby-images/08785/087858f3b3d484a196d83123bc381989a6c42178" alt="04 solids 02"
Here, a box and a sphere have been added and raised in the Z axis, while the cone was not only raised and rotated 180 degrees, but also turned into a hole.
data:image/s3,"s3://crabby-images/ba1ed/ba1edf1f771d271ce51dc00d907419c90e061fa3" alt="05 adding solids"
Adding a Create Group block groups these three shapes together.
data:image/s3,"s3://crabby-images/be802/be80229f784f9088424ba54bf53524e05206f89f" alt="06 adding solids 01"
The power of Codeblocks becomes apparent the more you take advantage of coding aspects like loops and variables to control and iterate your designs. Here is a simple loop that uses a variable to rotate rings around 0, 0, 0.
data:image/s3,"s3://crabby-images/69f06/69f0676b4244ad73e595fee709076929abb14763" alt="07 rotation"
This laser-cut cardboard disk helps students understand the polar and Cartesian movements in the Codeblocks environment.
Add a torus shape to 0, 0, 0.
data:image/s3,"s3://crabby-images/cf408/cf408ed52371efd98422edd9d33fe5386c8fa699" alt="08 quadrants 03"
Move the torus in a positive Y direction.
data:image/s3,"s3://crabby-images/9f73c/9f73cbf446adb0ffe3f4308dc73d03e5276f8c26" alt="09 quadrants 06"
Rotate the torus around 0, 0, 0.
data:image/s3,"s3://crabby-images/1b6fc/1b6fc5aaf1fddcfd94f5aee2cb1599eb9afc4e14" alt="10 quadrants"
Add, move, and rotate a second torus.
data:image/s3,"s3://crabby-images/6eff6/6eff637134ddb7674e2c664fbc068a433a0ca528" alt="11 quadrants 02"
Add, move, and rotate a third torus.
data:image/s3,"s3://crabby-images/99ac6/99ac683a0bffd51952987466d2bbb564df869062" alt="12 quadrants 05"
Repeat 8 times.
data:image/s3,"s3://crabby-images/cbbc6/cbbc639ac2baacf4298658926ddcf26e41b54470" alt="13 quadrants 04"
This basket is made up of hearts that have been duplicated and rotated.
data:image/s3,"s3://crabby-images/83764/83764a84d4aa65f1aacc953c59a760b480733fd4" alt="14 codeblocks and tinkercad 02"
The export button allows you to export as STL or OBJ files for 3D printing, but you can also export the design as a “Part”.
data:image/s3,"s3://crabby-images/22520/22520e62f870f5605f8b9c64ca42c6db9ab15fa5" alt="15 export"
When you save a Part, the design becomes available back in traditional Tinkercad, where you can resize it and add it to other creations.
data:image/s3,"s3://crabby-images/5fab4/5fab4ff3fd2a103508a7c6b883e398f1a0ead789" alt="16 create a part"
The red elements of this design have been added to the original blue Codeblocks design using traditional Tinkercad.
data:image/s3,"s3://crabby-images/95772/9577218880e717f16287e30a0242dfc505d50367" alt="17 codeblocks and tinkercad 01"
From traditional Tinkercad, you can also export the design in SVG format, which then allows you to paper or laser cut it.
data:image/s3,"s3://crabby-images/eccc7/eccc793ef17f8a3cbe638e98bc084c2d05341a30" alt="18 products 03"
These earrings were designed in Codeblocks and then laser cut.
data:image/s3,"s3://crabby-images/ef610/ef610ed2ffccac24e562ae5f89996b2d6e5707aa" alt="19 products 01"
The sides of this lamp were designed using a combination of traditional Tinkercad and Codeblocks.
data:image/s3,"s3://crabby-images/6a3c3/6a3c323662279802fd8e6b1e22803a5d41801ff0" alt="20 products 02"
This sign uses a combination of traditional Tinkercad and Codeblocks.
data:image/s3,"s3://crabby-images/0230a/0230a4c4b89ebf4be3b088e2138df1c6ebb8255e" alt="21 codeblocks and tinkercad 03"
This clock’s face was designed in Codeblocks and laser cut.
data:image/s3,"s3://crabby-images/5f061/5f061239d1d782f5e60e2afc53e340f64efa7022" alt="22 products 04"
For a good introduction to generative design, see “Some Thoughts on Generative Art” by Anders Hoff, and watch Kate Compton’s presentation “Generative Art (and Games and More)” from JSConf Iceland.
Codeblocks also makes it easy to experiment with generative design. The building heights in this cityscape and the ridges in this Martian crater were randomly generated.
data:image/s3,"s3://crabby-images/dd35e/dd35eb88eb1168305176f5f563af5f6b006586aa" alt="23 parametric 01"
data:image/s3,"s3://crabby-images/c0154/c0154d3116bd31d888460e49eaf2af675a50e4f6" alt="24 codeblocks project example 02"
data:image/s3,"s3://crabby-images/de713/de71338692a44f10e83d283b7d7fc95a503ea920" alt="25 codeblocks project example 01"
Another great feature of Codeblocks for teachers and learners is the ease with which you can comment on your code. This helps students make their thinking visible, which aids both in their own metacognition as well as in allowing teachers to gain insight into their understanding.
data:image/s3,"s3://crabby-images/cafe1/cafe1b597899586c5fbc264a2c84bb967b5da9ed" alt="26 blocks"
Access Codeblocks either by going to traditional Tinkercad and finding the link, or by going straight to: https://www.tinkercad.com/codeblocks
data:image/s3,"s3://crabby-images/9aa73/9aa730091c9134fc91641f1b0d9a682cf3bd997e" alt="27 codeblocks"
Codeblocks’ opening page contains starter projects that let you see how a variety of blocks can be used in different ways.
data:image/s3,"s3://crabby-images/2192c/2192c30476d2bde446d0e21a0e7db8f2ede4dac5" alt="28 starters"
Here is a quick video on a “Codeblocks Intro”:
And here is a longer tutorial: “Getting Going with Codeblocks”:
Explore, have fun, and share your designs.