![]() |
Compressor works in teleop but not autonomous?
Hi,
We're having some issues with our compressor in autonomous. compressor.start(); doesn't seem to do anything, but all other code in autonomous works fine, and compressor.start(); works in teleop. Are we doing something wrong? |
Re: Compressor works in teleop but not autonomous?
what we did was put the compressor.start(); line in robotInit() and it worked all the time
|
Re: Compressor works in teleop but not autonomous?
compressor.start() won't start the compressor every time you call it.
It is designed to be called once for every time you stop it. (it defaults to off) When you call start, a semaphore is set to true. This flag is checked twice a second by another thread, and if enabled (from the semaphore) and enabled (from the driver station) and the pressure switch pulls the IO pin to ground it sets the compressor's spike to turn on forward. The line Code:
c->Enabled()This is the thread that turns on and off the compressor (In C++, the Java version is very similar): Code:
static void compressorChecker(Compressor *c)You only need to call start once in the program. |
Re: Compressor works in teleop but not autonomous?
Hi,
@biojae: We know that compressor.start(); is meant to be called once. The problem is, it doesn't do anything (even with pressure at zero). In other words, it's not starting even when it should (and again, the compressor works in teleop without an issue). @buildmaster5000: We're using SimpleRobotTemplate, so we don't have robotInit(). We'll try robotMain() and see what it does. |
| All times are GMT -5. The time now is 09:42. |
Powered by vBulletin® Version 3.6.4
Copyright ©2000 - 2017, Jelsoft Enterprises Ltd.
Copyright © Chief Delphi