3
1

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?

More than 1 year has passed since last update.

PONOSAdvent Calendar 2022

Day 21

Unityでお手軽にスクロール実装!Simple Scroll-Snapの紹介!

Last updated at Posted at 2022-12-20

PONOS Advent Calendar2022 の21日目の記事です。
昨日は@aibausoundさんのRuby on RailsでCloud Spannerエミュレータを使ってみるでした。

初めに

ゲームを遊んでいると、よくスクロールというものを見かけると思います。
ステージやアイテム、キャラクター一覧など、上下や左右に指を動かして
リストを移動させているアレですね。

Unityでスクロールを実装しようとすると標準機能の「ScrollRect」を使うと思います。
最低限の機能はついていますが
「スナップ機能つけたいな...」
「特定のオブジェクトまで自動スクロールしてほしいなあ...」
「無限にスクロールできるようにしたいなあ...」
なんて考えたことないでしょうか。
ScrollRect単体でも、できないことはないですが実装が大変だったりします。
また、Unity初心者の方だとスクロール機能の実装は大変だと思います。
簡単に実装したい!という方におすすめなのがSimple Scroll-Snapです!

Simple Scroll-Snapの使い方!

Asset StoreからSimple Scroll-SnapをダウンロードしてUnityにインポート

シーンに配置

インポートするとAssetsのところにSimpleScroll-Snapというフォルダが作られてる。
スクリーンショット 2022-12-15 15.45.11.png
中にはいろいろ入っているが、まずはフォルダの中のPrefabsをクリックしてScroll-SnapというPrefabをシーンに配置してみよう。
配置すると実にシンプルなUIが登場。
中身は下記の通り。
スクリーンショット 2022-12-19 10.55.18.png
再生すると番号のついたImageが横にスクロールする動き。

Simple Scroll-Snapのいいところは、オブジェクト同士の間付近までスクロールすると自動的に近い方のオブジェクトが真ん中に来てくれるところですね。
ScrollRectにはない機能なので嬉しいですね。
(ScrollRectオンリーでもできなくはないですが、構築が大変だったりで結構しんどいのでありがたいですね)

無限スクロールのやり方。

やり方はとっても簡単。
スクリーンショット 2022-12-15 19.06.26.png
インスペクター欄のUseInfiniteScrolllingにチェックを入れるだけ。
たったこれだけで無限にスクロールできるようになる。

指定したオブジェクトをスクロール欄に表示する方法

今は数字のついたImageを表示していますが、他のオブジェクトに差し替えたい場合は以下の2パターンで行える

  • 非再生時にSceneで直接Contentにオブジェクトを入れる
  • Script側でオブジェクト生成→Contentに入れる。

最初から表示する内容が決まっているなら前者のやり方でも問題ないですが、ステージやアイテムなど状況によって表示するものや数などは変わってくるのでコード側で制御する後者の方を推奨します。
ここではコード側でスクロールに追加するやり方を解説します。

まずはスクロールに表示するオブジェクトを用意します。
内容はなんでもいいので今回はオブジェクトごとに違う色が出るようにしています。

using System.Collections;
using System.Collections.Generic;
using UnityEngine;

using UnityEngine.UI;

public class TailObject : MonoBehaviour
{
    [SerializeField] Image tailImage = default;
    public void Initialize(Color tailColor)
    {
        tailImage.color = tailColor;
    }
}

次に先ほど用意したオブジェクトを生成、スクロールに追加するようにします。

using System.Collections;
using System.Collections.Generic;
using UnityEngine;

//コード上でSimpleScrollSnapを扱えるようにする
using DanielLochner.Assets.SimpleScrollSnap;

public class Test : MonoBehaviour
{

    [SerializeField] SimpleScrollSnap scrollSnap = default;
    [SerializeField] TailObject originalTailObject = default;

    void Start()
    {
        Color[] colorList = { Color.black, Color.blue, Color.cyan, Color.gray, Color.green };

        for (int i = 0; i < 5; ++i)
        {
            TailObject tailObject = Instantiate(originalTailObject, scrollSnap.Content);

            int index = i;
            tailObject.Initialize(colorList[index]);
        }
    }

SimpleScrollSnapをコードで扱う際は
using DanielLochner.Assets.SimpleScrollSnap;
を読んでやる必要があります。
上記を呼ぶことによって
SimpleScrollSnapの変数を宣言できます。

生成したオブジェクトはInstantiateの引数にscrollSnap.Content
または、tailObject.gameObject.transform.parentでContentにしてContentの子オブジェクトに設定するとスクロールに追加してくれます。
また、後述するscrollSnap.AddToFrontやscrollSnap.AddToBackなどでもスクロールに追加できます。

Simple Scroll-Snapの便利な関数紹介

最後にSimpleScrollSnapの便利な関数を紹介します。

移動関連

ボタンを押した際の表示の切り替え、特定のパネルに移動などタッチしてのスクロール以外にも動かしたい時に便利です。

GoToNextPanel()

1つ次のパネルへ移動

GoToPreviousPanel()

1つ前のパネルへ移動

GoToPanel(int panelNumber)

指定した番号のパネルへ移動

追加関連

スクロールにオブジェクトを追加する際はInstantiateの引数でContentを使用するのが基本ですが
後から追加したい時もあるかと思います。その時はこちらを使いましょう。

AddToBack(GameObject panel)

スクロールの最後にオブジェクト追加

AddToFrontGameObject panel)

スクロールの最初にオブジェクト追加

Add(GameObject panel,int index)

指定した番号のところにオブジェクト追加

最後に

一見地味に見えるかもしれないスクロールですが、ちょっと動きが変わるだけでもゲームの見え方は変わってくるのではと思います。
また、スクロール機能の実装が苦手な方もSimple Scroll-Snapを使用することで簡単にスクロール機能を追加することができます。
便利なのでおすすめです。

明日は@ackylaさんの記事になります!

3
1
0

Register as a new user and use Qiita more conveniently

  1. You get articles that match your needs
  2. You can efficiently read back useful information
  3. You can use dark theme
What you can do with signing up
3
1

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?