LoginSignup
0
1

【Unity】 Live2D Cubism SDKの導入と使用方法(個人用まとめ)

Last updated at Posted at 2023-12-09

はじめに

こんにちは、@codaponです。

Live2DのUnityでの導入方法や実際に動かす方法をまとめた記事です。

1. 環境構築

2. Live2DにAnimationを適用して動かす

3. Unityのパラメータによってモーションを切り替える方法

4. スクリプトからLive2Dのパラメータを変化させる

5. Live2Dのスピードを変化させる

6. アニメーションのフレーム位置にSEなどの音を付ける

環境構築

  1. Live2D Cubism SDK for Unityをダウンロードします。
    https://www.live2d.com/sdk/download/unity/

  2. 新しいUnityプロジェクトを起動し、上でダウンロードしたSDKをドラッグ&ドロップ。
    image.png

  3. 以下のサンプルLive2Dアニメーションが動くことが確認できればOKです。
    image.png

Live2DにAnimationを適用して動かす

  1. Live2Dをプロジェクトにドラッグ&ドロップ
  2. Prehub(青立方体)が生成されるのでヒエラルキーにドラッグ&ドロップ
  3. AnimationクリップをPrehubにドラッグ&ドロップ
    image.png
  4. 実行ボタン押して適用したアニメーションが動くことを確認してみてください。
  • Animationクリップと、Animator Controllerの意味
     ・Animationクリップ :1つのモーション。最小単位。
     ・Animator Controller :複数のモーションの関係や遷移を管理する。

  • ウィンドウ>アニメーション>アニメーション
    アニメーションでは、Animationクリップの中身を確認できます。
    image.png

  • ウィンドウ>アニメーション>アニメーター
    アニメーターは、複数のAnimationクリップの関係や流れを管理します。
    image.png

Unityのパラメータによってモーションを切り替える方法

パラメータを使用することで、任意のタイミングでモーションを切り替えることができます。パラメータはBooleanやTriggerの形式で持つことができす。

  1. 以下の図のように新しくステートを作成し、右クリックで遷移を作成をクリックし、矢印を相互に引きましょう。
    ※以下の例ではmo_1がtrueの場合に矢印の先に遷移します。
    image.png
  2. Animatorに対してSetBoolする処理をスクリプトに記載する例です。
    public Animator anim;

    public void SetBoolParam(string boolPamamName, bool setTrue) 
    {
        anim.SetBool(boolPamamName, setTrue); //Boolean
    }

    public void SetTrigger(string triggerName) 
    {
        anim.SetTrigger(triggerName); //Triggerも同様
    }

スクリプトからLive2Dのパラメータを変化させる

必ずLateUpdateの中から動かさないとパラメータが変化しないので注意してください。

using UnityEngine;
using Live2D.Cubism.Core;

public class Live2dCustomScript : MonoBehaviour
{
    private CubismModel _model;

    void LateUpdate() // LateUpdate・・・様々な計算が終わった後の最終調整を書くところ
    {
        FindParam("ParamEyeLOpen").Value -= 20; //直接パラメータを変化させる。
    }

    //パラメータ名をCubismParameterに変換する
    public CubismParameter FindParam(string paramId) 
    {
        CubismParameter[] cp = _model.Parameters;
        foreach (CubismParameter cubismParameter in cp){
            if (paramId == cubismParameter.Id){
                return cubismParameter;
            }
        }
        throw new System.Exception("指定されたIDを持つParametaterがありません。" + "ID:" + paramId);
    }
}

参考資料
【Unity+Live2D】UnityからLive2Dモデルを触るときの個人的メモ

Live2Dのスピードを変化させる

    public Animator anim;
    public slider;
    
    public void SpeedChange()
    {
        anim.speed = slider.value / 10f; //総数10のsliderを使う場合
    }

アニメーションのフレーム位置にSEなどの音を付ける

  1. アニメーションタブを開く。(アニメーションタブはCtrl + 6でも開けます)

  2. 時間が表示されている領域で右クリックし、「アニメーションイベントを追加」を押してください。
    image.png

  3. 実行したいスクリプトを、Live2DのPrehubオブジェクトにAddComponentします。

  4. インスペクターのFunctionの中から、実行したいスクリプトを選択してください。
    image.png
    スクリプトの例。以下のように配列でAudioClipを整理すると管理しやすいと思います。
    image.png

手順としては以下の流れです。

  1. SoundFlame.csを作成し、Live2DにAddcomponentする
  2. インスペクターのFunctionでrunSeMethod1を選択する。
  3. SoundSeManager.csを作成し、別のオブジェクトに付けておく。
    これを応用すれば任意のスクリプトを実行することも可能となります。
SoundFlame.cs:Live2Dに付けるスクリプト。SoundSeManagerを呼ぶ。
using UnityEngine;

public class SoundFlame : MonoBehaviour
{
    public AudioClip[] soundSe1;
    public SoundSeManager
    
    private void runSeMethod1(int no)
    {
        soundSeManager.Call(soundSe1[no]);//SoundSeManagerを呼ぶ
    }
}
SoundSeManager.cs:SoundFlame.csからAudioClipを受け取り、audioSource.PlayOneShotを実行する
using UnityEngine;

public class SoundSeManager : MonoBehaviour
{
    private AudioSource audioSource;
    
    void Awake()
    {
        audioSource = GetComponent<AudioSource>();
    }
    
    public void Call(AudioClip audioClip)
    {
        audioSource.PlayOneShot(audioClip);
    }
}

終わりに

最後まで読んでいただきありがとうございました。読者の皆様がこの記事から何かしらのヒントや情報を得てくださり、少しでもお役に立てたなら幸いです。

今まで他の記事みてクソ長コード貼り付けられてたら不親切だなあと思ってたんですが、同じことを自分もやりかけてるというな。これは非常によくないことです。

参考資料

【もう悩まない】初心者が押さえたいブログの書き方の基本18個
Unity初心者がUnityでLive2Dモデルを動かすため環境構築をした
Unityゲーム開発記・アドバイスお願いします ~ゲームをリスタートできるようにする1~
追記予定

0
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
0
1