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

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

ただいまの
回答率

89.55%

Objectに視線があたったときの時間のLogを取りたいです。

解決済

回答 1

投稿

  • 評価
  • クリップ 0
  • VIEW 456

前提・実現したいこと

下記のプログラムに自分で作成したログを取るプログラムを入れて実行してもLog自体が取れません。
また、ifの部分を変えて何回も取り組みましたができません

発生している問題・エラーメッセージ

Objectは光るがLogは取れていない

該当のソースコード

using UnityEngine;

public class FOVELookSample : MonoBehaviour
{
    public Light attachedLight;
    public FoveInterfaceBase foveInterface;

    private Collider my_collider;
    private Material material;
    private bool light_attached = false;

    void Start()
    {
        my_collider = GetComponent<Collider>();

        if (attachedLight == null)
            attachedLight = transform.GetComponentInChildren<Light>();

        if (attachedLight)
        {
            light_attached = true;
            attachedLight.enabled = false;
        }
        material = gameObject.GetComponent<Renderer>().material;

        if (material == null)
            gameObject.SetActive(false);
    }

    void Update()
    {
        if (foveInterface.Gazecast(my_collider))
        {
            material.EnableKeyword("_EMISSION");

            if (light_attached)
            {
                material.SetColor("_EmissionColor", attachedLight.color);
                attachedLight.enabled = true;
                DynamicGI.SetEmissive(GetComponent<Renderer>(), attachedLight.color);
            }
        }
        else
        {
            gameObject.GetComponent<Renderer>().material.color = Color.white;
            material.DisableKeyword("_EMISSION");

            if (light_attached)
            {
                attachedLight.enabled = false;
                DynamicGI.SetEmissive(GetComponent<Renderer>(), Color.black);
            }
        }
    }
}
  • 気になる質問をクリップする

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

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

    クリップを取り消します

  • 良い質問の評価を上げる

    以下のような質問は評価を上げましょう

    • 質問内容が明確
    • 自分も答えを知りたい
    • 質問者以外のユーザにも役立つ

    評価が高い質問は、TOPページの「注目」タブのフィードに表示されやすくなります。

    質問の評価を上げたことを取り消します

  • 評価を下げられる数の上限に達しました

    評価を下げることができません

    • 1日5回まで評価を下げられます
    • 1日に1ユーザに対して2回まで評価を下げられます

    質問の評価を下げる

    teratailでは下記のような質問を「具体的に困っていることがない質問」、「サイトポリシーに違反する質問」と定義し、推奨していません。

    • プログラミングに関係のない質問
    • やってほしいことだけを記載した丸投げの質問
    • 問題・課題が含まれていない質問
    • 意図的に内容が抹消された質問
    • 過去に投稿した質問と同じ内容の質問
    • 広告と受け取られるような投稿

    評価が下がると、TOPページの「アクティブ」「注目」タブのフィードに表示されにくくなります。

    質問の評価を下げたことを取り消します

    この機能は開放されていません

    評価を下げる条件を満たしてません

    評価を下げる理由を選択してください

    詳細な説明はこちら

    上記に当てはまらず、質問内容が明確になっていない質問には「情報の追加・修正依頼」機能からコメントをしてください。

    質問の評価を下げる機能の利用条件

    この機能を利用するためには、以下の事項を行う必要があります。

質問への追記・修正、ベストアンサー選択の依頼

  • bochan2

    2018/12/20 15:05

    Logを入れた方のコードを追加出来ますか?

    キャンセル

  • Gakuseitasukete

    2018/12/20 15:08

    using UnityEngine;

    public class hannnteiLog : MonoBehaviour
    {
    public Light attachedLight;
    public FoveInterfaceBase foveInterface;

    private Collider my_collider;
    private Material material;
    private bool light_attached = false;

    //private string datetimeStr;

    void Start()
    {
    my_collider = GetComponent<Collider>();

    if (attachedLight == null)
    attachedLight = transform.GetComponentInChildren<Light>();

    if (attachedLight)
    {
    light_attached = true;
    attachedLight.enabled = false;
    }
    material = gameObject.GetComponent<Renderer>().material;

    if (material == null)
    gameObject.SetActive(false);
    }

    void Update()
    {

    //StreamWriter sw;
    //FileInfo fi;

    //fi = new FileInfo(Application.dataPath + "/Log/hannteiLog/hanntei00.csv");
    //sw = fi.AppendText();

    if (foveInterface.Gazecast(my_collider))
    {
    material.EnableKeyword("_EMISSION");

    if (light_attached)
    {
    material.SetColor("_EmissionColor", attachedLight.color);
    attachedLight.enabled = true;
    DynamicGI.SetEmissive(GetComponent<Renderer>(), attachedLight.color);

    /* datetimeStr = System.DateTime.Now.Year.ToString() + "." +
    System.DateTime.Now.Month.ToString() + "." +
    System.DateTime.Now.Day.ToString() + "." +
    System.DateTime.Now.Hour.ToString() + "." +
    System.DateTime.Now.Minute.ToString() + "." +
    System.DateTime.Now.Second.ToString() + "." +
    System.DateTime.Now.Millisecond.ToString();
    sw.WriteLine(datetimeStr);*/

    }
    //sw.Flush();
    //sw.Close();
    }
    else
    {
    gameObject.GetComponent<Renderer>().material.color = Color.white;
    material.DisableKeyword("_EMISSION");

    if (light_attached)
    {
    attachedLight.enabled = false;
    DynamicGI.SetEmissive(GetComponent<Renderer>(), Color.black);
    }
    }
    }
    }

    キャンセル

  • Gakuseitasukete

    2018/12/20 15:09

    //入れときました、追加のところには
    光るところに光れば時間のLogを残すプログラムを入れればいけるかなとおもったものです。

    キャンセル

回答 1

checkベストアンサー

0

sw.FlushはStreamWriterの中身を空にしてしまうのでデータを書き込んだ後に実行すると書き込んだデータが消えてしまいます。
sw.Flushを削除すれば動作すると思います。
Flushの動作:

Clears all buffers for the current writer and causes any buffered data to be written to the underlying stream.

投稿

  • 回答の評価を上げる

    以下のような回答は評価を上げましょう

    • 正しい回答
    • わかりやすい回答
    • ためになる回答

    評価が高い回答ほどページの上位に表示されます。

  • 回答の評価を下げる

    下記のような回答は推奨されていません。

    • 間違っている回答
    • 質問の回答になっていない投稿
    • スパムや攻撃的な表現を用いた投稿

    評価を下げる際はその理由を明確に伝え、適切な回答に修正してもらいましょう。

  • 2018/12/20 19:49

    普通にDebug.Log()でプリントして
    https://docs.unity3d.com/Manual/LogFiles.html
    のやり方でエキスポートも出来ますが余計なLogが入ったりします

    キャンセル

  • 2018/12/26 18:31

    確かに動きました。Logも残りました。
    ありがとございます。

    キャンセル

  • 2018/12/26 18:36

    エラーが出るのですが解決方法分かりますか?

    IOException: Sharing violation on path C:\Users\surfa\Desktop\New Unity Project 9\Assets\Log\hannteiLog\hanntei00.csv
    System.IO.FileStream..ctor (System.String path, FileMode mode, FileAccess access, FileShare share, Int32 bufferSize, Boolean anonymous, FileOptions options) (at /Users/builduser/buildslave/mono/build/mcs/class/corlib/System.IO/FileStream.cs:320)
    System.IO.FileStream..ctor (System.String path, FileMode mode, FileAccess access, FileShare share)
    (wrapper remoting-invoke-with-check) System.IO.FileStream:.ctor (string,System.IO.FileMode,System.IO.FileAccess,System.IO.FileShare)
    System.IO.FileInfo.Open (FileMode mode, FileAccess access, FileShare share) (at /Users/builduser/buildslave/mono/build/mcs/class/corlib/System.IO/FileInfo.cs:210)
    System.IO.FileInfo.Open (FileMode mode, FileAccess access) (at /Users/builduser/buildslave/mono/build/mcs/class/corlib/System.IO/FileInfo.cs:205)
    System.IO.FileInfo.AppendText () (at /Users/builduser/buildslave/mono/build/mcs/class/corlib/System.IO/FileInfo.cs:178)
    (wrapper remoting-invoke-with-check) System.IO.FileInfo:AppendText ()
    hannteiLog.Update () (at Assets/hannteiLog.cs:40)

    キャンセル

  • 2018/12/26 21:48

    ファイル構成や他の条件が絡んでくるので、ファイル書き込み部分だけのプログラムを作って別の質問にして下さい
    申し訳ございません

    キャンセル

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

  • ただいまの回答率 89.55%
  • 質問をまとめることで、思考を整理して素早く解決
  • テンプレート機能で、簡単に質問をまとめられる