スクラッチに挑戦している皆さん、どうも!スクラッチコーチです。
もう単調な動きしかないアスレじゃ満足できない欲張りな君、安心してください。回りますよ!
- ① まずはここからレッツゴー!
- ② リファクタリング)ステージをスプライトにしよう
- ③ シーンの切り替えのベース処理
- ④ ヒットボックスを使おう
- ⑤ アニメーションを実装しよう
- ⑥ 絶望の坂道処理を克服する
- ⑦ 長押しで大ジャンプする
- ⑧ 壁をツツ〜っとスライドする
- ⑨ か、壁ジャンプだと!?かっこよすぎるだろ
- ⑩ ステージがヨコにだけ続くと誰が言った?タテ構造
- ⑪ うわ!障害物が行く手をさえぎるぞ
- ⑫ 動く床のギミックを作ろう!
- ⑬ ギミックに乗っているときの衝突処理
- ⑭ オシャレなグラフィックを作るコツ
- ⑮ アイテムをゲットできればゲームに目的ができる!
- ⑯ 重要アイテムがないと開かないドア!?たぎる!
- ⑰ チェックポイントを作って激ムズなアスレを作ろう!
- ⑱ ゲームオーバーを作って緊張感をキープする!
- ⑲ エネミーが現れた!どうすりゃいいのよ!?
- ⑳ エネミーを踏んづけろ!
- ㉑ ギミックのリファクタリング
- ㉒ 回転が切り拓く新境地 (いまここ)
今回の目標
回転ギミックを爆誕させる!
回転するギミックを作る
新しいコスチュームを追加しよう。形に制限はないから、自由に作ってもスクショみたいな四角でもOK。
![](https://scratch.coach/wp-content/uploads/2024/08/7ef9a0be28d1e1e5f0d1e36b33040340.png)
スポーンを改修する
スポーンさせよう。
![](https://scratch.coach/wp-content/uploads/2024/08/11cd8f5fe44acc4cf32a283366efa4d8.png)
この定義に引数を追加したいので編集する。
![](https://scratch.coach/wp-content/uploads/2024/08/9d2fd0f29ec5a9ba75a5d86cd24e9ffc.png)
回転という引数を追加するよ。
![](https://scratch.coach/wp-content/uploads/2024/08/b6f4a9b5508e47f629a25cc976ba26f9.png)
回転に1を入れておく。
![](https://scratch.coach/wp-content/uploads/2024/08/d7c46666ded08fd3fcbafec8df39362e.png)
さらに変数も用意しておきたい。
![](https://scratch.coach/wp-content/uploads/2024/08/9e0dc6eeea45b0f0e1433bc9ec61186b.png)
値をセットする場所はスポーンする定義の中。
![](https://scratch.coach/wp-content/uploads/2024/08/a2f821b5e0e4da67d9d3ff0b0b1e059d.png)
回転の動きを作る
クローンされた時に条件ブロックを追加するぞ。
![](https://scratch.coach/wp-content/uploads/2024/08/115e561aeb0c7abb88c5920ee5c787bf.png)
条件式にて、回転の値を調べる。「回転>空白」でOK。回転に値があればTRUEになって、中が実行される。
![](https://scratch.coach/wp-content/uploads/2024/08/e7cd4d2e82bade4feab4ae7466b77118.png)
中ではグルグル回り続ける処理を実装するぞ。
![](https://scratch.coach/wp-content/uploads/2024/08/9a3cc6b64e52630936323f08d1437509.png)
回転するかテストする
うん、回ったね。もっと煮詰めていこう!
回転したらプレイヤーが落ちるようにする
今はただ単に回っただけで、物理的に違和感は残る。だってスクラッチキャットが余裕で立ち続けてるもんね。普通は足元が回転してたら落とされるような動きになるはずだよね。
定義「_更新する」を改修する
定義「_更新する」を改修するよ。いったんスクショを参考にブロックを外そう。
![](https://scratch.coach/wp-content/uploads/2024/08/67955b36c277f1b3a2b6355f4f2c8971.png)
最下部にあったブロックだけ戻す。残りは消さないでおいて。
![](https://scratch.coach/wp-content/uploads/2024/08/4b81f5e80c7656a36d38d9e926dfba11.png)
さらに、回転の値を調べる条件ブロックも追加する。
![](https://scratch.coach/wp-content/uploads/2024/08/c882d3265fbf5991e4535f5123868c2c.png)
「でなければ」の中に、外しておいたブロックを戻そう。
![](https://scratch.coach/wp-content/uploads/2024/08/ffcb9dfab57058d3f7b3532b30cc75fa.png)
回転していた場合の処理を実装していこう。
![](https://scratch.coach/wp-content/uploads/2024/08/93ec497daa1281aa7e8b24f85c20cbbf.png)
定義「_回転距離を計算する」を作る。
さて、新しい定義を作るぞ。
![](https://scratch.coach/wp-content/uploads/2024/08/b270a1afda38dc800fde834f62472710.png)
-
これは反時計回りって意味で考えておいて。カウンタークロックワイズの略だよ。カウンターは反対って意味。クロックワイズは時計回りって意味。
引数には回転の逆向きの力が入るようにする。つまり「ゼロ - 回転」だよ。
![](https://scratch.coach/wp-content/uploads/2024/08/6c47a5aadbbf039374f0e45ae6c0fa07.png)
よし、では気張って定義の中身を実装していくぞ!
![](https://scratch.coach/wp-content/uploads/2024/08/2e9405d99da95cdcdfeb93333caed416.png)
変数を4つ作る
いきなり変数を4つ作る。説明は後でするのでスクショを見て作ってみて。
![](https://scratch.coach/wp-content/uploads/2024/08/c774bd88abaf5d3ec6753e3b0415fb43.png)
![](https://scratch.coach/wp-content/uploads/2024/08/a7a38df8ad2e857734e7b00da5cd936b.png)
![](https://scratch.coach/wp-content/uploads/2024/08/54ba89c18792a6fd6bbc6028d4d446b7.png)
![](https://scratch.coach/wp-content/uploads/2024/08/bc429bf4a5b1ff800802203415f3a72a.png)
プレイヤーとの距離
ではまずプレイヤーの距離XとYに値をセットしたい。引き算をはめておいて。
![](https://scratch.coach/wp-content/uploads/2024/08/c16175b74215c9b439cca1f6246e6be9.png)
それぞれプレイヤーの座標から自分の座標を引く。
![](https://scratch.coach/wp-content/uploads/2024/08/632b752820cb4d243f79b1af4bd185fd.png)
CCWのsinとcos
次にCCWのsinとcosに値をセットする。シンプルに引数「CCW」のsinのcosを入れよう。
![](https://scratch.coach/wp-content/uploads/2024/08/9c39d68f74d8a35ff03c81f5ad8abd69.png)
思ってたより単純で安心(笑)なーんて思っていた時期が私にもありました。こっからはギアを1段上げて飛ばすぞ!
ギミックの差分
ギミックの差分XとYに値をセットする。とりあえずスクショのように引き算の左側は空けておいて。
![](https://scratch.coach/wp-content/uploads/2024/08/118bb1a1181d69cc2e471d4825614f34.png)
そんで、演算ブロックを6個並べてほしい。スクショみたいに横3列ずつにしておいて。真ん中だけ種類が違うから気をつけて。
- 掛け算 引き算 掛け算
- 掛け算 足し算 掛け算
![](https://scratch.coach/wp-content/uploads/2024/08/0cb8b547fa1d6a04eef94fd4ef1fdb22.png)
プレイヤーとの距離Xを左側の掛け算にいれる。
プレイヤーとの距離Yを右側の掛け算に入れる。
![](https://scratch.coach/wp-content/uploads/2024/08/bfc801f3af8ed0021ac1a13898ca22c2.png)
スクショを見て変数「CCWのcos」を2つ入れるぞ。
![](https://scratch.coach/wp-content/uploads/2024/08/16526eb9d8eae99245d3fb8cb0881ae0.png)
変数「CCWのsin」を2つ入れよう。
![](https://scratch.coach/wp-content/uploads/2024/08/df451d3e8a2aee34f64f59a29d76a10d.png)
矢印のとおりに演算を合体させる!
![](https://scratch.coach/wp-content/uploads/2024/08/3537c9f41110d65331ce0016ed84a239.png)
ガチャーン!
![](https://scratch.coach/wp-content/uploads/2024/08/8a8e07d3bb8f7cc2bb4b355b262a1748.png)
さらにこれを空けておいた引き算の左側に入れよう!
![](https://scratch.coach/wp-content/uploads/2024/08/e3c849c329c65bd16ede8a49ca82271f.png)
ガチャンガチャーン!
何が起きたのかテストで確認する
超ざっくり何が起きたのか説明すると、プレイヤーとギミックの距離が回転によってどう変わるかを三角関数で算出している。
えーっと、つまり、まぁ、、、回転してるものに乗ったら落ちるってことだ!く、詳しくはお近くの学校の先生に聞いてほしい(笑)
別の形、別の回転も追加してみる
上では正方形っぽい形を使ったけど、長い棒みたいな長方形もやってみたい!
![](https://scratch.coach/wp-content/uploads/2024/08/ef94d7e72b6e1d9a7d4a85be2beef64e.png)
スポーンさせる。
![](https://scratch.coach/wp-content/uploads/2024/08/bb63a9cd88cad0a555e1d1b703929487.png)
うまく回るかテストする
おっとぉ、回っちゃいるけど、これだと通りにくくてつまらないね。
じゃあ回転の値を変えてみようか!
マイナス0.5にしてみて。
![](https://scratch.coach/wp-content/uploads/2024/08/1ae1e8953dbf14ac294b4aacf247d567-1.png)
どうかな。
いい感じ!逆回転になったね。
まとめ
今回はついに回転するギミックが完成した!このシリーズが面白かったらサンプル作品のハートを押して教えてね!たくさんハートがついたら続きを書くね。
- ① まずはここからレッツゴー!
- ② リファクタリング)ステージをスプライトにしよう
- ③ シーンの切り替えのベース処理
- ④ ヒットボックスを使おう
- ⑤ アニメーションを実装しよう
- ⑥ 絶望の坂道処理を克服する
- ⑦ 長押しで大ジャンプする
- ⑧ 壁をツツ〜っとスライドする
- ⑨ か、壁ジャンプだと!?かっこよすぎるだろ
- ⑩ ステージがヨコにだけ続くと誰が言った?タテ構造
- ⑪ うわ!障害物が行く手をさえぎるぞ
- ⑫ 動く床のギミックを作ろう!
- ⑬ ギミックに乗っているときの衝突処理
- ⑭ オシャレなグラフィックを作るコツ
- ⑮ アイテムをゲットできればゲームに目的ができる!
- ⑯ 重要アイテムがないと開かないドア!?たぎる!
- ⑰ チェックポイントを作って激ムズなアスレを作ろう!
- ⑱ ゲームオーバーを作って緊張感をキープする!
- ⑲ エネミーが現れた!どうすりゃいいのよ!?
- ⑳ エネミーを踏んづけろ!
- ㉑ ギミックのリファクタリング
- ㉒ 回転が切り拓く新境地 (いまここ)
当連載で取り上げるグリフパッチさんの動画はこちら
![このスクラッチゲームの作り方への質問もOK](https://scratch.coach/wp-content/uploads/2022/12/soylatte-e1717210866337.png)
質問テンプレート(素早く3回クリックすると全選択できるのでコピーしよう)
・◯◯ ... 記事のどこまで実装が終わったのかを記入しよう。・□□ ... どんな問題が起きているのか、どういうときに起きるのか、具体的に書こう。
・共有済みURL ... たまに共有してない作品URLを書いてる人がいるけど、共有しないとこちらから確認できないからよろしくね。