
プログラミング学習の入門として人気の高いScratch(スクラッチ)で、誰もが知っている名作ゲーム「スーパーマリオ」を作ってみませんか?マリオの動きをプログラミングすることで、ゲーム制作の基礎を楽しく学ぶことができます。本記事では、スクラッチでマリオゲームを作るための基本手順から、キャラクターの動きの実装方法、さらには参考になる優秀な作品例まで、初心者でも分かりやすく解説します。プログラミングが初めての方も、この記事を読めばオリジナルのマリオゲームを作成できるようになるでしょう。

ゲームと言って初めに思い浮かぶものはマリオって人がいるほどマリオは世界的に見ても有名なゲームだよね♪
今日はスクラッチを使ってマリオを作る方法を伝授するのだ!!以外に簡単に出来るから、ぜひ見てほしいのだ!!
1. スクラッチでゼロからマリオを作る基本の手順
スクラッチを使ってマリオゲームを作成することは、プログラミングを学ぶ上で非常に楽しいプロジェクトです。以下に、その基本的な手順を紹介します。
1. スプライトの選択と編集
まず、ゲームの主要キャラクターである「マリオ」のスプライトを準備します。スクラッチのスプライトライブラリから「キャット」を選び、次にそれを「マリオ」のコスチュームに編集します。
- マリオのコスチューム作成: 色を塗り替えたり、帽子や服のデザインを加えたりして個性的な見た目にしましょう。
- スプライトサイズの調整: スプライトが画面に適切に収まるようにサイズを調整します。
2. 背景の設定
次に、ゲームの背景を選びます。スーパーマリオの特徴的な青空の背景を選択し、「Blue Sky」というコスチュームを追加するのが良いでしょう。これにより、ゲームの雰囲気が一気に出ます。
3. ゲームの基本的な動作
ゲームの基本的な動作を設定することが重要です。マリオが動いたりジャンプしたりするためのコードを書きます。
- 操作方法の設定:
- 左右に動かす: 矢印キー「←→」
- ジャンプ: 矢印キー「↑」
- 緑の旗を押してゲーム開始: ゲームを開始する際に音を出す設定も忘れずに行いましょう。
4. スコアシステムの導入
プレイヤーがゲームを進める中で得られるスコアを設定します。コインを集めたり、敵を倒したりすることで得点を増やす仕組みを作ります。
- 得点の表示: スコアを表示させるスプライトやテキストボックスを作成します。
- スコアが増える条件設定: コインを取得した際にスコアが増えるようにプログラムします。
5. 敵キャラクターの追加
ゲームに難易度を与えるために、敵キャラクターも作成します。例えば、クリボーやノコノコなどのスプライトを追加し、それぞれの動き方をプログラムします。
- 敵の動き: 敵が一定のパターンで動くように設定しましょう。これにより、プレイヤーは敵を避ける楽しみを感じることができます。
6. テストと調整
全てのプログラミングが完了したら、実際にゲームをテストします。不具合が無いか確認したり、動きがスムーズかどうかチェックしたりします。必要に応じて調整を加えていきましょう。
この基本の手順を踏むことで、スクラッチでマリオゲームを構築するための土台が出来上がります。次は、より高度な機能やデザインを考えて、ゲームを充実させていくことができます。スクラッチを使ったマリオゲーム作りを楽しんでください!

2. マリオの動きをプログラミングしよう!
マリオの動きをプログラミングすることは、スクラッチでゲームを作る楽しさの一部です。基本的な動作を設定することで、キャラクターがプレイヤーの入力に反応するようにしましょう。ここでは、マリオの動きのプログラミング手順を詳しく解説します。
必要なスプライトとリソース
まず、マリオのスプライトを用意しましょう。スプライトは、ゲームの中で動かすキャラクターやオブジェクトのことです。自分で描いたり、スクラッチのライブラリから選んだりできます。以下のようなスプライトが必要です:
- マリオ本体
- 地面のスプライト
- 背景(ステージによって異なる)
マリオの基本動作を設定
マリオには、通常の移動とジャンプの二つの基本的な動作があります。この二つをプログラミングするためには、次のようなブロックを使用します。
- 左右の移動
- 矢印キー「←」や「→」を使って移動します。以下のようなコードを設定します。scratch
永遠に繰り返す
もし(左矢印が押されているなら) {
x座標を-5ずつ変える
}
もし(右矢印が押されているなら) {
x座標を+5ずつ変える
} - ジャンプ
- ジャンプ動作は、高さを設定する必要があります。矢印キー「↑」を押すと、マリオが上に移動します。コードは以下の通りです。scratch
もし(上矢印が押されているなら) {
y座標を+10ずつ変える
待つ(0.1)秒
y座標を-10ずつ変える
}
地面との接触判定
ジャンプ時に地面に接触するかどうかを確認することが重要です。これを行うためには、地面のスプライトとマリオのスプライトが重なっているかを判定する必要があります。具体的には、以下のコードを使用します。
scratch
もし(マリオが地面と接触しているなら) {
ジャンプ可能
} そうでなければ {
ジャンプ不可能
}
おまけの動き:ダッシュ機能
さらに面白くするために、マリオに「ダッシュ」動作を追加することもできます。例えば、Shiftキーを押した瞬間に移動速度を上げて、通常の移動と差別化することができます。以下はその例です。
scratch
もし(Shiftキーが押されているなら) {
x座標を+10ずつ変えるまたは-x座標を-10ずつ変える
}
このようにして、マリオの多彩な動きをプログラミングして、ゲームのキャラクターに活気を与えることができます。これをもとに、自分だけの特徴を持ったマリオに仕上げていきましょう。

一概にマリオといっても、キャラクター一つ一つに動きを設定しないといけないのだ
想像とは違う動きをしてしまうことも多いけど、トライアンドエラーで一つ一つクリアしていくのだ!!

3. おすすめのスクラッチマリオ作品まとめ
スクラッチでは、多くのクリエイターが独自のマリオゲームを制作しており、プレイヤーに楽しさを提供しています。ここでは、特におすすめのスクラッチマリオ作品をいくつか紹介します。これらの作品は、各クリエイターの独自のアプローチやゲームデザインが反映されたものばかりです。
人気のスクラッチマリオゲーム
- New Super Mario Bros オンライン
- 作成者: JRHGames
- 一般的なマリオゲームの特長をしっかりと反映しながらも、オンラインで他のプレイヤーと競い合える楽しさがあります。 - NEWスーパーマリオ FOR スクラッチ
- 作成者: Brad-Games
- クラシックなマリオの要素を取り入れつつ、新たなステージデザインが魅力。特に、巧妙なトラップや隠されたアイテムに挑戦することで、遊ぶたびに新鮮さがあります。 - New スーパーマリオスクラッチ
- 作成者: DuckGoose9254
- シンプルで直感的な操作が特徴。初心者でも楽しめる設計がされています。
特徴的なクリエイターの作品
- グリフパッチさんのマリオ作品
豊富な経験から生まれた緻密なゲームメカニクスが光る作品。特に、ステージ設計のアイデアが秀逸で、何度もプレイしたくなる楽しさです。 - スーパーマリオ64 - クールクールマウンテン
- 作成者: FunnyAnimatorJimTV
3Dマリオの要素を取り入れた独創的な作品で、多次元的なステージを楽しむことができます。謎解きや課題も多く、やりこみ要素が満載です。
シンプルで楽しめるカジュアルゲーム
- フラッピーマリオ
- 作成者: TinyDxde
シンプルながらも中毒性のあるゲームプレイが多く、隙間時間にさくっと楽しめるのがポイントです。 - マリオにマイクラアクションを入れてみたゲーム
- 作成者: atomicmagicnumber
すでに人気のあるマイクラとマリオのコラボレーション。新しいプレイスタイルが体験でき、両方のファンにとって嬉しい作品です。
スクラッチマリオの多様な作品は、クリエイターの個性と工夫が表れています。これらを楽しむことで、自分自身でも新たなアイデアを得られるかもしれません。ぜひ、スクラッチのマリオ作品を探して、様々な体験をしてみてください。

4. マリオのキャラクター設定とスプライトの作り方
スクラッチで「マリオ」を取り入れたゲームを作成するためには、まずキャラクターの設定とスプライトの作り方を理解することが重要です。ここでは、マリオキャラクターの魅力を引き出すための具体的な方法を紹介します。
マリオのキャラクター設定
マリオはそのユニークなキャラクター設定が魅力の一つです。彼の特性を理解し、ゲーム内でどのように表現するかを考えることが必要です。以下は、マリオのキャラクターを設定する際のポイントです。
- 職業: マリオは元々大工であり、後に配管工へと変身しました。この背景をスプライトに反映させるために、道具や服装をデザインしたり、特定のアクションで彼の職業を感じさせることができます。
- 性格: マリオは勇敢であり、時にはコミカルです。アニメーションや表情を使って、その性格を活かすと良いでしょう。
- テーマ: ゲームのテーマに応じて、異なるマリオのバリエーション(通常のマリオ、ファイヤーマリオ、スーパースターなど)を用意できます。これにより、プレイヤーは様々な動きを楽しむことができます。
スプライトの作り方
次に、マリオのスプライトを作成する手順を見ていきましょう。スクラッチでは、スプライトをカスタマイズすることが容易です。
- 新しいスプライトの作成
スクラッチのプロジェクト画面で「新しいスプライトを追加」ボタンをクリックし、基本となるスプライト(猫のスプライト等)を選びます。 - コスチュームの変更
スプライトのコスチュームをクリックし、マリオに見えるように色や形を編集します。例えば、赤い帽子と青いオーバーオールを持つマリオを描くことができます。 - アニメーションの設定
マリオ特有の動きやジャンプ、攻撃などを表現するために、コスチュームを複数作成します。例として、ジャンプの際に上に飛び上がるコスチュームを用意すると、アニメーションがより自然に見えます。 - スプライト名とコードの設定
スプライト名を「マリオ」に変更し、動きやアクションに関するプログラミングを行います。矢印キーでの移動や、ジャンプのためのコードを追加することで、よりインタラクティブな体験が実現します。
クリエイティビティを活かす
マリオのキャラクター設定やスプライトを作成するときは、独自のスタイルやアイデアを取り入れることが大切です。スクラッチの機能を使って、あなた自身のマリオの世界を表現してみてください。また、他のキャラクター(ルイージやピーチ姫など)との連携を考えることで、より面白いゲームが作れるかもしれません。
5. 横スクロールの実装方法とコツ
スクラッチでマリオ風のゲームを作成する際、横スクロールの実装は非常に重要な要素です。横スクロールを上手に実装することで、プレイヤーはスムーズなゲーム体験を楽しむことができます。ここでは、横スクロールのプログラミング方法や役立つコツを紹介します。
横スクロールの基本的なアイデア
横スクロールゲームでは、プレイヤーキャラクターが画面を移動しながら背景や敵が動いてくる仕組みです。この動きを実現するための基本的なポイントは以下の通りです。
- 背景の移動: プレイヤーキャラクターが右や左に移動したときに、背景もそれに合わせて動くようにします。
- カメラの移動: キャラクターがある位置に到達したら、画面全体をその位置に合わせて移動させる必要があります。これにより、プレイヤーは常にキャラクターを中心にした視点でゲームを楽しむことができます。
実装手順
- スプライトの準備: マリオや敵キャラクター、背景などのスプライトを準備します。
- 移動量の設定: 矢印キーの入力に応じて、キャラクターの移動量を設定します。例えば、右矢印キーを押した場合、キャラクターが右に動くようにします。
- 背景のスクロール: プレイヤーが動くと、それに応じて背景も動くようにします。これには、背景スプライトの位置を変更するプログラムを組みます。
- カメラの調整: プレイヤーキャラクターが画面の中心にくるように、カメラの位置を調整します。こうすることで、キャラクターが画面外に出たときでも、ゲームが自然に続いていきます。
コツと注意点
- スムーズな動き: スプライトの動きがカクカクしないように、適切な移動速度を設定し、フレームレートを意識することが必要です。
- タイルの配置: 背景や障害物のタイルを適切に配置することで、ゲームの奥行きやスピード感を演出します。
- テストと調整: プログラムを作成した後は、必ずテストを行い、動きがスムーズかどうか、ゲームバランスが取れているかを確認します。
まとめておくべきポイント
- 矢印キーを使ったキャラクターの操作
- 背景の動きを同期させる方法
- プレイヤーの視点を調整するカメラの仕組み
このように、横スクロールを実装するためには、しっかりとしたプログラミングの基礎が必要です。慣れれば自分だけのオリジナルゲームを作り上げることができるでしょう。

まとめ
スクラッチを使ってマリオゲームを作成することは、プログラミングを学ぶ上で非常に楽しく、創造的な体験となります。この記事では、マリオのスプライト作成から、基本的な動作、スコアシステム、敵キャラクターの追加など、ゲーム制作の基本的な手順を紹介しました。さらに、実際のマリオゲームの事例や、キャラクター設計、そして横スクロールの実装方法とコツについても解説しました。これらの知識と技術を活かして、自分だけのオリジナルなマリオゲームを作り上げていくことができるでしょう。スクラッチを使ったマリオゲーム制作の魅力を存分に楽しんでください。

マリオに限らずスクラッチを使えばいろいろなゲームが作成できるのだ!!
自分の子どもに一般のゲームをさせるのが心配という方は、自分で面白安心ゲームを作ってみるのも面白いんだぜ!!
スクラッチを使った他のゲーム作成情報は下のリンクに詰まっているのだ!是非見てほしいのだ
【初心者必見】Scratch ゲームチュートリアル完全ガイド!コード不要で本格ゲーム制作