- Home /
Trigger script does not work
What it want this script i made, to do is: When i enter its collider my controls disable so i can't move. That activates a statement so when i have pressed "i" 50 times the controls gets back again.
But it does not work. When i enter the collider and my controls disable the "i" press does not work.
Can someone help?
 #pragma strict
 
 var taps = 0; 
 var tapNow = false;
 
 function OnTriggerEnter (other : Collider) {
  if(other.tag == "Player") 
  
  GameObject.Find( "First Person Controller" ).GetComponent(FPSInputController).enabled = false;
 
 GameObject.Find( "First Person Controller" ).GetComponent(CharacterMotor).enabled = false;
 
 tapNow = true;
 
 }
 
 function Activate () {
 
   if(tapNow == true);
 
 if(Input.GetKeyDown("i")) taps = taps+1;
 
 if(taps == 50);
 
 GameObject.Find( "First Person Controller" ).GetComponent(FPSInputController).enabled = true;
 
 GameObject.Find( "First Person Controller" ).GetComponent( CharacterMotor).enabled = true;
 
 }
 
Answer by Statement · Dec 25, 2013 at 09:35 PM
The code hides some issues that are not obvious unless you indent your code properly.
Let's have a look with an indented version of your code (it does the same thing).
 #pragma strict
 var taps = 0; 
 var tapNow = false;
 function OnTriggerEnter (other : Collider) {
     if(other.tag == "Player") // Test only branches for one statement.
         GameObject.Find( "First Person Controller" ).GetComponent(FPSInputController).enabled = false;
         
     GameObject.Find( "First Person Controller" ).GetComponent(CharacterMotor).enabled = false;
     tapNow = true;
 }
 function Activate () {
     if(tapNow == true); // Wrongly placed ;-sign
     
     if(Input.GetKeyDown("i")) 
         taps = taps + 1;
     if(taps == 50); // Wrongly placed ;-sign
     
     GameObject.Find( "First Person Controller" ).GetComponent(FPSInputController).enabled = true;
     GameObject.Find( "First Person Controller" ).GetComponent( CharacterMotor).enabled = true;
 }
There are a couple of issues that may cause problems. For one, you don't use bodies for your if-statements so you are only executing the next line of code if the condition is met, and the other lines are executed regardless.
Your if-statements in Activate have statement terminators ; which basically render the tests useless.
Here is a version that hopefully works better. As you see, I added bracers around the code in the test, forming a block of code. I also made a small refactoring (extracted a method for enabling or disabling the objects scripts).
 #pragma strict
 var taps = 0; 
 var tapNow = false;
 function OnTriggerEnter (other : Collider) {
     if(other.tag == "Player") 
     {
         EnableFirstPersonController(false);
         tapNow = true;
     }
 }
 function Activate () {
     if(tapNow && Input.GetKeyDown("i"))
     { 
         taps = taps + 1;
         if(taps == 50)
         {
             EnableFirstPersonController(true);
             tapNow = false;
         }
     }
 }
 
 function EnableFirstPersonController(state : boolean) {
     var fpsController = GameObject.Find( "First Person Controller" );
     fpsController.GetComponent(FPSInputController).enabled = state;
     fpsController.GetComponent(CharacterMotor).enabled = state;
 }
Also, I am not sure if you have something calling Activate. Perhaps this function should be called `Update` for the script to function properly.
Your answer
 
 
             Follow this Question
Related Questions
The name 'Joystick' does not denote a valid type ('not found') 2 Answers
Boolean Not Changing 1 Answer
About Destructible 3d objects 1 Answer
Accesing another Script on gameObject and asking if it is true. 1 Answer
How to form copies of yourself that follow you when you walk? (2D Platformer) 2 Answers
 koobas.hobune.stream
koobas.hobune.stream 
                       
                
                       
			     
			 
                