今回は、Untiyの2Dゲームで背景を右から左にループして動かしていきます。画像は1枚だけを使い、右から左だけでなく、左から右、上から下、下から上も簡単に動かすことが出来る方法です。
はじめに
Unityのバージョンは2021.3.3f1です。
画像を2枚並べて、動かす方法は下記で紹介しています。
今回は画像を1枚だけ用意してスクロールして動かしていきます。
画像を用意
まずは背景画像を用意します、下記は適当に作成した画像です。
data:image/s3,"s3://crabby-images/8c0f2/8c0f26657c7fb9c7504bfdb3d584525d9353e1c3" alt=""
1枚の画像をループさせるので右端と左端がつながる画像にします。
実装開始
画像の設定を行った後、ゲーム画面に組み込んでいきます。
画像の設定変更
まずはUnityに画像を取り込みます。
data:image/s3,"s3://crabby-images/98392/98392f6b6059788419023e92a508cded34200aed" alt=""
次に画像の設定を変更します。TextureTypeを「Default」、WrapModeを「Repeat」にします。
data:image/s3,"s3://crabby-images/d9d88/d9d887a272bdb4aed4c1dac7bad8400ed8eb418a" alt=""
Materialの作成
Project→Assetsフォルダ内にMaterialを追加します。名前はbackgroundにしておきます。
data:image/s3,"s3://crabby-images/24b58/24b5870ea5b23c29295aaa76eb8500b17fe81058" alt=""
Materialの設定を変更します。Shaderを「Unlit/Texture」に変更して、画像をセットします。
data:image/s3,"s3://crabby-images/b0135/b0135b4eda76110c363e03291b3ebdbfd765eaa9" alt=""
画面作成
Hierarchyで「3DObject」→「Quad」を追加します。Planeでも可。
data:image/s3,"s3://crabby-images/aec6a/aec6a00efc372fcb0451ec18ca7f5e9c41da322b" alt=""
MeshRendererのMatarials→Elementに作成したマテリアルをセットしてスケールをいい感じに変更します。
data:image/s3,"s3://crabby-images/58ab8/58ab8a83abc62503082fbc1fb475e7b3123346a7" alt=""
下記の様になります。
data:image/s3,"s3://crabby-images/30e46/30e4637e53dba5865d2943a3f85f1219f6f61f4d" alt=""
マテリアルのOffset数値を変更すると画像を動かすことが出来ます。
data:image/s3,"s3://crabby-images/14987/14987493636e29adc751182b78f2e1e8e6953b2f" alt=""
これをスクリプトで実装して動かしていきます。
スクリプトの作成
下記スクリプトを作成します。今回は右から左に動かすのでOffsetのXが時間経過で増加するようにしています。
using UnityEngine; public class background : MonoBehaviour { [SerializeField] private float _speed; private Material _material; void Start() { _material = GetComponent<Renderer>().material; } void Update() { _material.mainTextureOffset += new Vector2(Time.deltaTime * _speed, 0); } }
Quadに追加してSpeedに適当な数値を入力します。
data:image/s3,"s3://crabby-images/22762/22762da03fae34893332f95f2dec306fedf067dd" alt=""
実行すると下記の様な感じで背景画像が右から左に動きます。
data:image/s3,"s3://crabby-images/ca84c/ca84c74aa89619686c31eefe8c7a453b6c420522" alt=""