質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.48%
C#

C#はマルチパラダイムプログラミング言語の1つで、命令形・宣言型・関数型・ジェネリック型・コンポーネント指向・オブジェクティブ指向のプログラミング開発すべてに対応しています。

Unity

Unityは、Unity Technologiesが開発・販売している、IDEを内蔵するゲームエンジンです。主にC#を用いたプログラミングでコンテンツの開発が可能です。

Q&A

解決済

2回答

578閲覧

Unity:コンソール画面の数値がダブっている?

da-ryo

総合スコア11

C#

C#はマルチパラダイムプログラミング言語の1つで、命令形・宣言型・関数型・ジェネリック型・コンポーネント指向・オブジェクティブ指向のプログラミング開発すべてに対応しています。

Unity

Unityは、Unity Technologiesが開発・販売している、IDEを内蔵するゲームエンジンです。主にC#を用いたプログラミングでコンテンツの開発が可能です。

0グッド

0クリップ

投稿2021/06/10 04:50

編集2021/06/10 05:27

#現状
Unityバージョン2020.1.15とVscodeにて2Dのゲームを作成中ですが問題が起きました。

キャラクターが敵の攻撃を受けるとHPが減るという処理を作ったのですがUpdate内の"Debug.Log"と関数内の"Debug.Log"で違う値が出てしまいます。
#NPCのスクリプト

using System.Collections; using System.Collections.Generic; using UnityEngine; public class paraN : MonoBehaviour { //HP private float hpM; private float hpC; // Start is called before the first frame update void Start() { hpM = 100; hpC = hpM; } // Update is called once per frame void Update() { Debug.Log (hpC); } //ダメージ public void damA() { hpC -= 10;      Debug.Log (hpC); } }

NPCが敵の攻撃に当たるたびに"damA()"が呼び出されます。

しかし、コンソール画面では「①hpC = 100」と「②10ずつ引かれているhpC(例:-90,-80,-70...)」の二つが表示されてしまいます。

さらに不可解なのがゲームの再生をストップし、再スタートしたとしても②の値がリセットされないことです(例:-90,-80,-70 ここで一度ゲームの再生を終了、そして再スタートさせる→-60,-50,-40となり-90からじゃない)

ちなみにUnity自体を再起動させると②はまた-90から始まるのですが、再起動後の初めの一回のみでゲームを再スタートさせると-60,-50,-40となり、果ては-2010,-2020,-2030というコンソール画面になってしまいます。
#敵の攻撃のスクリプト

using System.Collections; using System.Collections.Generic; using UnityEngine; public class Zspell : MonoBehaviour { [SerializeField] GameObject npc; paraN nsc; // Start is called before the first frame update void Start() { nsc = npc.GetComponent<paraN>(); } // Update is called once per frame void Update() { } //アニメーション後破壊 private void Des() { Destroy (this.gameObject); } private void OnTriggerExit2D(Collider2D other) { if (other.tag == "npc") { nsc.damA(); } } }

#実現したいこと
Update内のDebug.Logでの値が攻撃を喰らうたび-90,-80,-70と表示され、かつゲームが再スタートされるとまた-90,-80,-70とhpCがリセットされるようにしたいです。

このような現象は今までに遭遇したことはなく、調べてみても同じような例はなかったため投稿させていただきました。

返答のほどよろしくお願いいたします。

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

guest

回答2

0

とりあえず、ログを出力しているオブジェクトがどのオブジェクトか確認したいですね。

Debug.Log (hpC,gameobject);

こんな感じに、ログの第二引数にオブジェクトを指定してログを出力。そのログを選択すると第二引数のログを出力した状態になります。
ログでgameobjectのオブジェクト名を出力して確認してもOK。

そんな馬鹿な、と思うかもしれませんが、画面に1個だけだと思っていたものが2個あって、処理が複数回実行されている、ということは稀によくあります。

投稿2021/06/11 14:14

退会済みユーザー

退会済みユーザー

総合スコア0

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

da-ryo

2021/06/12 03:49

なるほど、第2引数でオブジェクト名まで確認できるのですね。知りませんでした笑 その後なのですが、当たり判定を攻撃オブジェクト側からnpc側に移し替えたところうまくいきました! ご協力ありがとうございます。
guest

0

自己解決

攻撃オブジェクトの当たり判定(OnTrigger)を外し、逆にnpc側に当たり判定を設けることでうまく動くようになりました。

投稿2021/06/12 03:51

da-ryo

総合スコア11

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.48%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問