data:image/s3,"s3://crabby-images/be814/be8144057f86cc28edb6ddb24851d4b4f804b61f" alt="見出し画像"
GODOT Game engineでゲームを作ってみよう!(その2)
どうも僕です。
前回、GODOTを使って主人公キャラを歩かせました。
その続きをやっていこうと思います。
(本家のチュートリアルを参考に進めてます。
今回は敵の作成とゲーム編編シーンを進めます)
敵の作成
敵の素材
以下から、ありがたくキャラの画像を取得しました。
*上記からダウンロードするにはアカウントを作るべし!
スライムがあるのでこれを敵さんとして使おう!
data:image/s3,"s3://crabby-images/ddd11/ddd1175a470109c5dc16c3badfbab24485da85fa" alt=""
ドキュメントのプロジェクトフォルダの下に
敵さん用にenemyフォルダ(名前は何でもよし)を作り、
その中に上記のスライムの画像フォルダを配置しよう。
data:image/s3,"s3://crabby-images/647b5/647b50df742e3f39b6f1735dd98e7732c8a24527" alt=""
敵のシーン
メニューの「シーン」>「新規シーン」をクリック。
data:image/s3,"s3://crabby-images/8bd2c/8bd2c7f5c5f1c3439914d423d2a7efa131a7e296" alt=""
+をクリックして、
data:image/s3,"s3://crabby-images/68d5d/68d5dd079a9b119f0b1aaa3f6d173d32154b4c8a" alt=""
RigidBody2Dを子ノードとして追加。
data:image/s3,"s3://crabby-images/bb570/bb57081952274ee4cd16ea8ba6d922461a2cbdd2" alt=""
名前をMobに変える。
data:image/s3,"s3://crabby-images/33672/33672596cf171335661f603a607a493e331e318a" alt=""
data:image/s3,"s3://crabby-images/ed7f2/ed7f247a41748bf7c600fd51b17861f29fdea5e4" alt=""
上記のMobの下に孫ノードとして、以下をそれぞれ追加しよう。
・AnimatedSprite2D
・CollisionShape2D
・VisibleOnScreenNotifier2D
data:image/s3,"s3://crabby-images/00999/00999b4cc490728cd5362a0c53191ebe18f5ed3d" alt=""
追加できたら、AnimatedSprite2Dを選択し、
data:image/s3,"s3://crabby-images/9441f/9441f5b91e8bdb313161abd16e87647b28ca3dcd" alt=""
右側のインスペクターのAnimationのSprite Framesの<空>をクリックし、
新規SpriteFramesを追加しよう。
data:image/s3,"s3://crabby-images/4ba51/4ba51f0a601d2ec4b0d6b19a12374f3f6b6e6669" alt=""
もう一度「SpriteFrames」をクリックと、
中央にアニメーション/アニメーションフレームの欄が出てくる。
敵さんの画像をドラッグアンドドロップ。
data:image/s3,"s3://crabby-images/0edf2/0edf2376ddf7d886a760f8f0c1faac65d854ae85" alt=""
data:image/s3,"s3://crabby-images/ecab4/ecab475cef9af0b8ec3e898fd471b673e43a15df" alt=""
000~003へ並んでいれば、綺麗にアニメーションしてるよ。
data:image/s3,"s3://crabby-images/82f14/82f148c3b7c240607289a6f82c53d5eb8199dbb6" alt=""
▶をクリックして敵さんアニメーションを確認しよう。
data:image/s3,"s3://crabby-images/a5651/a5651e7f9fb8d39d98ea2343edcc3f1f611c17bf" alt=""
小さいので、TransformのScaleを2倍にしよう。
data:image/s3,"s3://crabby-images/208a4/208a487806e55608e7fc2413a651106f49bf2a0a" alt=""
大きくなった。
data:image/s3,"s3://crabby-images/5070e/5070ed8ca207e46dcda54b6faeb5f392a9be0579" alt=""
左側のシーン「Mob」をクリックし、
data:image/s3,"s3://crabby-images/7bada/7bada07a791892cdcf5dfbbfafcb5ab4cda3f5f0" alt=""
右側のインスペクターのRigidBody2Dの中の
Gravity Scaleの1を0へ
data:image/s3,"s3://crabby-images/118f2/118f25bcf821bb850436701fc6d60a400e388251" alt=""
右側のインスペクターのCollisionObject2Dの中の
CollisionのMaskを外す。(何の数字も選択されていない状態に)
data:image/s3,"s3://crabby-images/2e533/2e5334e0e234b3a6a5b60255a55952ee06a2cb63" alt=""
data:image/s3,"s3://crabby-images/dc9ba/dc9ba5cea116d2d9cfe6499943eb1971a2fa27f9" alt=""
左側の「CollisionShape2D」をクリックし、
data:image/s3,"s3://crabby-images/35998/359989f24124b67fc13f8351d9600a2ddccc59be" alt=""
右側のインスペクターのCollisionShape2DのShapeの空をクリックし、
CircleShape2Dを選択しよう。(*スライムが丸いのでねw)
data:image/s3,"s3://crabby-images/a6e31/a6e313cc68b5efe03e02df0da232687e5a08e030" alt=""
当たり判定の丸の大きさをマウスで調節しよう。
(小さい赤丸をクリックして引っ張る)
はみ出るけど気にしないwww
data:image/s3,"s3://crabby-images/aa9c9/aa9c915077d9b52d437fbd1382b679220d26db93" alt=""
一旦、敵さん完成。
data:image/s3,"s3://crabby-images/8946d/8946d3e3039c152babe98498d4ffec480c25e55d" alt=""
セーブしておこう。(Ctrl+Sキーね)
data:image/s3,"s3://crabby-images/095e1/095e19564f4c5fff266535c3e2d11a654d4f709e" alt=""
mob.tscnでOKね。保存しておこう。
敵のスクリプト
Mobを選択し、巻物みたいなアイコンをクリックして
スクリプトを追加しよう。
data:image/s3,"s3://crabby-images/4522c/4522caafaaaad2238c879eb676afb6af03b118b2" alt=""
作成をクリック。
data:image/s3,"s3://crabby-images/480c2/480c2b18f3579a629efff872897b14bff84b9945" alt=""
以下でスクリプトを書き換えよう。
extends RigidBody2D
# Called when the node enters the scene tree for the first time.
func _ready():
var mob_types = $AnimatedSprite2D.sprite_frames.get_animation_names()
$AnimatedSprite2D.play(mob_types[randi() % mob_types.size()])
$AnimatedSprite2D.flip_h = true
# Called every frame. 'delta' is the elapsed time since the previous frame.
func _process(delta):
pass
func _on_visible_on_screen_notifier_2d_screen_exited():
queue_free()
data:image/s3,"s3://crabby-images/934d5/934d54e0e1d80fdc283ecd94f1da70d475625c32" alt=""
ゲーム本編シーン
メニューのシーン>新規シーンを選択する。
data:image/s3,"s3://crabby-images/25f7f/25f7f7d5510a6581c568f3c857ab7991aacd07dc" alt=""
2Dシーンを選択。
data:image/s3,"s3://crabby-images/d3446/d34464d573f1a9797ed129eb3b1e738452c8d244" alt=""
名前を"Main"に変更する。
data:image/s3,"s3://crabby-images/3808d/3808d9df52e3ae03f11372cb8e87d088beee1607" alt=""
主人公シーン"area_2d"を子ノードとしてぶら下げよう。
インスタンスアイコンをクリック。
data:image/s3,"s3://crabby-images/d8a99/d8a99c78d91f698970ee578c26227f717519a628" alt=""
area_2d.tscnを選択し、開くをぽちー。
data:image/s3,"s3://crabby-images/4c908/4c908be3c303b387d71e7d9ded66f9fda7b83d10" alt=""
Mainを選択して、
+をクリックし、タイマー×3つ追加。
data:image/s3,"s3://crabby-images/6fe57/6fe5755fdde94933c6561cd26f5a9ed006cc9927" alt=""
Timerで絞り、作成ボタンをぽちー。
data:image/s3,"s3://crabby-images/0620b/0620b95ac2f13be099ae46e7583ecbfb1a7ccd45" alt=""
Mainの直下に3つTimer追加したら、下記のようにリネームしよう。
・タイマー”MobTimer”
・タイマー”ScoreTimer”
・タイマー”StartTimer”
data:image/s3,"s3://crabby-images/9dc2e/9dc2eb0d93532101bb6606d75d7e27376cc64135" alt=""
各タイマーを選択し、右側インスペクターのWait Timeを変更しよう。
・MobTimer:0.5
・ScoreTimer:1
・StartTimer:2
data:image/s3,"s3://crabby-images/ab354/ab354fd49c5688c5abf9d0b27026649524ed361b" alt=""
さらにMainシーンの下に、Maker2Dノードを追加しよう。
名前は"StartPosition"で。
data:image/s3,"s3://crabby-images/03047/0304744fd93486d3f20474db3b02e08359fdf85a" alt=""
data:image/s3,"s3://crabby-images/bad49/bad49ef9801a00b9d23147e42c4beabc52fe8232" alt=""
タイマーのStartTimerを選択し、
右側インスペクターのOne Shotにチェックを入れる。
data:image/s3,"s3://crabby-images/c95ca/c95ca965d0c7be61dfa209e2afd3b6d483640dc7" alt=""
ノードのStartPositionを選択し、
右側インスペクターのTransform>Positionのxとyに
240と 450をセット。
data:image/s3,"s3://crabby-images/35720/3572004d0cc3b357064eddf5637b7a8c031247f4" alt=""
スポーンモブ
さらにMainの下にノードを追加します。
Mainを選択し、+をクリックしよう。
data:image/s3,"s3://crabby-images/b2243/b2243885ce68fd2a51e755c28242c9f7a2215968" alt=""
Path2Dで検索し、「Path2D」を選択し、作成をクリックする。
data:image/s3,"s3://crabby-images/caf55/caf553c572472a6405bc0a2fa646e63605595120" alt=""
名前はMobPathにしよう。
data:image/s3,"s3://crabby-images/21699/216998a50be771ccd42f869a2c0149f84e52a8a5" alt=""
MobPathを選択し、下記の通りに枠を組もう。
data:image/s3,"s3://crabby-images/8dfc6/8dfc6924af4780c9dba073c8a03211d1cee20674" alt=""
「点を空きスペースに追加」アイコンをクリックしてから、
四隅をクリック(左上、右上、右下、左下)し、
最後に「曲線を閉じる」アイコンをクリックする。
data:image/s3,"s3://crabby-images/2c18d/2c18dcec883ff0187f5dafa330c0df041b1fa8ac" alt=""
MobPathの下にPathFollow2Dノードを追加する。
MobPathを選択して+をクリックする。
data:image/s3,"s3://crabby-images/50c05/50c050070e4bec58c1b58496a58fbe16aa275061" alt=""
PathFollow2Dを選んで、作成をぽちー。
data:image/s3,"s3://crabby-images/99941/9994132cf6124b6c7a3f72c731251eef7226ce20" alt=""
"MobSpawnLocation"って名前に変更しよう。
data:image/s3,"s3://crabby-images/e3dbf/e3dbf077a3a77adf6fa6a3277a5c9561b63cc1a8" alt=""
ここで一旦保存しよう。(Ctrl+Sキーね)
main.tscnの名前で保存する。
data:image/s3,"s3://crabby-images/0fcf8/0fcf8177cb2c62f3d79de50193cfbca06f99637a" alt=""
メインスクリプト
Mainを選択して、巻物みたいなアイコンをクリックして
スクリプトを追加しよう。
data:image/s3,"s3://crabby-images/1a0f5/1a0f58e97ea76f61f7e71d3ea9d677d59dba08ff" alt=""
作成をぽちー。
data:image/s3,"s3://crabby-images/475b2/475b2303c66afc421dc4af11c450ff577508ad60" alt=""
以下のスクリプトに書き換える。
extends Node
@export var mob_scene: PackedScene
var score
func game_over():
$ScoreTimer.stop()
$MobTimer.stop()
func new_game():
score = 0
$Area2D.start($StartPosition.position)
$StartTimer.start()
func _on_score_timer_timeout():
score += 1
func _on_start_timer_timeout():
$MobTimer.start()
$ScoreTimer.start()
func _on_mob_timer_timeout():
# Create a new instance of the Mob scene.
var mob = mob_scene.instantiate()
# Choose a random location on Path2D.
var mob_spawn_location = get_node("MobPath/MobSpawnLocation")
mob_spawn_location.progress_ratio = randf()
# Set the mob's direction perpendicular to the path direction.
var direction = mob_spawn_location.rotation + PI / 2
# Set the mob's position to a random location.
mob.position = mob_spawn_location.position
# Add some randomness to the direction.
direction += randf_range(-PI / 4, PI / 4)
mob.rotation = direction
# Choose the velocity for the mob.
var velocity = Vector2(randf_range(150.0, 250.0), 0.0)
mob.linear_velocity = velocity.rotated(direction)
# Spawn the mob by adding it to the Main scene.
add_child(mob)
func _ready():
new_game()
data:image/s3,"s3://crabby-images/a801e/a801e258958cf2f684f07cf59c548baf895e37e3" alt=""
mob_scene変数にMobシーンを紐づけよう。
左側シーンのMainをクリックし、
右側インスペクタの「Mob Scene」の<空>をクリックして
「読み込み」を選択しよう。
data:image/s3,"s3://crabby-images/67372/67372367ceb11e764543f7c706772f52ab794efc" alt=""
mob.tscnを選択して、開くをぽちー。
data:image/s3,"s3://crabby-images/f9098/f90985f33c591867fb65885d50f546adbf788bce" alt=""
Mod Scene変数にMobシーンが紐づけられた。
data:image/s3,"s3://crabby-images/fefb8/fefb8222064140ab2d2ace9dfa5a9043d28d2f3b" alt=""
各タイマーのシグナルをスクリプトと結びつけよう。
左側ノードのModTimerをクリックし、
右側ノードのシグナルのTimerのtimeout()を右クリックして
「接続」を選択。
data:image/s3,"s3://crabby-images/a3b0f/a3b0f86dcbc8b29ebb4c50cef142dfdda605c570" alt=""
接続をぽちー。
data:image/s3,"s3://crabby-images/5e2ec/5e2ec9fd24a1e24380a7299652c96d2fc271a4e0" alt=""
スクリプトの横にアイコンが表示されることを確認。
data:image/s3,"s3://crabby-images/ecae6/ecae6fd6bf536d35ac3b59b9c163e9ff3cd7bb7f" alt=""
左側ノードのScoreTimerをクリックし、
右側ノードのシグナルのTimerのtimeout()を右クリックして
「接続」を選択。
data:image/s3,"s3://crabby-images/20172/201725e5a24f4be89f71af6756a956cd642916ec" alt=""
接続をぽちー。
data:image/s3,"s3://crabby-images/7d33d/7d33d52755cb7aaa9cd5931c2b7d2cb2e78a70b2" alt=""
スクリプトの横にアイコンが表示されることを確認。
data:image/s3,"s3://crabby-images/d4624/d4624cc3d3a95c8f9e662b4ecefa22baa564e0c1" alt=""
左側ノードのStartTimerをクリックし、
右側ノードのシグナルのTimerのtimeout()を右クリックして
「接続」を選択。
data:image/s3,"s3://crabby-images/ca773/ca773ddae4369aa14414d392911d20eb6a80bbad" alt=""
接続をぽちー。
data:image/s3,"s3://crabby-images/f99a2/f99a2434786779aa6aca8201a9efa0063a8b13d6" alt=""
スクリプトの横にアイコンが表示されることを確認。
data:image/s3,"s3://crabby-images/adef4/adef4878ff21fd8656c0b751426b255c1fb21b80" alt=""
シーンのテスト
メインシーンの設定を行う。
左下のファイルシステムから”main.tscn”を右クリックする。
data:image/s3,"s3://crabby-images/618a9/618a90dc8956470cc9dabdf5b23511675aa2d1ec" alt=""
「メインシーンとして設定」を選ぼう。
data:image/s3,"s3://crabby-images/8966e/8966e543bbb361dbd60dd01b19c57eb901076a1a" alt=""
色が変わることを確認しよう。
data:image/s3,"s3://crabby-images/78d22/78d227afbd97f9107f27c34a8476db4a6f2f5b7e" alt=""
右上の▶を押して実行してみよう。
data:image/s3,"s3://crabby-images/88867/88867330aa157394d333d5edcf04bb75a034d6db" alt=""
おぉ、敵が四方八方からウヨウヨと出てくる!
十字キーで避けよう!!!
次回はスコアとかタイトルとか付けて行きます。
(実際は、GODOTのドキュメントに従って進めているだけですw)
今回は以上です。
では、また!
【補足】
続編書きました。以下も見てね!