Spirograph on Scratch
data:image/s3,"s3://crabby-images/35814/3581406e69b837601fb32ae82d1088ce01b9a1ec" alt="fjkljj.png"
Today, you will be making a spirograph on the block-based coding site Scratch.
Supplies
Internet
Scratch with the pen extension
data:image/s3,"s3://crabby-images/0ed6d/0ed6d90a73abb010221d5cc38d43c587d04f4636" alt="vmsb.png"
Open the Scratch interface, either offline or online. I did this project offline.
If you are creating this online, use this link and make sure to sign in to keep your work. https://scratch.mit.edu/
If you do not wish to use the Internet, make sure you have downloaded and installed Scratch Desktop.
data:image/s3,"s3://crabby-images/72de2/72de264401a549290bc0cacb56ef16cf62dd3bd9" alt="grhsutgyegsdgevb.png"
Add a sprite. I used a ball.
data:image/s3,"s3://crabby-images/b3f7f/b3f7f0494c40e60fccf76137f859badd50d3a734" alt="dfgui.png"
Create the following variables:
Degrees
Rate of change (moving) // how much x changes every time the cat moves
x
data:image/s3,"s3://crabby-images/778c6/778c6e18eb6a110706687d03c4158753f3babece" alt="fjcxdblghkbtfgjh.png"
Define a block called setup
Setup
erase all
pen up
go to center // x = 0, y = 0
pen down
set pen color red // Color = 0, Brightness = 100, Saturation = 0
set (variable) x to Rate of change (moving)
data:image/s3,"s3://crabby-images/778c6/778c6e18eb6a110706687d03c4158753f3babece" alt="fjcxdblghkbtfgjh.png"
Define a block called draw (steps) (degrees) (rate of change)
Draw (steps) (degrees) (rate of change)
move (steps) steps
turn right (degrees) degrees
change (variable) x by (rate of change) // the my block variable
change pen color by 1
data:image/s3,"s3://crabby-images/aec2a/aec2a058844ecef689e09093981d990d549cf628" alt="xfgasuyfdtuisr7ikfg.png"
Create the following code
When green flag clicked
setup
forever
draw [variable (x)] degrees rate of change (moving)
When I receive (message) draw // create new message
draw [variable (x)] degrees rate of change (moving)
When I receive (message) clicked & responded // create new message
stop other scripts in sprite
setup
broadcast (message) draw
data:image/s3,"s3://crabby-images/d2a68/d2a68466540662760e4e2a884fd66643ea1717d3" alt="fgdbhk.png"
In the other sprite (in this case the ball), create and define the following blocks:
Clicked
ask (New rate of change) // the question in parenthesis so it is not confusing // and wait
set (variable) rate of change (moving) to answer
ask (New degrees) and wait
broadcast (message) clicked and responded
set (variable) degrees to answer
Clear
erase all
go to x; 173 y; 142 // not necessary*
data:image/s3,"s3://crabby-images/9b8f8/9b8f8947ac9e416d8a76cb4adcab37cf9ae4c78a" alt="hfjiry89p;.png"
Create the following code:
When green flag clicked
go to x; 173 y; 142 // *reason why not necessary
clear // my block
forever
wait 0.1 seconds
next costume // not necessary
When this sprite clicked
clicked // my block
clear // my block
Time to Test!
data:image/s3,"s3://crabby-images/dae34/dae34fe3436df2f6dbca6332fd72205170cc8f46" alt="eiohgy8e4.png"
Steps 9-11 will be the testing phase.
But a reminder: I suggest using Turbo Mode because I tested it regularly and it took FOREVER! But in Turbo Mode it took less than 10 seconds!
Setting With the Ball
data:image/s3,"s3://crabby-images/f46ae/f46aee7a3a0d0b73b5c96557d13599e1fa6abaaf" alt="mhkudfoyt.png"
data:image/s3,"s3://crabby-images/1409f/1409f3d3e5f2882665128014ee06468c2232cbc4" alt="ghjk.png"
I set the rate of change to 0.1, and the degrees to 35.
The Result
data:image/s3,"s3://crabby-images/35814/3581406e69b837601fb32ae82d1088ce01b9a1ec" alt="fjkljj.png"
And a reminder: it took less than 10 seconds because I used Turbo Mode.
P.S: This isn't a perfect spirograth. When the "drawing" sprite (in this case the cat) eventually touches three (or 4) borders in a row, then it starts messing up. The right border will most likely be the third border touched by the "drawing" sprite.