【Godot】Camera2Dで画面を揺らす方法

この記事では、Godot Engineで画面を揺らす方法について説明をします。

Camera2Dを使って画面をスクロールさせる

まずは Camera2D を使用して、画面のスクロールを実装してみます。

2Dシーンを作成して、ノード名を “Main” に変更します。
そして、背景画像 “bg.png” をプロジェクトに追加し、画面上に配置します。

Camera2Dの作成

次に Camera2D を作成します。

ノード構成は以下のようになりました。

そしてインスペクタから Current にチェックを入れて、現在使用するカメラとします。

カメラにスクリプトをアタッチ

Camera2D にスクリプトをアタッチします。スクリプトは以下のように記述します。

extends Camera2D

func _process(delta):
    # マウスカーソルが中心になるようにする
    offset = get_viewport().get_mouse_position()

実行すると、マウスカーソルの位置に合わせて、画面がスクロールします。

簡単な画面揺れの実装

Spaceキーを押したら画面揺れが開始するようにします。

extends Camera2D

# 揺れ時間
var time = 0

func shake():
    # 残り時間の幅でランダムに揺らす
    # 画面比率 (1024:60) 固定
    offset.x = 32    * rand_range(-1, 1) * time
    offset.y = 18.75 * rand_range(-1, 1) * time

func _ready():
    # カメラを画面の中心に移動 (解像度を 1024 x 600とした場合)
    position.x = 1024 / 2
    position.y = 600 / 2

func _process(delta):
    if time > 0:
        # 揺れ時間が残っていれば揺らす
        time = max(0, time - delta)
        shake()

    if Input.is_action_just_pressed("ui_accept"):
        # Spaceキーで揺れ開始
        time = 1 # 1秒

残り時間に合わせて揺れ幅を変更するシンプルな画面揺れです。

ノイズテクスチャを使って揺らす

ランダムな幅で揺らすと、どうしても鋭すぎる動きになってしまいます。
そこでノイズテクスチャを使って揺らします。

ノイズテクスチャとはおおよそ下の画像のような煙っぽい画像です。

このテクスチャの指定の座標にある値を少しずつずらしながら取得すると、それなり値がランダムっぽい動きをして、それでいて滑らかに値が変化するため、ランダムの揺れのような激しさが緩和されます。

ランダムテクスチャを使用したスクリプトは以下のようになります、

extends Camera2D

# ノイズテクスチャ
var noise := OpenSimplexNoise.new()
var noise_y := 0

# 揺れ時間
var time = 0

func shake():
    # 残り時間の幅でノイズテクスチャを使って揺らす
    noise_y += 1 # 動かす
    # 画面比率 (1024:60) 固定
    offset.x = 32    * time * noise.get_noise_2d(noise.seed * 2, noise_y)
    offset.y = 18.75 * time * noise.get_noise_2d(noise.seed * 3, noise_y)

func _ready():
    # 乱数初期化
    randomize()

    # ノイズテクスチャを生成
    noise.seed = randi()
    noise.period = 4
    noise.octaves = 2

    # カメラを画面の中心に移動 (解像度を 1024 x 600とした場合)
    position.x = 1024 / 2
    position.y = 600 / 2

func _process(delta):
    if time > 0:
        # 揺れ時間が残っていれば揺らす
        time = max(0, time - delta)
        shake()

    if Input.is_action_just_pressed("ui_accept"):
        # Spaceキーで揺れ開始
        time = 1 # 1秒

OpenSimplexNoise というのがノイズテクスチャを生成するモジュールです。

実行すると以下のように、動きが滑らかなカメラ揺れとなります。

参考