小学生からのプログラム:Scratchを理解するための12の技(4)

Pocket

こんにちは。前回までの記事で一通りの動きは作ることができているようになったと思います。今回の記事は、前回の動きのあるエフェクトの作り方をさらに進め、動画を作る、音を出す、スコアを記録するなど、更に機能追加する方法を学びます。ここまで来るとだいぶ慣れてくるのではないでしょうか。使い方に慣れてくると、新しい物を作るフェーズにいよいよ入ることができます。

 技10. 乱数でいろいろな音を出してみる

最初の技は乱数を使うというものです。英語ではランダム(Random)と言いますが、コンピュータではよく乱数を利用してプログラムを記述することがあります。例えば、ゲームなどで敵を動かす場合に、予測できないような動きを作りたいとしましょう。その場合に、乱数を使って移動する速度や向きを決めることで予測できないような動きを作ることができます。このScratchでも乱数を使ったプログラムを作ることができます。例ではドラムの音を乱数で変化させることで、予測できない音をだすドラムを作ってみます。ドラムのスプライトを選択して、次の図に示すようなプログラムを作ってみてください。今までの連載を読んでいただいている方にはすぐできる内容だと思います。

乱数を使う

ここでのポイントは、演算のカテゴリにある「○から△までの乱数」というブロックを使っているところです。この○や△の部分の数値を変更することで乱数として作り出す値の範囲を決めることができます。このプログラムでは、Scratchで用意されている音の数が、18まであることから、1から18までの乱数というブロックを入れています。こうすることで、毎回違う音がなるプログラムができているはずです。ご自身で動作を確認してみてください。

技11.動画を作ってみよう

次は動画を作る技です。突然ですが、みなさんは、パラパラ漫画というのをご存知でしょうか。いわゆるアニメなどの動画は基本的にはそうですが、絵を何枚も用意して切り替えていくことで絵が動いているように見えることになります。前回の記事において簡易的なものを作成しましたが、動きを作ってみたいと思います。

最初はスプライトを選ぶ

 実際は自分で絵を描くといいのですが、絵を書くのは時間がかかることもあり、今回の例ではライブラリに用意されているスプライトを利用します。スプライトの中にはいくつかの動きを表現したものがコスチュームに入っているものがあります。例で選択した、Jaime Walking というスプライトには、図に示すように5種類のコスチュームが登録されています。これを利用して動きを作ってみることにします。

スプライトを選択

 

動きをつけるには

前回の記事でも示していますが、コスチュームを変える場合は、見た目のカテゴリにある、「次のコスチュームにする」を使います。図を見ていただくとわかるのですが、コスチュームの順番が動きの順に並んでいます。これを利用して次々とコスチュームを切り替えていくと歩いている絵に見えるのです。では、「ずっと」のブロックを使って図のように「次のコスチュームにする」を使ってみましょう。

次のコスチュームにする

速い、速すぎる

動かしてみるとわかりますが、かなり早くバタバタしている動きになっていると思います。これだと歩いている感じにはならないので、時間を調整するために、「0.2 秒待つ」をいれてみてください。

0.2秒待つ

これでなんとなく歩いている感じになったのではないでしょうか。動きの速さは自分で好きな様に調整できます。

移動させてみよう

次はこのスプライトを歩かせてみます。歩かせるのは、ここまで見ていただいている読者の方ならばすぐにわかると思います。そうです。動きのカテゴリにある「○歩動かす」を使います。

動かすと端にめり込む

単純に「○歩動かす」を使った場合、上のような感じで端の方にめり込んでしまいます。

それを回避するために、「もし端に着いたら、跳ね返る」を使います。ただ、これもすでに紹介済みなのでこれ以上深掘りはしません。

技12. スコアを記録しよう

最後の技ですが、スコアを記録するというのを考えてみます。よくゲームなどでスコアを計算していくかと思いますが、スコアを記録するための方法がわかれば、自分でゲームを開発することもできるようになります。

サメのゲームを作ろう

 ここでは、サメが魚を食べるゲームを考えてみます。サメと魚をスプライトライブラリから選択していただきます。そして、サメのスプライトで図に示すようなキー入力を受け付けてそれぞれ動かすようにしてみてください。このようにするとサメがいろいろな方向へ移動できるようになるはずです。

サメと魚でゲーム

スコアを付けるためには変数を使う

そして、スコアを付けられるようにします。スコアをつけるためには、変数の機能を使います。変数は、数値を記録するための場所になります。その場所に対して名前をつけて管理します。この例では、「スコア」という名前の変数にしてみます。

変数を作る

まずは、変数を作ります。変数カテゴリのところにある、「変数を作る」を選びます。

変数名をつける

すると変数の名前を入力できるウィンドウが開きます。ここでは、スコアという名前をつけます。

サメに動きをつけてゲームらしくしてみる

この変数を用いて、スコアを付けられるようにしましょう。このゲームでは、サメが魚に触れたら1ポイントゲットできるとします。また、単に動かすだけだとすぐに触れてしまうので、次のような動きを作ってみます。先ほども解説した乱数を使って、次の処理を繰り返すようにします。

1から10の乱数の向きだけ右に回転して、5歩動かす。
もし「魚」にあたったら
 その時は、点数を1点追加する
 そして、−100歩動かす(100歩戻す)
 もし端についたら跳ね返す

という処理を実現します。図に示すようなブロックの形になります。これを動かしてみてください。酔っ払ったサメのような動きになりますが、くるくると回っているかと思います。魚まで距離があると辿りつけないので、先ほど追加した矢印カーソルを使って位置をずらして行くとヒットするようになるはずです。

サメの動きにスコア処理を追加

ここで大事なこと

これで完成、と言いたいのですが、これだと少々問題があります。それは、1回目プレイしたあと、もう一度スタートした場合にスコアの値がそのままになっていることです。一般的にコンピュータのプログラムを作る場合、変数はどのような値が入っているかは定められていません。そのため、値をある一定の数になるように定めてあげる必要があります。これを専門用語では、「初期化(Initialization)」といいますが、この初期化をしてください。つまり、最初に変数の値を0にします。そうすることで、スタートしたときにいつでもスコア0から始まります。

初期化をする

図では、スコアのみではなく、サメの位置と向きに関しても初期化しています。このようにすることで毎回同じ条件でスタートするようになります。この初期化は基本的ですが、実は忘れる人が多いです。忘れると予期しない動きをして誤動作の原因になるので注意しましょう。

まとめ

4回に渡って書いてきた12の技の最後になりました。4回分の内容だけでもかなりのことが実現できるようになっているはずです。見ていただくだけでは実感がわかないと思いますので、ぜひご自分で体験いただくことをおすすめします。Scratch はWeb上で完結した開発環境ですので、インストールや環境設定に悩まされることはなく、スムーズに開発に移行できる点もメリットだと思います。
 今回紹介していない内容では、論理式や演算子の考え方、関数(ブロックを作る)の考え方、ペンの機能、カメラ画像の取得と利用、クローンがありますが、また別の機会にご紹介できればと思います。


文京区小石川で小学生、中学生、高校生を対象としたプログラミング&ロボット教室を開校しています。ご興味ありましたらぜひお問い合わせください。

お問い合わせはこちら!

問い合わせをする

Pocket

この投稿へのコメント

コメントはありません。

コメントを残す

メールアドレスが公開されることはありません。 * が付いている欄は必須項目です

この投稿へのトラックバック

  1. […] さまならピンときていると信じていますが、乱数です。(まだ読んでいないアナタ、ぜひこの記事を読んでください。)乱数をつかって、ゆらぎを作ってあげることで、色々なパターン […]

トラックバック URL