(Showed how to create a conversation between sprites.)
(No difference)

Revision as of 01:04, 6 July 2013

Template:How To In Scratch, two or more sprites can talk to one another, having a conversation. There are several scripting methods associated with this, each unique to the other.


For this entire article, assume the two sprites conversing are "Scratch Cat" and "Gobo".

Broadcast Method

The broadcast method isn't always the most efficient way to make sprites communicate many messages, but short conversations can be easily made using broadcasts and no variables or lists. The following script would go into "Scratch Cat".

when gf clicked
say [hi!] for (2) secs
broadcast [Gobo 1 v]

Then, inside the Gobo sprite:

when I receive [Gobo 1 v]
say [how are you?] for (2) secs
broadcast [Scratch Cat 2 v]

The two sprites continuously broadcast back and forth to each other to say a message. However, when the conversation becomes long, multiple broadcasts are needed and the scripts can become unorganized.

Variable Method

The variable method uses a variable to trigger the other sprite to talk. After a sprite finishes speaking, it changes a variable by "1", in which the other sprite recognizes and then begins speaking. The following script would go into "Scratch Cat".

when gf clicked
set [talker v] to [1] //sets it so the conversation starts from the beginning and functions properly
say [Hi Gobo] for (2) secs
change [talker v] by (1) //signals Gobo to talk
wait until <(talker) = [3]> //wait until Gobo is done responding
say [I am good, how about you?] for (4) secs
change [talker v] by (1)

And for the "Gobo" sprite:

when gf clicked
wait until <(talker) = [2]> //wait until Scratch Cat greets
say [Hi Scratch Cat. How are you?] for (3) secs
change [talker v] by (1) //signals Scratch Cat to talk
wait until <(talker) = [4]>
say [I am great also!] for (3) secs

The script can keep cycling continuously. The script can become very long from a long conversation, but it doesn't use multiple of any broadcasts. The variable method is often best for unordered conversations, in which there are multiple sprites not speaking to one another in a patterned fashion.

List Method

The list method uses the same amount of scripting no matter how long the conversation is. It is a great method to reduce large scripts and a project's file size. The list method uses two scripts, one of "Scratch Cat's" messages and one of "Gobo's". The first sprite says a message, triggers the second sprite to speak, and then the cycle continues, with a variable being changed after both have fully spoken, to signal the next message from the lists. The lists are used to simply store the text which each sprite will speak, and is ordered within. The following script goes into "Scratch Cat"

when gf clicked
set [item# v] to [1] //so the first message is the first item in the list of messages
set [talker v] to [Scratch Cat] //to know that "Scratch Cat" speaks first
say (item (item#) of [Scratch Cat messages v]) for (3) secs //says the current item from the list of messages
set [talker v] to [Gobo] //signal "Gobo" to speak
wait until <(talker) = [Scratch Cat]> //wait until it's its turn to speak

And for "Gobo":

when gf clicked
wait until <(talker) = [Gobo]> //wait until it's its turn to talk
say (item (item#) of [Gobo messages v]) for (3) secs //say the item in the list of messages
change [item# v] by (1) //so the next message in the lists is said by each sprite instead of the same one
set [talker v] to [Scratch Cat] //signals "Scratch Cat" to speak