v9 Scratch-3-Tutorial Final
v9 Scratch-3-Tutorial Final
Acknowledgements
The Curriculum group of ACARA has developed this professional learning program to
support teachers in the 3-year National Innovation and Science Agenda (NISA) project
known as Digital Technologies in focus: Supporting implementation of Digital Technologies.
Julie King
julie.king@acara.edu.au
Permission to use Scratch user-generated content, and support materials is permitted under
the Creative Commons Attribution-ShareAlike 2.0 license.
Initiative of and funded by the Australian Government Department of Education and Training. ©
Australian Government Department of Education and Training.
CONTENTS Page
About this tutorial 3
Thought provoker 3
Your challenge 3
Your mission 3
Setting the scene 3
Section 1: Introductory tutorial 5
Starting a new project 8
Let’s revise 11
Opening a saved file (multiplier program) 12
Variables 13
Let’s recap 16
Next step: Joining the blocks 17
Joining it all together 18
Testing the code 19
Defining key terms 23
How can this look in your classroom? 24
Section 2: Creating a game 25
Setting up the game 26
Resizing a sprite 26
Editing the backdrop 26
Adding another sprite 28
The logic (an algorithm) 29
Making the cat move smoothly 29
Testing the cat’s movements 30
Keeping the cat within the track 32
Check your progress 33
Broadcasting a message 34
Coding a second sprite 36
Adding a sound effect 37
Placing a second sprite exactly where a first sprite is located 38
Creating some variables 39
Setting the variable to a known location 39
Setting up a constant start 42
Thought provoker
‘Design and programming are human activities; forget that and all is lost.’
Source: Bjarne Stroustrup, Danish computer scientist and developer of the C++ programming language
Your challenge
Understand the basics of simple code – this works equally well for visual programming
(block coding) and general-purpose programming – and how this applies to the Australian
Curriculum: Digital Technologies.
Your mission
● understand coding practices and use coding tools effectively
● analyse the complexities and logic of code using block (or visual) code
● use the visual programming language, Scratch, in either its online or offline versions,
to gain an understanding of input, output, sequences, looping, conditional branching
and variables
● explore teaching and learning opportunities in other areas of learning
● create valid assessment opportunities for students to demonstrate the required
standards and progress in their learning.
Availability
Online
The latest version of Scratch, Scratch 3.0 will work on a PC, Mac or iPad… basically any
computing device that can run a recent web browser (e.g. Chrome, Edge, Firefox, Safari) as
it is written in HTML5 and JavaScript. The previous online version (Scratch 2.0) worked on
computing devices that supported Flash Player. This is why it didn’t work on iPads.
Offline
Offline versions of Scratch are available starting with Scratch 1.4. Version 2,0 is
recommended if you have a Linux system, or version 3.0 if you have a Mac or Windows 10
machine.
Links to both the offline and online versions can be found here
(https://en.scratch-wiki.info/wiki/Compatibility_of_Versions_of_Scratch)
Alternatives
There are a range of alternatives including Snap! from Berkeley University
https://snap.berkeley.edu/. Snap! is affectionately known as Scratch on steroids – in some
ways it offers more coding opportunities but discussion of it is beyond the scope of this
tutorial.
Other alternatives include Blockly https://developers.google.com/blockly and Tynker
https://www.tynker.com/. There is also a program called Mind + which has online as well as
offline versions. It is useful for coding with external devices such as DF Robots and
micro:bits. http://mindplus.cc/en.html as well as the more traditional Scratch like coding.
ScratchJr is another alternative you may consider, especially if the students are from Prep to
Year 2. It has traditionally worked on an iPad only: https://www.scratchjr.org/.
A Desktop (offline) beta version of Scratch Jnr is available for download as well for a mac or
PC https://jfo8000.github.io/ScratchJr-Desktop/. Just note it is a beta version so may still
have a few bugs.
In this set of tutorials, the Scratch version is not too important except where indicated (only
using the draw function). The activities will work in offline mode in version 2 and 3 and in the
current online mode.
Before you start with this introductory tutorial you might like to initially watch the video
ScratchVariables (https://www.youtube.com/watch?v=1qAiiMJIc9E) to see examples of
perseverance, serendipity and collaborative learning.
Figure 1: Scratch layout (there are slight variances, depending on your version)
To control your actor or sprite, click on it so Scratch knows you are writing scripts for it and
then drag the script elements shown in Figure 2 (page 6), across to the scripting area on the
right. Each script element has a characteristic shape, and not all shapes will fit into all slots.
This is intentional (it’s based on the behaviour of Lego™) as it disguises the syntax issues
normally associated with general-purpose coding. Scratch is able to accept a variety of ways
of inputting instructions, such as clicking and pressing the space bar, as shown in Figure 2.
In each of these input cases, when the brown event is triggered, do what it says under it and
observe the result. You can have more than one script or code fragment available, each
responding to a different input event.
There are a variety of ways that you can start a program segment.
You can do the same thing to interact further with the user. Figure 3 (page 7) shows four
different bits of code that become increasingly useful. Try them out.
The fourth script in Figure 3 is repeated in Figure 4 – it’s a bit wobbly, isn’t it? Pull the script
apart and add a few new elements to give a better conditional branch.
This is better, but notice that a right answer plays up a bit – it just goes straight to the finish.
You miss out on the recognition you deserve. Why is that? Because computers are so fast,
you need to add a delay so you can see the result. This is done by putting a loop around the
question so you get more than one opportunity to answer a little later on.
Let’s demonstrate the speed of the computer with some movement.
You are going to code a new project to get the sprite to move in a square.
But first your previous coding will be forgotten unless you save it somewhere – you can
create a folder called Scratch on your desktop (right-click in any blank space on the desktop
and choose new folder) and save it there. You then have two choices:
• If in Scratch Offline editor, select File/Save as and choose the desktop folder you
created.
• If in Scratch Online, select File/Download to your computer and drill to the desktop
folder you created.
You will be using this old code later on, so best to save it.
Figures 6, 7 and 8 show the results of right-clicking on the top blue block of code and
selecting ‘duplicate’ this line, and everything under it will be duplicated. Soon the code will be
ready to run.
Now when you run your code, you can see what is happening because of the ‘wait’
commands. You can also use the sprite to draw the results of your code.
Figure 9: Scratch exercise You can make the code work smarter by using a command that
using pen commands
allows you to not type repetitive instructions.
In the orange control block there is a repeat command, as shown in Figure 10.
If you did, then great. If not, then you might have found another way that works – that’s great
too!
You’ve also learnt about a conditional situation – if something is true, do this or else do
something else, as shown in Figure 14. This is the third of the big three things that
algorithms can represent and code needs to do.
There is just one more thing that you need to go through – getting feedback from the user in
a useful way.
Go back to the original code that you saved in a folder on your desktop.
If you are saving online, just go to the folder icon on the menu bar at the top right and
choose the file you want to open. You need to log in to Scratch to save online. This is
probably the best way for students to save as they can move to new computers and once
logged in can still get their projects. The next step is to put a loop around the code so that it
will continue to ask you for an answer more than one time. The forever loop achieves this, as
shown in Figure 15. This loop will, as its name suggests, go on forever, even if you get the
correct answer. There are lots of ways to fix this but an easy way is to press the red stop
sign next to the green flag at the top of the stage window.
Another problem here is that this code only works for one problem – ‘4 times 10’ – this is
referred to as being hard coded. This is great if you want to concentrate on just that problem
but if you want to change the numbers you have to rewrite the program code every time.
This is not an efficient way of coding.
So let’s fix it so the code picks a random number for each multiplicand.
Variables
You’ll need to create three Variables (orange blocks) – one each to hold the value of the first
and second numbers and one for the value of the result of the multiplication (product).
You’ll have to create and name each variable needed
first.
To do that, click on Make a variable and give it a
suitable name. ‘X’ would be okay but ‘first number’ is
much more descriptive and easier to remember if the
code gets bigger and it is easier for another coder to
interpret. You will use it for this sprite only in this
example, as shown in Figure 16. That makes it a local
variable – something that will come up as you and your
students get more into coding. (In this example, it makes
no difference.)
If you want to test the code, you can put it in the coding area and click on it. A random
number will appear each time you click it. Give it a go.
The next step is to set your variables ‘first number’ and ‘second number’ to random numbers
between 1 and 10.
In the Variables block of commands you will see a block ‘set product to 0’. Note that ‘product’
has a down arrow next to it.
If you click the down arrow next to product you get the choice of first number, second
number and product, as shown in Figure 19. So, the block is happy to work with any of the
variables that you created.
Select first number and then add pick random 1 to 10 to the little square after ‘to’ where
the 0 is, as shown in Figure 20. If you have trouble placing things in the white circles or
squares, try dragging with the mouse arrow at the left end of the block you are dragging.
And the three commands you have created should look like Figure 23.
Figure 23: Scratch commands for multiplication with random selections for variables
Now you need to work out where to put them in the code. Good coding practice states that
you should initialise variables first. Put the code straight after when f key is pressed.
Your code should now look like Figure 24.
Let’s recap
You have decided to make the code choose random numbers to multiply each time you
press the ‘f’ key.
You have set up variables for the two random numbers ‘first number’ and ‘second number’.
You have set up a variable to store the result of the computation: ‘product = first number
x second number’.
You have placed all those variables at the start so later code can use them and know what
they are.
Next add the other join in the space that is left, as shown in Figure 27.
Now, if you read the command (without the join words and left to right) it reads how we want
it: ‘What is first number times second number’. This is something you will need to teach to
students as a great way to think about joins.
Next you need to put the complete join statement into the Ask block, as shown in Figure 28.
Figure 28: Scratch example of joining statements into the Ask block
If you haven’t moved your command blocks around too much the whole code will look like
Figure 29.
Figure 29: Scratch example of using variables, joins, ask and wait, loop commands
Can you see the last bit of code that needs to change? There is still something to do. Run
your code a couple of times and see what it does.
What needs to change is: if answer = 40 then.
You want the answer to equal ‘first number times second number’ and that will rarely be 40.
As luck would have it, you have created a variable already to hold the result of ‘first number
times second number’. It is called product. So, no matter whatever is the ‘first number’ and
whatever is the ‘second number’, product will always be the result of multiplying those two
numbers. Why? Because that is what we told the computer to do with this line, as shown in
Figure 30.
The next step is to go into the orange Variables blocks and drop the product variable into
the box that currently says 40, as shown in Figure 31.
To address this problem the first thing you need to do is change the forever loop to one that
will repeat until you get the right answer.
There is such a loop in Scratch and it is shown in Figure 32.
Note that it has a hexagonal space after ‘until’, where something can be placed.
Question: How can the program know when the correct answer has been supplied?
Answer: The same way that the if statement knows.
You can get the code to repeat until answer = product (see how it is in a hexagonal type
box as well).
So our repeat statement looks like that shown in Figure 33.
If you run the code now it will work brilliantly, but only once, and then you have to press
f again each time you want to run it.
That is okay, and you might want to stop there, but if you want the code to continually come
up with new questions, then you need to add another loop.
This time it can be a forever loop. If you put all the code in a forever loop then after the
correct answer is given, new random numbers will be chosen.
The code is shown in Figure 35. Try running it now.
Does it do what you wanted it to do? Hopefully you can answer ‘yes’.
Figure 35: Scratch code for generating a new question once a correct answer is given
Are you happy with the result? What happens with this code is when the question is asked, it
looks like what is shown in Figure 36. The ‘6times6’ format is neither conventional nor
attractive. It can be easily fixed by adding some white spaces (a space bar) to either side of
‘what is’ and ‘times’, as shown in Figure 37.
The result of adding the spaces is shown in Figure 38 – more attractive and conventional.
There is another part of this solution that needs fixing. While you see nicely spaced writing
on the stage, you also see the variables being displayed and one of them is the answer, as
shown in Figure 39.
There are times when variables on the stage are great, for example, for timers and scores,
but not for this project. You can hide the variables by going into the orange Variables blocks
and unticking the little boxes, as shown in Figure 40.
Figure 40: Scratch example of hiding variables from the stage by unticking
They will disappear from the stage as you do this (Figure 41).
Term Meaning
Input
Output
Looping
Variables
Conditional
statements
Figure 42 shows an image of a sample wire loop circuit and its underlying principles, which
form the basis of the game. School programs that take an integrated approach to this project
would need to initially focus on content related to electrical energy circuits before starting to
create this game. This resource focuses only on the programming aspect of the game.
Students make a game that focuses on the curved loop part of a circuit, with the user having
to negotiate the loop or ‘track’ to get from left to right. Each time a user touches the wall of
the track he or she will get a ‘zap’ (indicated by a buzzing noise) and lose a life.
There are many permutations on determining a winner of this game, such as the fastest time
to move from left to right, the highest score based on number of hits divided by fastest time
the least lives lost.
Resizing a sprite
To shrink Cat1, choose the icon that is circled in red, as shown in Figure 43, and then move
to Cat1 and click. Note that the icon to the left of the shrinker will enlarge the cat.
Figure 43: Adjust the size of sprite by changing the number (marked in red).
This is a percentage of its size
Then click the Backdrops icon, which you will find on the bottom righthand side of the
screen, as shown in Figure 45. Choose the paint tool so you can draw freehand. It is the
one highlighted in blue.
Figure 45: Scratch example of selecting Backdrops tab and brush tool
The next step is to draw a track that Cat1 follows. The track must be wide enough to let
Cat1 move through it without hitting the sides. It will have a left and right side, like a road. A
sample track is shown in Figure 46.
Note the size of the track compared to Cat1 – it is small enough to fit all the way around the
track and this is important. Of course, you can reduce or enlarge the size of Cat1 to suit your
track, as shown in Figure 43 (page 26).
If you make a mistake there is an eraser tool within the Backdrops edit screen as well as a
text tool, which will be discussed later.
To do: Draw your own track on the backdrop. Make sure it is just one colour!
Cat1 will be used until it hits the side of the track. When this happens, the second sprite
(Ghost, chosen from the sprite library, Figure 48) will be used because it has a shocked
expression, in keeping with the wire loop game theme. Cat1 will then reappear. It should be
effective, especially if you add other special effects. See ‘Adding a sound effect’ (page 37).
You can also find and upload your own images to use as sprites. It is suggested that you
save a selected sprite in the file where you keep all your Scratch programs. This allows you
to then retrieve it and use the ‘Upload Sprite’ icon, as shown in Figure 48. Any other sprite
you chose will also appear in your sprites area.
To do: Change the size of the Ghost to be smaller than the Cat1 sprite so they are both
about the same height.
To do: Get another sprite to use for when Cat1 touches the edge. There is a Lightning bolt
within the built-in library if you don’t want to use a Ghost.
Now you are almost ready to start coding. But first you need to think about, and document,
what you want Cat1 and the game to do, the decisions that need to be made and the order
of events. This is where you write an algorithm to help capture your logic and drive your
coding. Note: At Years 5 and 6 the achievement standard states that students should be
able to write algorithms.
You make Cat1 move by including some if statements inside a loop that checks forever if the
condition is true. Let’s start with when green flag clicked.
To start, let’s get Cat1 to move to the right when the green flag is clicked and the right arrow
key is then pressed. The code to achieve this is shown in Figure 51. Create that code
yourself and try it out.
Figure 51: Code to start Cat1 moving to the right of the track
To do: Try changing ‘change x by 2’ to some other number and see if there is still smooth
movement.
You want a low number like ‘2’ so that Cat1 can be controlled in small increments.
Now you need three other if statements to cover the other three arrow keys (left, up, down).
See if you can code it yourself. The answer is shown in Figure 53 (page 31) but you should
try it to learn how to do it for yourself.
Figure 52: An additional sprite (a donut) is added at the end of the track
If you are successfully moving Cat1 around the stage, your code should look very similar to
that shown in Figure 53.
Figure 53: Code showing if statements for moving Cat1 around the stage
You are going to finish with the code you have created (like that shown in Figure 53) and
begin a new set of blocks, which will also start working when the green flag is clicked. You
can put this new set of instructions right beside the one you have already created. At the
start it will look like Figure 54.
Now that you can choose a colour, move the hand over the track and when the little colour
square is the same colour as the track edge, click to lock in that colour. Hopefully you made
your track only one colour, as suggested earlier.
You want a forever loop to constantly check and you want two levels of if statements (nested
conditional statements). The first if statement will check if the edge is being touched – if it
isn’t being touched you don’t want it to do anything. The second-level if statement will
determine what key is being pressed, so you know which way to go back a couple of steps.
The first nested loop looks like Figure 56.
The forever loop checks forever if Cat1 is touching an edge (touching something black, the
colour of the track shown in Figure 52). If this is the situation, then if the right arrow key is
being pressed, you need to change the x axis by –2 to move Cat1 away from the edge.
To do (maybe): You could talk to your students about Cartesian maths and x and y
coordinates at this point.
If the left arrow is being pressed, then instead of it returning –2 steps, you want it to return
2 steps, so the new code will look like that shown in Figure 57.
Figure 57: Code for moving away from an edge if right or left
arrows were pressed
To do: Code this much and then try it out in your program. Adjust the values to -5 and 5 if
needed.
See if you can complete the code to deal with the situations when Cat1 touches the track
edge when moving up or down. The finished code is shown in Figure 58 (page 34), but again
it would be good for you to try it first.
Now you will get the rest of the code working, starting with logic point 3, which has three
parts to it:
If Cat1 hits any track edges (in black) I want it to do three things:
a. Swap to the Ghost and play a sound. The Ghost needs to be in exactly the same
spot as Cat1. When it is being shocked the cat should hide.
b. After being shocked, Cat1 should return to its normal self and the Ghost should hide.
c. After being shocked, Cat1 should return a couple of steps back from where it hit the
track edge.
Before you start coding, just check that your code is like that shown in Figure 58 (page 34).
Figure 58: Code for moving the sprite along and also away from an edge if right, left, up
and down arrows were pressed
Broadcasting a message
Scratch has an interesting way of letting other parts of the program know what is happening.
It is called broadcasting and it means letting other code know when something is happening
that it is waiting for.
You are going to use broadcasting to make the Ghost appear, make Cat1 disappear, play a
sound and then get Cat1 to reappear. It should look pretty good if you do it correctly.
Start by choosing the Event block that looks like Figure 59.
Drag the block into the coding area for Cat1 (where all the code is at this stage). Click the
down arrow on the block and choose new message. Call the new message ‘Zapped’. Drag
another similar ‘Event block’ into the coding area and create another new message called
‘zapped_over’. You should have two blocks that look like Figure 60.
The logic is that when ‘Zapped’ is broadcast, Cat1 should disappear. When ‘zapped_over’ is
broadcast, Cat1 should reappear. To do this, add hide and show to the respective Event
blocks, as shown in Figure 61.
Next you need to work out when to broadcast the message. If you do it whenever Cat1 is
touching the edge, (black colour) then this might cause a constant loop to occur. You want it
to broadcast only after Cat1 has moved back away from the edge. Therefore, you need four
broadcast messages. The broadcast message looks like Figure 62. You want to broadcast
‘Zapped’ regardless of which arrow key made Cat1 touch the edge.
The logic is: Check to see if Cat1 is touching the edge. If it is, then work out which key is
being pressed and move back two steps. Then broadcast ‘Zapped’. If ‘Zapped’ is received,
then hide Cat1.
Next you will make the Ghost do several things: appear when ‘Zapped’ is broadcast, flash a
couple of times, play a sound and then disappear. Also, you need to broadcast another
‘zapped_over’ message to let Cat1 know when to reappear.
You are finished with Cat1 for now but will return to do a couple of quick things at the end.
Remember: If using the offline editor, go to File on the top ribbon, choose Save as and pick
a location you will remember.
If in Scratch Online, choose File/Download to your computer and save to somewhere you
will remember.
If the Ghost cannot be seen anywhere on the stage area (anywhere near your track or donut
or Cat1), then drag it in from the sprites area.
In the Ghost coding area, choose another when I receive Zapped Event block (as shown in
Figure 65). Also choose a when green flag clicked block. The first thing you want to do is
when the green flag is clicked you need to make sure the Ghost doesn’t appear. When the
program starts, it needs to hide.
You are going to add a repeat loop, which will make the Ghost appear and disappear twice
with a 0.3 second wait time in between. You will also broadcast ‘zapped_over’ after the loop
is finished, so that Cat1 will know to reappear.
To do: Try doing this before looking at the code shown in Figure 67.
The logic: When the green flag is clicked, Ghost will hide and Cat1 will be able to move
around and crash into the edge of the track. If it does, a message called ‘Zapped’ will be
broadcast. Ghost is waiting for this message. When it comes, it will flash twice and then
hide. It will also broadcast ‘zapped_over’. Cat1 is waiting for this message. It will alert Cat1
to reappear (show).
The code for this is shown in Figure 67.
Remember, the code is in the Ghost coding area. You’ve probably tried it out and have
noticed a big problem. Can you identify the problem?
Before you tackle the problem, you are going to add a sound effect.
Notice the block has a dropdown arrow. When you click it there are no more presets but you
get the choice to record. You are not going to do that. Instead, go up to the ‘Scripts,
Costumes, Sounds’ tabs and click on ‘Sounds’, as shown in Figure 69. Choose New sound
from library (as shown in Figure 70), go to Effects, click on rattle and choose OK at the
bottom right of the window.
Click the Scripts tab again and when you go to play sound meow until done, click the
down arrow and ‘rattle’ will come up as a choice – select it, as shown in Figure 71. You want
to place the play sound block after the Ghost appears. It will play until the loop is complete
(until done).
Click on ‘Make a Variable’ again and this time call it ‘xpos’ (for x position). Again, make it For
all sprites. Do the same a third time, this time calling it ‘ypos’ and making it ‘For all sprites’.
Your three variables should look like Figure 75. Notice that each has a little grey box next to
it. This is how variables are depicted in Scratch.
Go into the Motion blocks and look at the very bottom. What do you notice?
There are three items that also look like variables – called ‘x position’, ‘y position’ and
‘direction’, as shown in Figure 77. These will give you the current x and y coordinates for the
sprite you are coding. Drag the blue x position block to where the 0 currently appears in the
set xpos to 0, as shown in Figure 78. You can do the same with the set ypos to 0 block.
You are now going to add these blocks to the bottom of the first block of code you created,
making it look like Figure 79.
All you need to do now is go into the Ghost coding area (choose it from the sprites so it has
a blue box around it and its code appears). From the Motion block set (dark blue) choose the
block that looks like Figure 80.
Remember you have created two variables that are holding the current x and y coordinates
of Cat1. You are going to use them now.
Go into Variables blocks and choose the variable xpos. Drag it into the blue go to x: block
Figure 81.
Do the same thing with the ypos variable. You should have a block of code that now looks
like Figure 82.
Now think about where it should go in the Ghost code. It should go to that location as soon
as the ‘Zapped’ message is broadcast. It will still be hidden at this stage, but that is okay. It
will become visible very soon after it gets there. Your code for the Ghost now looks like
Figure 83.
Note: If you made your ‘xpos’ and ‘ypos’ variables ‘For this sprite only’, then you would not
see them in the Ghost sprite coding area.
To do: Try out your program now and see where Ghost appears.
You might see the two variables ‘xpos’ and ‘ypos’ appear at the top of the stage area, like
that shown in Figure 84. You don’t want this, so you can simply untick the corresponding
variables in the code area to hide them and they will disappear.
The other variable you created, ‘counter’, is going to be used to count up how many times
the track edge is touched. In this case you want the variable to appear at the top of the stage
area.
The best place to put the code for this is when ‘Zapped’ is broadcast, as it is broadcast each
time the edge is touched. So still in the Ghost coding area, go to Variables blocks and
choose the change counter by 1 block. Place this block after (or just before) the broadcast
‘zapped_over’ command at the end of the code. Your code should now look like Figure 85.
To do: Try out your program now and see if the counter works accurately.
There are only a couple more quick things to do to make the code complete. You have
finished with the Ghost code, so go back to the Cat1 coding area by choosing its sprite in the
sprites area.
Now drag Cat1 to its starting position. You will notice that at the bottom of the stage area is
an x and y coordinate readout, as shown in Figure 87.
This tracks the mouse location but you can take a good
guess about Cat1’s actual location. When you drag Cat1 to
its starting position the x readout is about –220 and the y
readout is about –150. You will use those numbers to set the
initial (home) position of Cat1.
In the blue Motion blocks you need to choose the block that
says go to x: (number) y: (number). Replace the numbers
in the ovals with –220 and –150 (or if your start position is
different with your x and y start position numbers).
To finish off the game, have Cat1 say something when it reaches the donut. Then you will
stop the program completely.
You will use the second block to house this little bit of code. It could probably go in the first
block, but this way the blocks will be about the same length and you can get Cat1 to do
something if it is not touching the edge but is touching the donut.
To do: Try working out how to do this last little bit. The code is in Figure 89 if you get stuck.
This section provides two short exercises that extend advice provided in Section 2, a list of
resources, including projects and online coding resources that feature other visual
programming languages, as well as assessment advice.
Extension exercises
The following two extension exercises enhance your skills in controlling movement and
playing sounds.
Controlling movement
This exercise extends what is covered in Section 2: Creating a game. Controlling movement
has great applications in learning mathematics, designing games and animation, as it can be
very precise.
Choose File/New to start a new coding session. Select Stage and click on the bottom icon
underneath to choose a new backdrop from the library, as shown in Figure 90.
Save and upload an xy-grid image to use as a background from the Scratch wiki
https://en.scratch-wiki.info/wiki/File:Xy-grid.gif. Figure 91 shows the results of that backdrop.
Now your stage looks like a Cartesian plane with horizontal and vertical number lines.
Click on any of the Motion (blue) commands to see what they do.
If your sprite moves off screen or turns upside down, you can always get back to where you
started (the origin), the right way up, by clicking on ‘point in direction 90’ and ‘go to x:0 y:0’
motion blocks, as shown in Figure 92.
Figure 92: Scratch uses 0,0 as the origin (centre of the stage) and 0°,
90°, 180° and 270° for north, east, south and west, respectively. Just
like a compass, 0° is the same direction as 360°
Playing sounds
Have fun exploring sounds (use headphones) and costumes. Combine these to make
something interesting happen. Also try using the Broadcast blocks – they add a whole new
dimension to what you can do with block coding.
Resources
You don’t have to look far in Scratch to find help. It has lots of helpful tips that come up when
you click on ‘Tutorials’ on the menu bar, as shown in Figure 93. These help you go through
projects step by step – a great way to challenge students if you are not so sure yourself!
There are other tips as well, such as creating effects, animation and games; telling stories,
and working with music.
Figure 93: You can access lots of tips from the menu bar
Apart from tips, there are thousands of projects available online where students can see how
other programmers got things working.
These are available in the online version only under ‘Explore’, as shown in Figure 95
(page 48).
In Explore, students can load and play the programs that others have created.
Students can also click on 'See inside’ (the blue button) to see the code, as shown in
Figure 96 (page 48).
In Scratch, students are also encouraged to change the code of others (as long as credit is
given). This is called remixing and it helps students to learn more about coding. Students
can upload their own code or remixed code for other users to play and use. It is very
collaborative and many students really enjoy the site. You might want to think about getting
all your students to sign up. They can save their work online and continue working on it
anywhere they have internet access and a computer.
Assessment
The achievement standards in the Australian Curriculum describe the expected learning of
students at designated points. For Digital Technologies this is the end of a band of years.
The achievement standards are the standard upon which you make judgments about
students’ progress. The results of such assessments should help frame your teaching and
learning programs in order to progress students from one level of achievement to the next.
To see the Digital Technologies Achievement Standards for Years 3 and 4, Years 5 and 6
and Years 7 and 8 visit www.v9.australiancurriculum.edu.au/ > F-10 > Technologies > Digital
Technologies > Years 3 and 4 (or Years 5 and 6 or Years 7 and 8) > Achievement
Standards.
The following extracts from the Digital Technologies achievement standards focus on the
expected learning by students related to designing solutions and using a visual programming
language to implement digital solutions. Note: While students at Years 7 and 8 should be
studying a general-purpose programming language, they can still use a visual programming
language to create digital solutions.
It should be noted that most of the content of this resource focuses on using a visual
programming language to implement a solution – just one aspect of students becoming
innovative creators of digital solutions. The relevant component of the achievement standard
for these bands is stated below.
Assessment opportunities
When creating assessment opportunities, it is important that there are direct connections
between what is taught (content descriptions) and what knowledge and skills are being
assessed (achievement standards).
Listed are some assessment suggestions to help you measure student progress.
• A screen recording where the coder shows how the code works and the contribution
made by some parts.
• Get Year 5 students to design a game for Year 2 students and then have the Year 2
students provide feedback to the coders. Guidance on the scope of feedback should
be provided to the Year 2 students.
• Journal entries of the steps and changes made in developing codes as well as
algorithms. This might be a digital journal using screen shots, where appropriate.