16/04/04 14:18:24.51 7ElMLh3h.net
>>253
それはコードが間違っているのではなくやり方が間違っている。
DontDestroyOnLoad only work for root GameObjects or components on root GameObjects
"DontDestroyOnLoadはルートのゲームオブジェクトまたはルートのゲームオブジェクト上のコンポーネント上でのみ機能します"
ここでルート、というのは他のオブジェクトの子供ではない、ということ。
Unityでは親オブジェクトがDestroyされるとその子供のオブジェクトもDestroyされる。
まぁ全部を一々指定しないとDestroyされないのではメンドクサ過ぎるのは明白なので
妥当な設計だと思うしだからDontDestroyOnLoadはそのオブジェクトがぶら下がっている一番上の親オブジェクトに対して行わなければならない、ということになっている。
それを取得する方法はプログラムで一番上を辿ってもいいし名前でFindしてもいいしpublicにしておいてインスペクター上でD&Dして指定しておいてもいい。
あともう一ついえばそこではscoreという変数をstaticで宣言している。
だからDontDestroyOnLoadはそもそも行う必要はない。
何もせずに、というよりも「何もしなければ」そのまま次の面までscoreの値は引き継がれる。
staticというのはあるメモリのアドレスが固定的に使われるものだ。
10番地にscoreの値が書き込まれていてそれはゲームが起動してから終了するまで変わらない。
だからそのクラスが破棄されて、また構築されてもscoreという変数の中身はずっと10番地に書かれている。
もっといえばそのクラスが破棄されて再構築されていなくても10番地の中身はそのままだ。
だからpublicなら他のオブジェクトからScoreScript.scoreと指定すればその値は見ることが出来る
逆にゲームが終了した時、或いは新しくゲームが開始された時、など適切な場面でscoreの値をリセットしなければいつまでもその値は残り続ける。
>>246で示されたテラシュールさんのページにある
"例えばスコアをstaticに格納しスコアを加算し続けた場合、2週目から前回のスコアを引きついた強くてニューゲームになってしまいます"
というのはそういうこと。