Wayback Machinekoobas.hobune.stream
May JUN Jul
Previous capture 12 Next capture
2021 2022 2023
1 capture
12 Jun 22 - 12 Jun 22
sparklines
Close Help
  • Products
  • Solutions
  • Made with Unity
  • Learning
  • Support & Services
  • Community
  • Asset Store
  • Get Unity

UNITY ACCOUNT

You need a Unity Account to shop in the Online and Asset Stores, participate in the Unity Community and manage your license portfolio. Login Create account
  • Blog
  • Forums
  • Answers
  • Evangelists
  • User Groups
  • Beta Program
  • Advisory Panel

Navigation

  • Home
  • Products
  • Solutions
  • Made with Unity
  • Learning
  • Support & Services
  • Community
    • Blog
    • Forums
    • Answers
    • Evangelists
    • User Groups
    • Beta Program
    • Advisory Panel

Unity account

You need a Unity Account to shop in the Online and Asset Stores, participate in the Unity Community and manage your license portfolio. Login Create account

Language

  • Chinese
  • Spanish
  • Japanese
  • Korean
  • Portuguese
  • Ask a question
  • Spaces
    • Default
    • Help Room
    • META
    • Moderators
    • Topics
    • Questions
    • Users
    • Badges
  • Home /
This question was closed Jul 08, 2020 at 03:47 AM by NEGATIVERAGDOLL for the following reason:

The question is answered, right answer was accepted

avatar image
0
Question by NEGATIVERAGDOLL · Feb 22, 2018 at 02:53 AM · c#lightboolincorrect

Lights on Script not always working

Hello, so I created a basic script that when "e" is pressed down the light specified turns on, then off again if you press it again. For some reason though the light doesn't always turn on when "e" is pressed and I have no idea why. Here's my script:

 using System.Collections;
 using System.Collections.Generic;
 using UnityEngine;
 
 public class LightsOnPress : MonoBehaviour
 {
     public AudioSource Click;
     public Light Lights;
     public GameObject Text;
     public bool LightisOn;
 
     public void Start()
     {
         LightisOn = Lights.enabled = false;
     }
 
 
 
     void OnTriggerStay(Collider other)
     {
         Text.gameObject.SetActive(true);
     
          if (Input.GetKeyDown("e"))
         {
            
 
             if (LightisOn)
             {
                 LightisOn = Lights.enabled = false;
                 Click.Play();
             }
             else
             {
                 LightisOn = Lights.enabled = true;
                 Click.Play();
             }
        }
     }
 
      void OnTriggerExit(Collider other)
     {
         Text.gameObject.SetActive(false);
     }
 }
Comment
Add comment
10 |3000 characters needed characters left characters exceeded
▼
  • Viewable by all users
  • Viewable by moderators
  • Viewable by moderators and the original poster
  • Advanced visibility
Viewable by all users

1 Reply

  • Sort: 
avatar image
0
Best Answer

Answer by yummy81 · Feb 22, 2018 at 11:29 AM

It's simple. Input event information should be processed in Update. Processing these events in FixedUpdate can lead to unpredictable results. When it comes to your code, the problem is that you check for the input inside OnTriggerStay, which acts as FixedUpdate. The solution would be to move this code into coroutine-turned OnTriggerEnter. So basically, it could look like that:

 private IEnumerator OnTriggerEnter(Collider other)
 {
     while(true) 
     {
         // here's your code from OnTriggerStay
         yield return null;
     }
 }
 
 

As you can see, when coroutine version of OnTriggerEnter yields "null", it acts as Update. And, here's your script after modifications. It should now work as you want:

 using System.Collections;
 using System.Collections.Generic;
 using UnityEngine;
 
 public class LightsOnPress : MonoBehaviour
 {
     public AudioSource Click;
     public Light Lights;
     public GameObject Text;
     public bool LightisOn;
 
     public void Start()
     {
     LightisOn = Lights.enabled = false;
     }
 
     IEnumerator OnTriggerEnter(Collider other)
     {
         Text.gameObject.SetActive(true);
 
         while (true)
         {
             if (Input.GetKeyDown("e"))
             {
                 if (LightisOn)
                 {
                     LightisOn = Lights.enabled = false;
                     Click.Play();
                 }
                 else
                 {
                     LightisOn = Lights.enabled = true;
                     Click.Play();
                 }
             }
             yield return null;
         }
     }
 
     void OnTriggerExit(Collider other)
     {
         Text.gameObject.SetActive(false);
     }
 }
 
 
Comment
Add comment · Show 4 · Share
10 |3000 characters needed characters left characters exceeded
▼
  • Viewable by all users
  • Viewable by moderators
  • Viewable by moderators and the original poster
  • Advanced visibility
Viewable by all users
avatar image NEGATIVERAGDOLL · Feb 22, 2018 at 01:37 PM 0
Share

Hello,

thank you for the response. I have tried the script, it works for the most part but there's a few problems. When I enter the collider I am able to turn the light off but after exit I can turn it off an on whenever. Also no matter where I am "e" results in my "click" audio being played.

avatar image yummy81 NEGATIVERAGDOLL · Feb 22, 2018 at 02:10 PM 0
Share

You're right! So, I introduced new Boolean and I named it "boo". I added or modified following lines: 11, 21, 23, and 44. Here's the script:

 using System.Collections;
 using System.Collections.Generic;
 using UnityEngine;
 
 public class LightsOnPress : $$anonymous$$onoBehaviour
 {
     public AudioSource Click;
     public Light Lights;
     public GameObject Text;
     public bool LightisOn;
     public bool boo;
 
     public void Start()
     {
         LightisOn = Lights.enabled = false;
     }
 
     IEnumerator OnTriggerEnter(Collider other)
     {
         Text.gameObject.SetActive(true);
         boo = true;
 
         while (boo)
         {
             if (Input.Get$$anonymous$$eyDown("e"))
             {
                 if (LightisOn)
                 {
                     LightisOn = Lights.enabled = false;
                     Click.Play();
                 }
                 else
                 {
                     LightisOn = Lights.enabled = true;
                     Click.Play();
                 }
             }
             yield return null;
         }
     }
 
     void OnTriggerExit(Collider other)
     {
         boo = false;
         Text.gameObject.SetActive(false);
     }
 }
 
 
avatar image NEGATIVERAGDOLL yummy81 · Feb 22, 2018 at 02:44 PM 0
Share

Thank you very much, it worked! I have accepted your answer as the correct one. I hope you have a good day! :)

Show more comments

Follow this Question

Answers Answers and Comments

452 People are following this question.

avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image

Related Questions

Multiple Cars not working 1 Answer

Distribute terrain in zones 3 Answers

Dissable lights per camera? 2 Answers

Enable Draw Halo in Light Component via Script 1 Answer

I can't figure out why this if statement isn't responding 1 Answer


Enterprise
Social Q&A

Social
Subscribe on YouTube social-youtube Follow on LinkedIn social-linkedin Follow on Twitter social-twitter Follow on Facebook social-facebook Follow on Instagram social-instagram

Footer

  • Purchase
    • Products
    • Subscription
    • Asset Store
    • Unity Gear
    • Resellers
  • Education
    • Students
    • Educators
    • Certification
    • Learn
    • Center of Excellence
  • Download
    • Unity
    • Beta Program
  • Unity Labs
    • Labs
    • Publications
  • Resources
    • Learn platform
    • Community
    • Documentation
    • Unity QA
    • FAQ
    • Services Status
    • Connect
  • About Unity
    • About Us
    • Blog
    • Events
    • Careers
    • Contact
    • Press
    • Partners
    • Affiliates
    • Security
Copyright © 2020 Unity Technologies
  • Legal
  • Privacy Policy
  • Cookies
  • Do Not Sell My Personal Information
  • Cookies Settings
"Unity", Unity logos, and other Unity trademarks are trademarks or registered trademarks of Unity Technologies or its affiliates in the U.S. and elsewhere (more info here). Other names or brands are trademarks of their respective owners.
  • Anonymous
  • Sign in
  • Create
  • Ask a question
  • Spaces
  • Default
  • Help Room
  • META
  • Moderators
  • Explore
  • Topics
  • Questions
  • Users
  • Badges