cocone Teck Talk Vol.2 - Singletonを使わないUnityを用いたApplication開発
by
cocone
×
Copy
Open
Link
Embed
Share
Beginning
This slide
Copy link URL
Copy link URL
Copy iframe embed code
Copy iframe embed code
Copy javascript embed code
Copy javascript embed code
Share
Tweet
Share
Tweet
Slide 1
Slide 1 text
Singletonを使わない Unityを用いたApplication開発 ポケコロツイン事例紹介
Slide 2
Slide 2 text
自己紹介 堀尾 大地 ● ポケコロツイン clientエンジニア 職務経歴 ● 株式会社Aiming(約5年) ● 株式会社インディゴゲームスタジオ(約 1年) ● cocone株式会社 <= イマココ 趣味 ● ゲーム ● youtubeでhololiveの配信を見る ● 欅坂46/櫻坂46
Slide 3
Slide 3 text
目次 1. Singletonを使いたくない理由 2. ポケコロツインの実装紹介 3. まとめ
Slide 4
Slide 4 text
Singletonを 使いたくない理由
Slide 5
Slide 5 text
Unityを使ってApplicationを作る ● UnityがSceneを起点としている ● アプリやチームの規模が大きくなってくると複数のSceneができる ● Scene間でデータのやり取りをする仕組みが欲しくなる
Slide 6
Slide 6 text
Unityを使ってApplicationを作る ● UnityがSceneを起点としている ● アプリやチームの規模が大きくなってくると複数のSceneができる ● Scene間でデータのやり取りをする仕組みが欲しくなる ↓ そうだ、Singletonを使おう。
Slide 7
Slide 7 text
Singletonが手っ取り早くて実装も簡単…だけど? ● Scene間のやり取りのために作ったのにどこからでも呼べる便利クラス化 ● ボタン押したらボタン制御クラスが急にSingletonを呼び出したりしてこれどうやって 動いてるんだ…?ってなる ● Singletonを1個作るとどんどん生まれる(割れ窓) ● 複数のSingleton同士が依存しあって初期化を変えると全部死ぬ、処理が追えなく なる
Slide 8
Slide 8 text
Singletonが手っ取り早くて実装も簡単…だけど? ● Scene間のやり取りのために作ったのにどこからでも呼べる便利クラス化 ● ボタン押したらボタン制御クラスが急にSingletonを呼び出したりしてこれどうやって 動いてるんだ…?ってなる ● Singletonを1個作るとどんどん生まれる(割れ窓) ● 複数のSingleton同士が依存しあって初期化を変えると全部死ぬ、処理が追えなく なる ↓ 管理コスト高くない?
Slide 9
Slide 9 text
結局使う人による ● 使用ルールを作って必要最低限だけをSingletonでカバーするとかなら全然いいと 思う ● 人の入れ替わりが起こる運営型のProjectでずっと保守できる?
Slide 10
Slide 10 text
結局使う人による ● 使用ルールを作って必要最低限だけをSingletonでカバーするとかなら全然いいと 思う ● 人の入れ替わりが起こる運営型のProjectでずっと保守できる? ↓ やりたくない (できる or できない ではない)
Slide 11
Slide 11 text
話をもとに戻します 論点はSingletonを使うか使わないか、どう使うかではなく Scene間のデータのやり取りをスムーズに行いたいだけ
Slide 12
Slide 12 text
話をもとに戻します 論点はSingletonを使うか使わないか、どう使うかではなく Scene間のデータのやり取りをスムーズに行いたいだけ ↓ SceneLoad時に必要な情報をScene側に 良い感じに渡せれば良いだけ!!!!!
Slide 13
Slide 13 text
ポケコロツインの 実装紹介
Slide 14
Slide 14 text
Scene C ざっくりとしたイメージ ApplicationManager (MonoBehaviour) Scene B ApplicationManagerで共有で使う インスタンスを初期化しておいて Load時に各Sceneに渡す Scene A ApplicationOperator (c# class)
Slide 15
Slide 15 text
ApplicationManagerの役割 1. 起点となるSceneに設置されたGameObjectにAttachしApplicationのエントリポイ ントとなる 2. 初期化時にGameObjectをDontDestroy 3. Operatorを初期化してインスタンスを保持する
Slide 16
Slide 16 text
ApplicationOperatorの役割 1. 共通で使うインスタンスの初期化と保持 2. インスタンス同士の依存などを解決 共通で使う処理の例 Scene、UI、通信、AssetBundle、Sound、Localデータ、設定データ、ユーザーデータ…など…
Slide 17
Slide 17 text
SceneClassの定義 こんな感じのclassを継承して各Sceneに配置したGameObjectにAttachしておく
Slide 18
Slide 18 text
SceneのLoad
Slide 19
Slide 19 text
まとめ
Slide 20
Slide 20 text
良かった点 ● Singletonを使わずにScene間のやり取りを実現でき た!!!!!! ● インスタンスの使用スコープを絞ることが出来る ● エントリポイントが明確なので処理が追いやすい ● 再利用性が高い
Slide 21
Slide 21 text
悪い点(?) ● 学習コストが高め ● 雑にApplicationManager側に処理を作られる
Slide 22
Slide 22 text
結局、最終的には人をどうやって教育するかになりますね…
Slide 23
Slide 23 text
ご清聴ありがとうございました。