Scratch Novatec

Fazer download em pdf ou txt
Fazer download em pdf ou txt
Você está na página 1de 27

Aprenda a

Programar com
S c r at c h
Uma introduo visual
p r o g r a m a o c o m j o g o s , a r t e,
cincia e matemtica

Ma j e d Ma r j i

novatec

Copyright 2014 by Majed Marji. Title of English-language original: Learn to Program with Scratch, ISBN 978-159327-543-3, published by No Starch Press. Portuguese-language edition copyright 2014 by Novatec Editora Ltda.
All rights reserved.
Copyright 2014 por Majed Marji. Ttulo original em Ingls: Learn to Program with Scratch, ISBN 978-1-59327-543-3,
publicado pela No Starch Press. Edio em Portugus copyright 2014 pela Novatec Editora Ltda. Todos os direitos
reservados.
Novatec Editora Ltda. 2014.
Todos os direitos reservados e protegidos pela Lei 9.610 de 19/02/1998. proibida a reproduo desta obra, mesmo
parcial, por qualquer processo, sem prvia autorizao, por escrito, do autor e da Editora.
Editor: Rubens Prates
Traduo: Lcia Kinoshita
Reviso gramatical: Marta Almeida de S
Editorao eletrnica: Carolina Kuwabata
ISBN: 978-85-7522-312-3
Histrico de impresses:
Julho/2014

Primeira edio

Novatec Editora Ltda.


Rua Lus Antnio dos Santos 110
02460-000 So Paulo, SP Brasil
Tel.: +55 11 2959-6529
Email: [email protected]
Site: www.novatec.com.br
Twitter: twitter.com/novateceditora
Facebook: facebook.com/novatec
LinkedIn: linkedin.com/in/novatec

In t rodu o ao Scr atch

Voc j sentiu vontade de criar o seu prprio jogo de


computador, uma histria animada, um tutorial ou uma
simulao cientfica? O Scratch uma linguagem de programao grfica que facilita a criao dessas aplicaes,
alm de outras tarefas. Neste captulo introdutrio, voc ir:
explorar o ambiente de programao do Scratch;
conhecer diferentes tipos de blocos de comando;
criar o seu primeiro jogo no Scratch.
Ao criar uma aplicao no Scratch, voc pode salv-la em seu computador
ou pode carreg-la no site do Scratch; nesse ltimo caso, outras pessoas podero fazer comentrios ou transform-la em novos projetos.
Animado? Ento vamos comear!

O que o Scratch?
Um programa de computador nada mais do que um conjunto de instrues
que dizem o que um computador deve fazer. Essas instrues so escritas por
meio de uma linguagem de programao, e aqui que o Scratch entra em cena.
A maioria das linguagens de programao baseada em texto, o que significa
que voc deve dar comandos ao computador no que parece ser uma forma enigmtica de ingls. Por exemplo, para exibir Hello! na tela, voc pode escrever:

print('Hello!')

(na linguagem Python)

std::cout << "Hello!" << std::endl;

(na linguagem C++)

System.out.print("Hello!");

(na linguagem Java)

Aprender essas linguagens e entender suas regras de sintaxe pode ser um


desafio aos iniciantes. O Scratch, por outro lado, uma linguagem de programao visual. Ele foi desenvolvido no Massachusetts Institute of Technology (MIT)
Media Lab para tornar o aprendizado de programao mais fcil e mais divertido.
No Scratch, no necessrio digitar nenhum comando complicado. Em
vez disso, voc ir conectar blocos grficos para criar programas. Voc est
confuso? D uma olhada no programa simples apresentado na figura 1.1, que
eu irei explicar.

Um programa do Scratch
que contm um nico bloco

O resultado
da execuo
do programa

Figura 1.1 Ao executar esse bloco do Scratch, o gato diz Hello! em um balo.

O gato que voc v na figura 1.1 chamado de sprite (ator). Os sprites entendem e obedecem a conjuntos de instrues que voc lhes atribui. O bloco
roxo esquerda diz ao gato para exibir Hello! em um balo. Muitas das
aplicaes que sero criadas neste livro contero vrios sprites, e voc utilizar
blocos para fazer com que os sprites se movam, girem, digam algo, toquem
msica, realizem alguma operao matemtica e assim por diante.
Voc pode programar em Scratch ao juntar blocos diferenciados por cores,
como seria feito com as peas de um quebra-cabea ou com blocos de LEGO. As
pilhas de blocos que forem criadas so chamadas de scripts (roteiros). Por exemplo, a figura 1.2 mostra um script que altera a cor de um sprite quatro vezes.
Primeira
vez

Segunda
vez

Terceira
vez

Quarta
vez

Figura 1.2 Usando um script para alterar a cor do sprite Cat.

Esse script espera um segundo entre as mudanas de cores, e os quatro


gatos que voc v aqui mostram a nova cor do sprite aps cada mudana.
Este livro descreve o Scratch 2, disponibilizado em maio de 2013. Essa verso permite criar projetos diretamente em seu navegador web, portanto no
necessrio instalar nenhum software em seu computador, e iremos nos basear
na interface web do Scratch para o material contido neste livro.
Agora que voc j sabe um pouco sobre essa linguagem, hora de dar incio nossa jornada em programao e aprender a utiliz-la.
22Captulo 1

Fa a voc me smo 1.1


Embora ainda no tenhamos discutido os blocos da figura 1.2, leia-os, d uma
olhada em seus formatos e procure descobrir os passos executados pelo script
para deixar o gato azul. (Dica: O primeiro bloco roxo faz o gato voltar sua
cor original.) O que voc acha que aconteceria se removssemos o bloco wait
(espere) do script?

O ambiente de programao do Scratch


Para iniciar o Scratch, acesse o seu site (http://scratch.mit.edu/) e clique no link
TRY IT OUT (Experimente). Isso deve conduzi-lo interface do editor de projetos do Scratch, mostrado na figura 1.3.

Ferramentas
de cursor

Stage (Palco)

Paleta de blocos

Barra de menu

Scripts Area
(rea de scripts)

Janela de dicas

Abas

Sprite List (Lista de sprites)


Backpack (Mochila, visvel somente se voc estiver logado)

Figura 1.3 A interface de usurio do Scratch, em que voc ir criar os seus programas.

Voc dever ver uma nica janela contendo pelo menos os trs painis a
seguir: o Stage (Palco, na parte superior esquerda), a Sprite List (Lista de
Sprites, na parte inferior esquerda) e a aba Scripts (Roteiros, direita), que
contm a aba Blocks (Blocos) e a Scripts Area (rea de Scripts). O painel
direita tambm contm duas abas adicionais: Costumes (Fantasias) e Sounds
(Sons), que sero discutidas posteriormente nesta seo. Se estiver logado em
uma conta no site do Scratch, voc ver tambm o Backpack (Mochila, na
parte inferior direita), que contm botes que permitem compartilhar o seu
projeto e usar sprites (atores) e scripts (roteiros) de projetos existentes.
Vamos dar uma olhada rpida nos trs painis principais.
Introduo ao Scratch23

O Stage
O Stage (Palco) o local em que os seus sprites se movem, so desenhados e
interagem. O Stage tem 480 passos de largura e 360 passos de altura, conforme mostrado na figura 1.4. O centro do Stage tem coordenada x igual a 0 e
coordenada y igual a 0.
y
180

Modo de apresentao
Nome do projeto

(0,0)

240

180

240

Bandeira verde

Parar

Cursor do mouse

rea de exibio
da posio
(x,y) do mouse
x: 150 y: 100

Figura 1.4 O Stage (Palco) como um plano de coordenadas com o ponto (0,0) no
centro.

As coordenadas (x, y) de qualquer ponto do Stage podem ser encontradas


ao mover o cursor do mouse at esse ponto e observar os nmeros na rea de
Exibio da Posio (x,y) do Mouse, localizada logo abaixo do Stage.
A pequena barra localizada acima do Stage contm diversos controles. O
cone do modo de Apresentao oculta todos os scripts e as ferramentas de
programao e faz com que a rea de Stage ocupe quase todo o seu monitor. A
caixa de edio mostra o nome do projeto corrente. Os cones de bandeira
verde e de parar permitem iniciar e terminar o seu programa.
Fa a voc me smo 1.2
Mova o mouse pela rea de Stage e observe a rea de Exibio da Posio do
Mouse. O que acontece quando voc move o mouse para fora da rea do Stage?
Agora mude para o modo de Apresentao e observe como a tela muda. Clique
na parte superior esquerda da tela ou tecle esc em seu teclado
no cone
para sair do modo de Apresentao.

Lista de sprites
A Lista de Sprites (Sprite List) exibe os nomes e as miniaturas (thumbnails)
de todos os sprites de seu projeto. Novos projetos comeam com o Stage em
branco e um nico sprite representado por um gato, conforme mostrado na
figura 1.5.

24Captulo 1

Miniatura do Stage

Escolher ator do acervo


Pintar novo ator
Usar imagem da cmera para criar ator
Carregar ator a partir de arquivo
Miniatura de Sprite1
Clique no boto
para apresentar
informaes sobre o sprite
Use estes botes para criar um novo
pano de fundo (backdrop)

Figura 1.5 A Lista de Sprites para um novo projeto.

Os botes acima da Lista de Sprites permitem adicionar novos sprites ao seu


projeto a partir de um de quatro lugares: da biblioteca de sprites do Scratch ,
do Paint Editor includo (onde voc pode desenhar sua prpria fantasia), de
uma cmera conectada ao seu computador ou de seu computador .
Fa a voc me smo 1.3
Adicione novos sprites ao seu projeto utilizando alguns dos botes localizados
acima da Lista de Sprites. Reorganize os sprites na Lista de Sprites arrastando as
miniaturas correspondentes.

Cada sprite de seu projeto tem seus prprios scripts, fantasias e sons. Voc
pode selecionar qualquer sprite e ver os seus pertences. (1) Clique na miniatura do sprite na Lista de Sprites ou (2) d um clique duplo no prprio sprite
no Stage. A miniatura do sprite selecionado no momento sempre estar em
destaque, contornada com uma borda azul. Ao selecionar um sprite, voc
poder acessar seus scripts, suas fantasias e os sons ao clicar em uma das trs
abas localizadas acima da rea de Scripts. Daremos uma olhada nos contedos dessas abas posteriormente. Por enquanto, clique com o boto direito do
mouse (ou d um ctrl-clique se voc estiver usando um Mac) na miniatura
do sprite Cat para ver o menu pop-up mostrado na figura 1.6.

uma nova cpia do sprite contendo os mesmos


Cria
scripts, as mesmas fantasias e os mesmos sons
Apaga o sprite do projeto
o sprite (juntamente com suas fantasias,
Salva
os sons e os scripts) em um arquivo
Esconde/mostra o sprite

Figura 1.6 Clicar com o boto direito do mouse em uma miniatura de sprite faz com que
esse menu prtico seja mostrado.

Introduo ao Scratch25

A opo duplicate (duplicar) copia o sprite e d um nome diferente


cpia. Voc pode remover um sprite de seu projeto usando a opo delete (apagar) , e pode exportar um sprite para um arquivo .sprite2 em seu computador
usando a opo save to local file (salvar em arquivo local) . [Para importar um
sprite exportado por outro projeto, basta clicar no boto Upload sprite from file
(Carregar ator a partir de arquivo) mostrado na figura 1.5]. A opo hide/show
(esconder/mostrar) permite alterar a visibilidade de um sprite no Stage.
Juntamente com as miniaturas de seus sprites, a Lista de Sprites tambm
mostra uma miniatura do Stage esquerda (veja a figura 1.6). O Stage tem seu
prprio conjunto de scripts, imagens e sons. A imagem de fundo que voc v
no Stage chama-se pano de fundo (backdrop). Ao iniciar um novo projeto, o
pano de fundo default do Stage branco, mas voc pode adicionar novas imagens de fundo se utilizar qualquer um dos quatro botes abaixo da miniatura
do Stage. Clique no cone Stage na Lista de Sprites para visualizar e editar os
scripts, os panos de fundo e os sons associados.

A aba Blocks
Os blocos no Scratch esto divididos em dez categorias (paletas): Motion
(Movimento), Looks (Aparncia), Sound (Som), Pen (Caneta), Data (Variveis),
Events (Eventos), Control (Controle), Sensing (Sensores), Operators (Operadores)
e More Blocks (Mais Blocos). Os blocos so diferenciados por cor para ajudar
voc a identificar facilmente aqueles que esto relacionados. O Scratch 2 tem
mais de cem blocos, embora alguns apaream somente em determinadas condies. Por exemplo, os blocos da paleta Data (Variveis, discutida nos captulos 5 e 9) aparecem somente depois que uma varivel ou uma lista for criada.
Vamos dar uma olhada nos diversos componentes da aba Blocks na figura 1.7.
Seleo atual (em detaque)
A parte superior da aba Blocks mostra
os dez grupos de blocos. Clique em
cada categoria para ver os blocos
existentes nessa categoria

A parte inferior mostra os blocos


disponveis na categoria selecionada
no momento

Figura 1.7 Uma viso ampliada da aba Blocks (Blocos).

Experimente clicar em um bloco para ver o que ele faz. Se voc clicar em
(mova 10 passos) da paleta Motion (Movimento), por exemplo, o sprite deslocar dez passos no Stage. Clique nesse bloco novamente e o
sprite deslocar mais dez passos. Clique no bloco say Hello! for 2 secs (diga
Hello! por 2 segundos) na paleta Looks (Aparncia) para fazer o sprite mostrar
Hello! em um balo durante dois segundos. Voc tambm pode acessar a
move 10 steps

26Captulo 1

tela de ajuda de um bloco ao selecionar Block help (Ajuda do bloco, que corresponde ao cone de ponto de interrogao) na barra de ferramentas e clicar no
bloco a respeito do qual voc tem dvidas.
Alguns blocos exigem uma ou mais entradas (tambm chamadas de argumentos) que dizem ao bloco o que ele deve fazer. O nmero 10 no bloco move
10 steps (mova 10 passos) um exemplo de um argumento. Observe a figura
1.8 para ver as diferentes maneiras pelas quais os blocos permitem que suas
entradas sejam alteradas.

Figura 1.8 Alterando os dados de entrada de diferentes tipos de blocos.

Voc pode alterar o nmero de passos em move 10 steps (mova 10 passos) ao clicar na rea branca em que vemos o nmero 10 e inserir um novo
nmero , por exemplo, 30, como pode ser visto na figura 1.8. Alguns blocos,
como point in direction 90 (aponte para a direo 90 graus), tambm possuem menus suspensos para suas entradas . Voc pode clicar na seta para
baixo para ver uma lista das opes disponveis e selecionar uma delas. Esse
comando em particular apresenta uma rea em branco editvel, portanto
voc tambm pode simplesmente digitar um valor na caixa branca. Outros
blocos, como point towards (aponte para) , foraro voc a escolher um
valor a partir do menu suspenso.
Fa a voc me smo 1.4
V para a paleta Looks (Aparncia), altere o valor dos dados de entrada dos blocos e clique neles para ver o que eles fazem. Por exemplo, faa experincias com
o bloco set color effect to (mude o efeito cor para). Experimente usar nmeros
como 10, 20, 30 e assim por diante at que o gato retorne sua cor original.
Experimente usar as opes do menu suspenso com nmeros diferentes. Voc
pode clicar no bloco clear graphic effects [apague os efeitos grficos, tambm
na paleta Looks (Aparncia)] para eliminar as suas alteraes.

A rea de Scripts
Para fazer com que um sprite faa algo interessante, necessrio program-lo
arrastando blocos da aba Blocks (Blocos) para a Scripts Area (rea de Scripts),
unindo-os. Ao arrastar um bloco para a rea de Scripts, uma rea destacada em
branco indica em que local esse bloco pode ser solto para formar uma conexo
vlida com outro bloco (Figura 1.9). Os blocos do Scratch somente se encaixam de determinadas maneiras, eliminando os erros de digitao que tendem a
ocorrer quando as pessoas usam linguagens de programao baseadas em texto.
Introduo ao Scratch27

Arraste
rea de Scripts

Uma rea destacada em


branco indica em que local
o bloco pode ser solto
para formar uma conexo

Figura 1.9 Arraste os blocos para a rea de Scripts e una-os para criar scripts.

No preciso completar os scripts para execut-los, o que significa que


voc pode test-los medida que os criar. Clicar em qualquer ponto de um
script, esteja ele totalmente ou parcialmente criado, faz o script todo ser executado de cima para baixo.
Fa a voc me smo 1.5
Inicie um novo projeto no Scratch e crie o script abaixo para o sprite Cat.
[O bloco forever (sempre) est na paleta Control (Controle), e os demais blocos
esto na paleta Motion (Movimento).]

Esta borda amarela


indica que o script
est sendo executado

Voc conhecer a maior parte desses blocos no captulo 2. Por enquanto,


clique em seu novo script para execut-lo. (O Scratch deve deixar o script em
execuo em destaque com uma borda amarela brilhante, como mostrado na imagem direita.) Voc pode at mesmo alterar os dados de entrada de um bloco e
adicionar blocos novos a um script enquanto ele estiver executando! Por exemplo,
altere o nmero do bloco move (mova) e observe como o movimento do gato se
altera. Clique no script mais uma vez para interromp-lo.

Voc pode facilmente desmontar uma pilha de blocos e testar cada uma
das partes individualmente. Essa ser uma estratgia de valor inestimvel
quando voc estiver tentando entender scripts longos. Para mover toda uma
pilha de blocos, clique no bloco superior da pilha. Para desassociar um bloco
que est no meio de uma pilha e todos os blocos abaixo dele, clique nesse
bloco e arraste-o. V em frente e experimente fazer isso.
Esse recurso tambm permite criar o seu projeto por partes. Voc pode
conectar conjuntos pequenos de blocos, test-los para garantir que funcionam
conforme esperado e ento combin-los em scripts mais longos.
28Captulo 1

Voc pode at mesmo copiar uma pilha de blocos de um sprite para outro.
Basta arrastar a pilha da rea de Scripts do sprite de origem para a miniatura
do sprite de destino na Lista de Sprites.
Fa a voc me smo 1.6
Adicione outro sprite ao seu projeto. Arraste o script do sprite Cat e solte-o sobre a
miniatura do novo sprite. O ponteiro do mouse deve estar sobre a miniatura do novo
sprite para que esse processo seja bem-sucedido. Verifique a aba Scripts (Roteiros)
do novo sprite para garantir que ele contenha uma cpia idntica do script.

A aba Costumes
A aparncia de um sprite pode ser alterada se mudarmos a sua fantasia
(costume), que somente uma imagem. A aba Costumes (Fantasias) contm
tudo o que necessrio para organizar as fantasias de seu sprite; voc pode
imagin-la como se fosse um guarda-roupa. O guarda-roupa pode conter
diversas fantasias, porm um sprite pode vestir somente uma em um determinado instante.
Vamos agora tentar alterar a fantasia do sprite Cat. Clique na miniatura
do sprite Cat e selecione a aba Costumes (Fantasias). Como mostrado na
figura 1.10, Cat tem duas fantasias: costume1 e costume2. A fantasia em destaque
(costume1, nesse caso) representa a fantasia atual do sprite.
Utilize estes botes para adicionar
novas fantasias ao sprite
Utilize esta caixa de edio para
alterar o nome da fantasia selecionada
Clique no x para apagar a fantasia
A fantasia em destaque representa
a fantasia atual do sprite
Voc pode alterar a ordem
das fantasias ao arrastar e
mover as miniaturas
Clique na miniatura de uma
fantasia para fazer com que ela
seja a fantasia corrente

Figura 1.10 Voc pode organizar todas as fantasias de um sprite a partir da aba
Costumes (Fantasias).

Se voc clicar com o boto da direita do mouse na miniatura de uma fantasia, um menu pop-up com trs opes ser apresentado: (1) duplicate (duplicar), (2) delete (apagar) e (3) save to local file (salvar em arquivo local). A
primeira opo adiciona uma nova fantasia com uma imagem idntica da
fantasia que voc estiver duplicando. A opo delete apaga a fantasia selecionada. A ltima opo permite salvar a fantasia em um arquivo. Voc pode
Introduo ao Scratch29

importar essa fantasia e utiliz-la em um projeto diferente ao usar o boto


Upload costume from file (Carregar fantasia a partir de arquivo, que o terceiro boto na figura 1.10). V em frente e experimente usar essas opes.
Fa a voc me smo 1.7
Clique no primeiro boto acima da imagem do gato na figura 1.10 para selecionar uma nova fantasia a partir da biblioteca do Scratch. Em seguida, selecione
qualquer imagem que voc gostar na janela que for apresentada. Aplique algumas das dicas que esto na figura 1.10 para se familiarizar mais com as opes
associadas s fantasias.

A aba Sounds
Os sprites tambm podem reproduzir sons, o que deixa os seus programas
mais animados. Por exemplo, voc pode disponibilizar diferentes sons a um
sprite para que sejam usados quando ele estiver feliz ou triste. Se o seu jogo
contiver um sprite que se parea com um mssil, voc poder faz-lo gerar
sons diferentes de acordo com o fato de o mssil atingir ou errar um alvo.
Os botes da aba Sounds (Sons) ajudaro a organizar os diferentes sons
que seus sprites podem reproduzir. Como mostrado na figura 1.11, o Scratch
oferece at mesmo uma ferramenta que pode ser usada para editar arquivos
de udio. No discutirei os detalhes a respeito dessa ferramenta neste livro,
porm sugiro que voc faa experimentos por conta prpria.
Na maioria das vezes, voc precisar somente dos trs botes que esto
na parte superior da aba Sounds. Eles permitem selecionar um som a partir
da biblioteca de sons do Scratch , gravar um udio novo (se voc tiver
um microfone) ou importar um arquivo de udio de seu computador . O
Scratch pode ler somente arquivos de udio MP3 e WAV.
Utilize estes botes para adicionar um novo som a um sprite
Voc pode digitar um nome diferente para o som

Botes de Play (Reproduzir),


Stop (Parar) e Start/Stop recording
(Iniciar/Parar gravao)
Este arquivo de
udio tem durao
de 0,8 segundos

Figura 1.11 A aba Sounds (Sons) permite organizar os sons associados a um sprite.

30Captulo 1

Fa a voc me smo 1.8


Selecione a aba Sounds (Sons) e clique no boto Choose sound from library
(Escolher som do acervo). Oua os vrios sons que esto disponveis no Scratch
para ter algumas ideias para seus projetos futuros.

A aba Backdrops
Ao selecionar a miniatura do Stage na Lista de Sprites, o nome da aba do meio
mudar de Costumes (Fantasias) para Backdrops (Panos de fundo). Utilize essa
aba para organizar as imagens de fundo do Stage, que podem ser alteradas juntamente com seus scripts. Por exemplo, se voc estiver criando um jogo, um
pano de fundo contendo instrues para comear poder ser apresentado e,
em seguida, poder ser alterado para algo diferente quando o usurio iniciar o
jogo. A aba Backdrops (Panos de fundo) idntica aba Costumes (Fantasias).
Fa a voc me smo 1.9
Clique no boto Choose backdrop from library (Escolher fundo do acervo)
abaixo da miniatura do Stage na Lista de Sprites. Selecione o pano de fundo
xy-grid na janela apresentada e clique em OK. O Scratch adicionar o xy-grid
ao seu projeto e far com que ele seja o pano de fundo default. (O xy-grid mostra um plano cartesiano de duas dimenses, que ser til quando voc estiver
trabalhando com os blocos de comando de Movimento.) Repita esses passos e
selecione qualquer outro pano de fundo que voc desejar.

Informaes sobre o sprite


Voc pode visualizar a rea de informaes sobre o sprite ao clicar no pequeno
cone
no canto superior esquerdo da miniatura de um sprite, como mostrado na figura 1.12. Essa rea mostra o nome do sprite, sua posio atual (x,y)
e a direo, seu estilo de rotao e o estado quanto visibilidade, alm de
mostrar se ele pode ser arrastado em modo de Apresentao. Vamos discutir
brevemente cada uma dessas opes.

Clique neste cone para


ver as informaes
sobre o sprite

Figura 1.12 A rea de informaes do sprite.

Introduo ao Scratch31

A caixa de edio na parte superior dessa rea permite alterar o nome


do sprite. Voc utilizar essa caixa diversas vezes neste livro.
Os valores de x e de y mostram a posio atual do sprite no Stage. Arraste
o sprite pelo Stage e observe o que acontece com esses nmeros.
A direo do sprite indica para qual direo o sprite ir se mover em
resposta a um bloco de movimento. Arraste a linha azul que parte do centro
do cone em forma de crculo para efetuar uma rotao no sprite.
Os trs botes de estilo de rotao [que se chamam Rotate (Efetuar rotao), Left-right flip (Virar esquerda e direita) e No rotate (Sem rotao)]
controlam o modo como a fantasia aparecer medida que o sprite mudar a
sua direo. Para compreender o efeito desses botes, crie o sprite mostrado na
figura 1.13 e clique em cada um desses botes enquanto o script estiver executando. O bloco wait (espere) pode ser encontrado na paleta Control (Controle).

Figura 1.13 Script para demonstrar os estilos de rotao.

A caixa de seleo Can drag in player (Pode ser arrastado) indica se o


sprite pode ou no ser arrastado (usando o mouse) em modo de Apresentao.
Mude para o modo de Apresentao com essa caixa selecionada/no selecionada e tente arrastar o sprite pelo Stage para compreender o efeito dessa
caixa de seleo.
A caixa de seleo Show (Mostrar) permite mostrar/ocultar o sprite
durante o design do programa. Experimente usar essa opo para ver o que
acontece. Voc ver diversos exemplos de sprites ocultos que realizam tarefas
teis por trs das cortinas em vrios exemplos ao longo deste livro.

A barra de ferramentas
Vamos dar uma olhada rpida na barra de ferramentas do Scratch na figura
1.14, comeando por alguns dos botes. (A barra de ferramentas ter uma
aparncia um pouco diferente se voc estiver logado, conforme ser discutido no Apndice A.) Utilize os botes Duplicate (Duplicar) e Delete (Apagar)
para copiar e remover sprites, fantasias, sons, blocos ou scripts. O boto Grow
(Aumentar) aumenta o sprite, enquanto o boto Shrink (Reduzir) faz com que
ele diminua. Basta clicar no boto que voc quiser usar e, em seguida, clicar em
um sprite (ou em um script) para aplicar essa ao. Para retornar ao cursor em
forma de seta, clique em qualquer rea em branco da tela. Voc pode utilizar o
menu Language (Idiomas) para alterar o idioma da interface do usurio.
32Captulo 1

Acessar o site do Scratch

Duplicar

Idiomas

Apagar

Diminuir
Aumentar

Figura 1.14 A barra de ferramentas do Scratch.

A partir do menu File (Arquivo), voc pode criar novos projetos, carregar (abrir) um projeto existente em seu computador, descarregar (salvar) o
projeto corrente para o seu computador ou desfazer (undo) todas as alteraes feitas no projeto corrente. Os projetos do Scratch 2 tm uma extenso de
arquivo .sb2 para distingui-los dos projetos criados com a verso anterior do
Scratch (.sb).
No menu Edit (Editar), a opo Undelete (Recuperar) trar de volta o
ltimo bloco, script, sprite, fantasia ou som que voc apagou. A opo Small
stage layout (Disposio com palco pequeno) diminui o Stage e proporciona
mais espao para a rea de Scripts. Selecionar Turbo mode (Modo turbo)
aumenta a velocidade de alguns blocos. Por exemplo, executar um bloco
move (mova) 1.000 vezes pode levar cerca de 70 segundos em modo normal e
aproximadamente 0,2 segundo em modo Turbo.
Agora que vimos o essencial sobre a barra de ferramentas do Scratch, discutiremos brevemente o Paint Editor includo no Scratch.

O Paint Editor
Voc pode usar o Paint Editor (Figura 1.15) para criar ou editar fantasias (costumes) e panos de fundo (backdrops). ( claro que voc tambm pode usar o
seu programa favorito de edio de imagens.) Se quiser aprender mais sobre
o Paint Editor do Scratch, d uma olhada em ScratchPaintEditor.pdf (localizado
junto aos recursos online, que podem ser baixados a partir de http://nostarch.
com/learnscratch/).
Por enquanto, h dois recursos importantes que voc deve conhecer: definir o centro de uma imagem e definir a cor transparente. Vou explicar esses
recursos nas sees a seguir.

Introduo ao Scratch33

Especificar
centro da
fantasia

Cor
transparente

Figura 1.15 O Paint Editor do Scratch.

Definindo o centro de uma imagem


Ao dar um comando para que um sprite vire (para a esquerda ou para a
direita), ele ir girar em relao a um ponto de referncia o centro de sua
fantasia. O boto Set costume center (Especificar centro da fantasia, no canto
superior direito do Paint Editor) permite selecionar esse centro. Ao clicar
nesse boto, voc ver uma cruz na rea de desenho, conforme mostrado na
figura 1.16. O ponto central determinado pela interseco desses dois eixos,
portanto, para alterar o centro de uma fantasia, basta arrast-los para uma
nova posio. Para ocultar os eixos, clique no mesmo boto novamente.
O centro de rotao
determinado pela interseco
destes dois eixos.
Voc pode alterar o centro
de rotao ao arrastar estes
eixos ou clicar com o mouse
no ponto central desejado

Figura 1.16 Alterando o centro de uma fantasia aps clicar no boto Set costume center
(Especificar centro da fantasia).

34Captulo 1

Fa a voc me smo 1.10


RotationCenter.sb2
Abra o RotationCenter.sb2 e execute-o. Essa aplicao contm um nico sprite
com a fantasia e o script mostrados abaixo. O centro da fantasia est definido
no meio do quadrado. Execute o script e observe o padro. Em seguida, altere a
fantasia de modo a definir o seu centro no meio do crculo e execute o script novamente para ver como a figura se altera.

Definindo a cor transparente


Quando duas imagens se sobrepem, a imagem de cima cobrir algumas partes da imagem de baixo. De modo semelhante, os sprites cobrem partes do
Stage. Se voc quiser ver a aparncia do Stage por trs de uma imagem, ser
necessrio usar o Paint Editor para deixar pelo menos parte da imagem transparente, como o pinguim que est direita na figura 1.17.
Na paleta Color (Cores), basta clicar no quadrado com uma linha vermelha
na diagonal e pintar com essa cor transparente para deixar algo invisvel.
Voc pode pensar nesse cone como um sinal de Ausncia de cor, semelhante
a um sinal de Proibido fumar com uma barra vermelha sobre um cigarro.
Utilize esta cor para
deixar qualquer parte de
uma imagem transparente

Esta parte da imagem


tem uma cor branca

Isto o que vemos quando


pintamos a parte branca
com a cor transparente
A grade corresponde ao
pano de fundo do Stage

Figura 1.17 Voc pode deixar qualquer parte de uma imagem transparente ao
preench-la com a cor transparente .

Agora que voc conhece a interface do Scratch, faremos um bom uso desse
conhecimento e criaremos algo divertido. Arregace as mangas e prepare-se:
vamos criar um jogo!
Introduo ao Scratch35

Seu primeiro jogo com o Scratch


Pong.sb2
Pong_NoCode.sb2

Nesta seo, voc criar um jogo para um s participante, no qual os jogadores deslocaro uma raquete para evitar que uma bola de tnis atinja o piso, de
acordo com o clssico jogo Pong do tipo arcade. A interface de usurio para o
nosso jogo est sendo mostrada na figura 1.18.
Quando o jogo iniciado,
a bola comea neste ponto
e se move para baixo em
um ngulo aleatrio
Quando a bola atinge a
raquete, ela rebatida
em um ngulo aleatrio
Utilize o mouse para mover
a raquete horizontalmente
Se a bola tocar nesta parte
do Stage, o jogo chegar ao fim

Figura 1.18 A tela de nosso jogo.

Como mostrado na figura, a bola comea na parte superior do Stage e se


move para baixo em um ngulo aleatrio, sendo rebatida ao tocar nas bordas
do Stage. O jogador move a raquete horizontalmente (usando o mouse) para
enviar a bola de volta para cima. Se a bola tocar a parte inferior do Stage, o
jogo chegar ao fim.
Criaremos esse jogo passo a passo, porm, inicialmente, devemos criar um
novo projeto. Selecione File4New (Arquivo 4 Novo) pa ra iniciar um novo
projeto no Scratch. Em seguida, apague o sprite Cat ao clicar no boto direito
do mouse e selecionar delete (apagar) no menu pop-up.

Passo 1: Preparar o pano de fundo


Para detectar se a bola no foi rebatida pela raquete, marcaremos a parte
inferior do Stage com uma determinada cor e utilizaremos o bloco touching
color ? [tocando na cor ?, da paleta Sensing (Sensores)] para nos informarmos quando a bola tocar nessa cor. Nosso pano de fundo (backdrop) atual
branco, portanto podemos simplesmente desenhar um retngulo estreito e
colorido na parte inferior, conforme mostrado na figura 1.19.
Clique na miniatura do Stage para selecion-lo e, em seguida, acesse a aba
Backdrops (Panos de fundo). Siga os passos da figura 1.19 para desenhar um
retngulo estreito na parte inferior do pano de fundo do Stage.

36Captulo 1

a
Selecione
ferramenta Retngulo

Selecione o
retngulo cheio

Selecione
a cor

D um clique com o mouse

mova-o para desenhar o


eretngulo.
Voc pode usar as
alas para ajustar o tamanho

Figura 1.19 Passos para desenhar um retngulo na parte inferior da imagem do pano de fundo.

Passo 2: Adicionar a raquete e a bola


Clique no boto Paint new sprite (Pintar novo ator) acima da Lista de Sprites
para adicionar o sprite Paddle ao seu projeto. Como a raquete somente um
retngulo pequeno e estreito, repita o que foi feito no Passo 1 para desenhar
uma raquete como a que est sendo mostrada na figura 1.18. D a cor que
quiser raquete e defina o centro aproximadamente no meio do retngulo.
A seguir, d um nome ao sprite que explique o que ele faz; eu o chamei de
Paddle. Alm disso, clique na imagem da raquete no Stage e mova-o para que
a sua coordenada y seja aproximadamente igual a 120.
O nosso jogo agora tem uma raquete, porm ainda precisamos de uma
bola para bater, portanto clique em Choose sprite from library (Escolher ator
do acervo) acima da Lista de Sprites para importar um. No dilogo que for
apresentado, clique na categoria Things (Coisas) e selecione a imagem Tennis
Ball para adicionar esse sprite ao seu projeto. Renomeie o sprite como Ball.
Antes de comear a trabalhar nos scripts para o jogo, selecione
FileDownload to your computer (Arquivo Baixar para o seu computador) para salvar o que voc fez at agora em seu computador. No dilogo que
for apresentado, selecione a pasta em que voc quer salvar o seu trabalho,
chame o arquivo de Pong.sb2 e clique em Save (Salvar). Se estiver logado no
momento, voc tambm poder salvar o seu trabalho na nuvem (ou seja, no
servidor do Scratch). Independentemente de voc ter decidido salvar seus
arquivos localmente (em seu computador) ou na nuvem, no se esquea de
salvar o seu trabalho com frequncia.
Com os sprites Paddle e Ball, o Stage dever ter uma aparncia semelhante
da figura 1.18. Se voc tiver dificuldades nesse momento, abra o arquivo
Pong_NoCode.sb2, que contm tudo o que acabamos de criar. Voc adicionar
os scripts para executar o jogo a seguir, mas no se preocupe demais com os
detalhes dos blocos. Iremos explorar todos eles posteriormente no livro, portanto, por enquanto, vamos focar em aprender a criar um projeto completo.
Introduo ao Scratch37

Passo 3: Iniciar o jogo e fazer seus sprites se moverem


Como designer desse jogo, voc decidir como os jogadores podem iniciar
uma nova partida. Por exemplo, o jogo pode comear quando voc pressionar
uma tecla, clicar em um sprite no Stage ou at mesmo quando voc bater palmas ou acenar (se voc tiver uma webcam). O cone de bandeira verde (localizado acima do Stage) outra opo popular que ser utilizada nesse caso.
A ideia simples. Qualquer script que iniciar com o bloco de trigger when
green flag clicked (quando clicar em bandeira verde) iniciar a execuo
quando esse boto for pressionado. A bandeira assumir a cor verde brilhante
e permanecer assim at o script terminar. Para ver isso em ao, crie o script
que est sendo mostrado na figura 1.20 para o sprite Paddle.

Da paleta Events (Eventos)


Da paleta Motion (Movimento)
Da paleta Control (Controle)
Inicialmente, arraste um bloco set x to 0

(mude x para 0) da paleta Motion (Movimento).


Em seguida, arraste um bloco mouse x
(posio x do mouse) da paleta Sensing (Sensores)
e solte-o sobre o nmero 0

Figura 1.20 O script para o sprite Paddle.

Quando a bandeira verde for clicada , o bloco go to x: y: (v para x: y:)


definir a posio vertical da raquete para 120, somente no caso de voc t-la
movido anteriormente com o mouse. A raquete deve flutuar imediatamente
acima do retngulo rosa que est na parte inferior do Stage, portanto, se o seu
retngulo for mais largo, altere o nmero referente sua posio para algo
que funcione em seu design.
O script ento utiliza um bloco forever (sempre) para verificar constantemente a posio do mouse. Iremos mover a raquete para trs e para a frente
ao fazer a correspondncia da posio x da raquete com essa posio do mouse
. Execute o script (clicando no cone da bandeira verde) e experimente mover
o seu mouse horizontalmente; a raquete dever seguir o movimento. Clique no
cone de parar ao lado da bandeira verde para interromper o script.
O script para o sprite Ball um pouco mais longo que o anterior e, sendo
assim, vou dividi-lo em pores mais simples. A bola deve comear a se mover
quando clicarmos na bandeira verde, portanto, inicialmente, adicione o script
da figura 1.21 ao sprite Ball.
Inicialmente, iremos mover a bola para a parte superior do palco e faremos com que ela aponte para baixo em um ngulo aleatrio usando o bloco
pick random (escolha nmero entre) [da paleta Operators (Operadores)]. O
script ento utiliza um bloco forever (sempre) para mover a bola pelo
Stage e faz-la ser rebatida se tocar nas bordas. Clique na bandeira verde
para testar o que foi implementado at agora. A bola deve mover-se em um
padro de zigue-zague e a raquete deve continuar seguindo o mouse.

38Captulo 1

Mova para a parte


superior do Stage

Comece o movimento.
Se tocar na borda do
Stage, faa a bola ser
rebatida

225

180

135

Escolha um ngulo aleatrio


entre 135 e 225 graus

Figura 1.21 A primeira parte do script para o sprite Ball.

Fa a voc me smo 1.11


Substitua o 12 dentro do bloco move (mova) por valores diferentes, execute o
script e observe o que acontece. Isso dever dar a voc uma ideia de como deixar o jogo mais fcil ou mais difcil. Clique no cone de parar quando terminar.

Agora hora de acrescentar a parte divertida os blocos que fazem a bola


ser rebatida pela raquete. Podemos modificar o bloco forever (sempre) que
acabamos de criar para que a bola v para cima quando atingir a raquete,
conforme mostrado na figura 1.22.
1) Arraste um bloco if (se) da paleta Control (Controle)
2) Arraste um bloco touching ? (tocando em ?)
da paleta Sensing (Sensores) sobre o hexgono do
bloco if (se). Clique na seta para baixo do bloco
touching ? (tocando em ?) e selecione Paddle
no menu suspenso
30 0 30

Figura 1.22 Adicionando cdigo para a bola subir.

Quando a bola e a raquete se tocarem, ordenaremos bola para que


aponte em uma direo aleatria entre 30 e 30. Quando o bloco forever
(sempre) executar a prxima rodada, o bloco move (mova) ser executado, o
que far a bola ir para cima. Clique na bandeira verde novamente para testar
essa parte do jogo. Clique no cone de parar quando tiver certeza de que a
bola est sendo rebatida pela raquete conforme esperado.
A nica parte que est faltando agora um cdigo que faa o jogo parar
quando a bola tocar a parte inferior do Stage. Adicione o script que est sendo
mostrado na figura 1.23 ao sprite Ball, imediatamente antes ou depois do bloco
if (se) da figura 1.22. Voc encontrar o bloco touching color ? (tocando na cor
?) na paleta Sensing (Sensores) e o bloco stop (pare) na paleta Control (Controle).

Introduo ao Scratch39

D um clique com o mouse no


quadrado referente cor. Em seguida,
clique na rea de cor rosa claro do Stage
Este bloco da paleta
Control (Controle)

Figura 1.23 Os blocos para finalizar o jogo.

Ao clicar com o mouse no quadrado colorido dentro do bloco touching


(tocando na cor ?), o cursor ser alterado para a imagem de uma mo.
Ao mover esse cursor e clicar sobre o retngulo rosa-claro na parte inferior
do Stage, o quadrado colorido dentro do bloco dever ficar com a mesma cor
do retngulo. O bloco stop all (pare todos) faz exatamente o que o seu nome
diz: todos os scripts em execuo em todos os sprites so interrompidos, e os
sprites Paddle e Ball no constituem nenhuma exceo.
Esse jogo bsico de pong agora est totalmente funcional. Clique na bandeira verde e jogue algumas vezes para test-lo. Aps ter percebido que
possvel criar um jogo inteiro com uma quantidade to pequena de cdigo,
espero que voc concorde comigo que o Scratch incrvel!
color ?

Passo 4: Dar uma animada com sons


claro que os jogos so muito mais divertidos quando tm som, portanto
vamos adicionar um toque final de modo que um som seja reproduzido sempre que acertarmos a bola.
D um clique duplo na bola que est no Stage para selecion-la e, em
seguida, selecione a aba Sounds (Sons). Clique no boto Choose sound from
library (Escolher som do acervo) para adicionar um som ao sprite Ball. No
dilogo que for apresentado, selecione a categoria Effects (Efeitos), selecione
o som pop e clique em OK para adicion-lo aba Sounds (Sons). Depois disso,
retorne aba Scripts (Roteiros) e insira um bloco play sound [toque o som, da
paleta Sound (Som)], como mostrado na figura 1.24.
Teste o jogo uma vez mais e, dessa vez, voc dever ouvir um breve som
pop sempre que a bola tocar na raquete.

Este bloco da paleta Sound (Som)

Figura 1.24 Reproduzindo um som quando a bola tocar na raquete.

Parabns! Seu jogo agora est completo (a menos, claro, que voc queira
acrescentar mais recursos a ele), e voc acabou de implementar o seu primeiro
programa no Scratch. Se quiser realizar mais alguns experimentos, tente
duplicar o sprite Ball para ter duas (ou mais) bolas em seu jogo e veja como
isso muda a maneira de jogar!

40Captulo 1

Na prxima seo, vou apresentar os diferentes tipos de blocos disponveis


no Scratch. medida que prosseguir neste livro, voc realmente ir explorar
a maneira como esses blocos funcionam, mas, por enquanto, iremos descrev-los apenas brevemente.

Blocos do Scratch: uma viso geral


Nesta seo, voc conhecer os diferentes tipos de blocos disponveis no
Scratch, seus nomes e os usos pretendidos. O objetivo definir alguns dos termos que sero vistos nos prximos captulos. Voc pode retornar a esta seo
medida que progredir, se for necessrio refrescar a sua memria.
Como est sendo mostrado na figura 1.25, o Scratch possui quatro tipos
de blocos: blocos de comando, blocos de funo, blocos de trigger e blocos
de controle. Os blocos de comando e os blocos de controle (tambm chamados de blocos de pilha) tm salincias na parte inferior e/ou nas reentrncias na parte superior.
Esses blocos podem ser unidos na forma de pilhas. Os blocos de trigger, tambm chamados de hats (chapus), tm a parte superior arredondada porque so colocados no topo de uma pilha. Os blocos de trigger conectam eventos a scripts.
Eles esperam por um evento por exemplo, um pressionamento de tecla ou
um clique do mouse e executam os blocos que esto abaixo deles quando
esse evento ocorre. Por exemplo, todos os scripts que comearem com o bloco
when green flag clicked (quando clicar em bandeira verde) sero executados
quando o usurio clicar no cone da bandeira verde.
Blocos do Scratch

Blocos de comando

Blocos de funo

Possuem uma reentrncia na


parte superior e uma salincia
correspondente na parte inferior

No possuem
salincias.
Retornam um valor

Blocos de trigger

Blocos de controle

Possuem a parte superior


Possuem aberturas
arredondada. Executam blocos que podem armazenar
que esto abaixo deles
outros blocos

Figura 1.25 Os quatro tipos de blocos disponveis no Scratch.

Os blocos de funo [tambm chamados de reporters (informantes)] no tm


salincias nem reentrncias. Eles no podem constituir uma camada de um
script sozinhos; em vez disso, so usados como entradas para outros blocos. Os
formatos desses blocos indicam o tipo de dado que eles retornam. Por exemplo, os blocos com extremidades arredondadas informam nmeros ou strings,
enquanto os blocos com as extremidades pontiagudas informam se algo verdadeiro ou falso. Isso est sendo mostrado na figura 1.26.
Alguns blocos de funo apresentam uma caixa de seleo ao lado deles.
Se a caixa for selecionada, um monitor aparecer no Stage para mostrar o valor
corrente do bloco informante. Selecione um sprite e marque a caixa de seleo
do bloco x position [coordenada x da posio, da paleta Motion (Movimento)].
Em seguida, arraste o sprite pelo Stage e observe esse monitor. Ele dever ser
alterado medida que o sprite for movido para trs e para a frente.
Introduo ao Scratch41

Blocos de funo com extremidades


arredondadas informam nmeros ou strings
Blocos de funo com extremidades pontiagudas
informam valores booleanos (verdadeiro/falso)

Figura 1.26 O formato de um bloco de funo indica o tipo de dado que ele retorna.

Operadores aritmticos e funes


Agora vamos dar uma olhada rpida nos operadores aritmticos e nas funes
suportadas pelo Scratch. Se voc perdeu sua calculadora, ento seus problemas acabaram! Voc pode criar a sua prpria calculadora no Scratch usando
os blocos da paleta Operators (Operadores), que sero explorados nesta seo.

Operadores aritmticos
O Scratch suporta as quatro operaes aritmticas bsicas de adio (+), subtrao (-), multiplicao (*) e diviso (/). Os blocos usados para realizar essas
operaes, chamados de operadores, esto sendo mostrados na figura 1.27.
Como esses blocos geram um nmero, voc pode utiliz-los como entradas
para qualquer bloco que aceite nmeros, conforme mostrado nessa figura.

Exemplo
Operador
Adio

Subtrao

Multiplicao

Diviso

Figura 1.27 Operadores aritmticos do Scratch.

O Scratch tambm suporta o operador de mdulo (mod), que retorna o


resto da diviso de dois nmeros. Por exemplo, 10 mod 3 (resto de 10 por 3)
retorna 1 porque o resto da diviso de 10 por 3 1. Um uso comum do operador de mdulo est em testar a divisibilidade de um inteiro por outro inteiro
(menor). Um mdulo igual a 0 indica que o nmero maior divisvel pelo
nmero menor. Isso d a voc alguma ideia para verificar se um nmero par
ou mpar?
Outro operador til suportado pelo Scratch o operador round (arredondamento de), que arredonda nmeros decimais para o inteiro mais prximo.
Por exemplo, round(3.1) = 3, round(3.5) = 4 e round(3.6) = 4.

42Captulo 1

Nmeros aleatrios
medida que programar com mais frequncia, bem provvel que voc precisar gerar nmeros aleatrios em algum momento, especialmente se voc
criar jogos e simulaes. O Scratch disponibiliza o bloco pick random (escolha nmero entre) especificamente para esse propsito.
Esse bloco gera um nmero aleatrio sempre que utilizado. Suas duas
caixas brancas editveis permitem inserir um intervalo para esse nmero, e
o Scratch selecionar valores somente entre esses dois limites (inclusive). A
tabela 1.1 mostra alguns exemplos de uso desse bloco.
Tabela 1.1 Exemplos de uso do bloco pick random (escolha nmero entre)

Exemplo

Resultados possveis
{0, 1}
{0, 1, 2, 3, ... , 10}
{2, 1, 0, 1, 2}
{0, 10, 20, 30, ... , 100}
{0, 0.1, 0.15, 0.267, 0.3894, ... , 1.0}
{0, 0.01, 0.12, 0.34, 0.58, ... , 1.0}

Nota

Os resultados de pick random 0 to 1 (escolha nmero entre 0 e 1) e de pick random


0 to 1.0 (escolha nmero entre 0 e 1.0) so diferentes. O primeiro caso resultar em
1 ou 0, porm o segundo fornecer um valor decimal entre 0 e 1. Se alguma entrada
do bloco pick random contiver um ponto decimal, a sada tambm ser um valor
decimal.

Funes matemticas
O Scratch tambm suporta um grande nmero de funes matemticas. O
bloco sqrt of (raiz quadrada de) agrupa 14 funes matemticas que podem ser
selecionadas a partir do menu suspenso, incluindo raiz quadrada, funes trigonomtricas, logartmicas e exponenciais. Consulte MathematicalFunctions.pdf
para obter uma descrio detalhada dessas funes.

Resumo
Este captulo forneceu uma viso geral do Scratch e de seu ambiente de programao. Voc conheceu os vrios elementos da interface do usurio e at
mesmo criou um jogo! Tambm exploramos os operadores e as funes matemticas do Scratch.
Introduo ao Scratch43

A esta altura, voc j conhece as informaes bsicas necessrias para criar


alguns scripts eficazes no Scratch, porm esse somente um passo na estrada
para a criao de programas incrveis. Nos captulos que se seguem, exploraremos mais profundamente o uso do Scratch para o desenvolvimento de suas
habilidades de programao.

Problemas
1. D o resultado de cada bloco do script a seguir. H um padro nesses
produtos?

2. H um padro nos produtos 9 9, 99 99, 999 999, ... , etc.? Utilize o


comando say (diga) para descobrir o resultado desses produtos e confira
sua resposta.
3. Complete a tabela a seguir fornecendo o valor de cada expresso.
Expresso

Valor

3 + (2 5)
(10 / 2) 3
7 + (8 2) 4
(2 + 3) 4
5 + (2 (7 4))
(11 5) (2 + 1) / 2
5 (5 + 4) 2 (1 + 3)
(6 + 12) mod 4
3 (13 mod 3 )
5 + (17 mod 5) 3

Agora utilize o comando say (diga) e os blocos apropriados de operadores para conferir suas respostas.
4. Avalie as expresses a seguir do Scratch usando lpis e papel. Suponha
que x = 2 e y = 4.

44Captulo 1

a)

d)

b)

e)

c)

5. Utilize o comando say (diga) e os blocos apropriados da paleta Operators


(Operadores) para calcular o seguinte:
a. A raiz quadrada de 32.
b. O seno de 30.
c. O cosseno de 60.
d. O resultado do arredondamento de 99,459.
6. Crie um bloco de funo que calcule a mdia dos trs nmeros a seguir:
90, 95 e 98. Mostre o resultado usando o bloco say (diga).
7. Crie um bloco de funo que converta 60F para Celsius.
(Dica: C = (5/9) (F 32).)
8. Crie um bloco de funo que calcule a rea de um trapezoide com
altura igual a 4/6 ps e bases iguais a 5/9 ps e 22/9 ps. (Dica: A= 0,5
(b1 + b 2) h, em que h a altura e b1 e b 2 correspondem s duas bases.)
9. Crie um bloco de funo que calcule a fora necessria para acelerar um
carro de 2.000 kg a 3 m/s2. (Dica: Fora = massa acelerao.)
10. O custo da eletricidade de 0,06 centavo de dlar por quilowatt-hora. Crie
um bloco de funo que calcule o custo de utilizao de um ar-condicionado de 1.500 watts durante 2 horas. (Dica: Energia = potncia tempo)
11. Com um simples truque matemtico, voc pode utilizar o operador round
(arredondamento de) para arredondar um nmero para uma casa decimal especfica. Por exemplo, voc pode arredondar o nmero 5,3567 para
o dcimo mais prximo (ou seja, a primeira posio direita da vrgula
decimal) usando os trs passos a seguir:
a. 5,3567 10 = 53,567 (Multiplique o nmero por 10.)
b. round(53,567) = 54 (Arredonde a resposta do passo a.)
c. 54/10 = 5,4
(Divida a resposta do passo b por 10.)

Que mudanas seriam necessrias nos passos anteriores para arredondar


o nmero para o centsimo mais prximo (ou seja, para a segunda posio direita da vrgula decimal)? Crie um bloco de funo que arredonde
5,3567 para o dcimo (ou centsimo) mais prximo e mostre o resultado
usando o bloco say (diga).

Introduo ao Scratch45

Você também pode gostar