facebook twitter hatena line email

「Unity/MVP」の版間の差分

提供: 初心者エンジニアの簡易メモ
移動: 案内検索
行72: 行72:
 
}
 
}
 
</pre>
 
</pre>
 +
 +
==手順==
 +
# SampleSceneのヒエラルキーにTextとPlusButtonとMinusButtonを作成する。
 +
# ヒエラルキーにGameObjectを作成して、CounterViewと変更する。CounterView.csをAddComponentする
 +
# CounterPresenter.csをMainCanvasにAddComponentする。
 +
# CounterViewオブジェクトを選択し、インスペクターのCounterViewの部分にそれぞれのUIをドラッグする。
 +
# MainCanvasのCounterPresenterにCounterViewオブジェクトをドラッグする。

2021年9月15日 (水) 03:23時点における版

MVPとは

MV(R)Pで、ModelとViewとPresenterをReactiveで、疎結合に連携したパターン

CounterModel.cs

public class CounterModel
{
    public int Counter {
        get => counter;
        set => counter = value;
    }
    int counter = 0;

    public void PlusCounter()
    {
        counter++;
    }
    public void MinusCounter()
    {
        counter--;
    }
}

CounterView.cs

using UnityEngine;
using UnityEngine.UI;

public class CounterView : MonoBehaviour
{
    [SerializeField] public Button minusButton, plusButton;
    [SerializeField] public Text text;

    public void SetValueText(float value)
    {
        text.text = value.ToString();
    }
}

CounterPresenter.cs

using UnityEngine;
using UniRx;

public class CounterPresenter : MonoBehaviour
{
    [SerializeField] private CounterView _counterView;

    void Start()
    {
        CounterModel model = new CounterModel();
        _counterView.SetValueText(model.Counter);

        _counterView.plusButton
            .OnClickAsObservable()
            .Subscribe(_ => {
                model.PlusCounter();
                _counterView.SetValueText(model.Counter);
            })
            .AddTo(this);

        _counterView.minusButton
            .OnClickAsObservable()
            .Subscribe(_ => {
                model.MinusCounter();
                _counterView.SetValueText(model.Counter);
            })
            .AddTo(this);
    }
}

手順

  1. SampleSceneのヒエラルキーにTextとPlusButtonとMinusButtonを作成する。
  2. ヒエラルキーにGameObjectを作成して、CounterViewと変更する。CounterView.csをAddComponentする
  3. CounterPresenter.csをMainCanvasにAddComponentする。
  4. CounterViewオブジェクトを選択し、インスペクターのCounterViewの部分にそれぞれのUIをドラッグする。
  5. MainCanvasのCounterPresenterにCounterViewオブジェクトをドラッグする。