parent
							
								
									8093c5f534
								
							
						
					
					
						commit
						2b5faa61e2
					
				| @ -1,74 +0,0 @@ | ||||
| /**
 | ||||
|  * Marlin 3D Printer Firmware | ||||
|  * Copyright (C) 2016 MarlinFirmware [https://github.com/MarlinFirmware/Marlin]
 | ||||
|  * | ||||
|  * Based on Sprinter and grbl. | ||||
|  * Copyright (C) 2011 Camiel Gubbels / Erik van der Zalm | ||||
|  * | ||||
|  * This program is free software: you can redistribute it and/or modify | ||||
|  * it under the terms of the GNU General Public License as published by | ||||
|  * the Free Software Foundation, either version 3 of the License, or | ||||
|  * (at your option) any later version. | ||||
|  * | ||||
|  * This program is distributed in the hope that it will be useful, | ||||
|  * but WITHOUT ANY WARRANTY; without even the implied warranty of | ||||
|  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the | ||||
|  * GNU General Public License for more details. | ||||
|  * | ||||
|  * You should have received a copy of the GNU General Public License | ||||
|  * along with this program.  If not, see <http://www.gnu.org/licenses/>.
 | ||||
|  * | ||||
|  */ | ||||
| 
 | ||||
| #ifndef __SPEAKER_H__ | ||||
| #define __SPEAKER_H__ | ||||
| 
 | ||||
| #include "buzzer.h" | ||||
| 
 | ||||
| class Speaker: public Buzzer { | ||||
|   private: | ||||
|     typedef Buzzer super; | ||||
| 
 | ||||
|     struct state_t { | ||||
|       tone_t   tone; | ||||
|       millis_t next; | ||||
|     } state; | ||||
| 
 | ||||
|   protected: | ||||
|     /**
 | ||||
|      * @brief Resets the state of the class | ||||
|      * @details Brings the class state to a known one. | ||||
|      */ | ||||
|     void reset() { | ||||
|       super::reset(); | ||||
|       this->state.next = 0; | ||||
|     } | ||||
| 
 | ||||
|   public: | ||||
|     /**
 | ||||
|      * @brief Class constructor | ||||
|      */ | ||||
|     Speaker() { | ||||
|       this->reset(); | ||||
|     } | ||||
| 
 | ||||
|     /**
 | ||||
|      * @brief Loop function | ||||
|      * @details This function should be called at loop, it will take care of | ||||
|      * playing the tones in the queue. | ||||
|      */ | ||||
|     virtual void tick() { | ||||
|       const uint32_t now = millis(); | ||||
| 
 | ||||
|       if (now >= this->state.next) { | ||||
|         if (this->buffer.isEmpty()) return; | ||||
| 
 | ||||
|         this->reset(); | ||||
|         this->state.tone = this->buffer.dequeue(); | ||||
|         this->state.next = now + this->state.tone.duration; | ||||
|         ::tone(BEEPER_PIN, this->state.tone.frequency, this->state.tone.duration); | ||||
|       } | ||||
|     } | ||||
| }; | ||||
| 
 | ||||
| #endif | ||||
					Loading…
					
					
				
		Reference in new issue
	
	 João Brázio
						João Brázio