2016-11-21 21:31:10 +00:00
|
|
|
/**
|
|
|
|
* @file Arduboy2Audio.h
|
|
|
|
* \brief
|
|
|
|
* The Arduboy2Audio class for speaker and sound control.
|
|
|
|
*/
|
|
|
|
|
2016-10-27 18:59:56 +00:00
|
|
|
#ifndef ARDUBOY2_AUDIO_H
|
|
|
|
#define ARDUBOY2_AUDIO_H
|
2015-05-01 05:26:58 +00:00
|
|
|
|
|
|
|
#include <Arduino.h>
|
|
|
|
#include <EEPROM.h>
|
|
|
|
|
2016-11-21 21:31:10 +00:00
|
|
|
/** \brief
|
|
|
|
* Provide speaker and sound control.
|
|
|
|
*
|
|
|
|
* \details
|
|
|
|
* This class provides functions to initialize the speaker and control the
|
|
|
|
* enabling and disabling (muting) of sound. It doesn't provide any functions
|
|
|
|
* to actually produce sound.
|
|
|
|
*
|
|
|
|
* The state of sound muting is stored in system EEPROM and so is retained
|
|
|
|
* over power cycles.
|
|
|
|
*
|
|
|
|
* An Arduboy2Audio class object named `audio` will be created by the
|
|
|
|
* Arduboy2Base class, so there is no need for a sketch itself to create an
|
|
|
|
* Arduboy2Audio object. Arduboy2Audio functions can be called using the
|
|
|
|
* Arduboy2 or Arduboy2Base `audio` object.
|
|
|
|
*
|
|
|
|
* Example:
|
|
|
|
*
|
2018-03-07 21:49:21 +00:00
|
|
|
* \code{.cpp}
|
2016-11-21 21:31:10 +00:00
|
|
|
* #include <Arduboy2.h>
|
2016-11-22 19:05:52 +00:00
|
|
|
*
|
2016-11-21 21:31:10 +00:00
|
|
|
* Arduboy2 arduboy;
|
|
|
|
*
|
|
|
|
* // Arduboy2Audio functions can be called as follows:
|
|
|
|
* arduboy.audio.on();
|
|
|
|
* arduboy.audio.off();
|
|
|
|
* \endcode
|
|
|
|
*
|
|
|
|
* \note
|
|
|
|
* \parblock
|
|
|
|
* In order for this class to be fully functional, the external library or
|
|
|
|
* functions used by a sketch to actually to produce sounds should be compliant
|
|
|
|
* with this class. This means they should only produce sound if it is enabled,
|
|
|
|
* or mute the sound if it's disabled. The `enabled()` function can be used
|
|
|
|
* to determine if sound is enabled or muted. Generally a compliant library
|
|
|
|
* would accept the `enabled()` function as an initialization parameter and
|
|
|
|
* then call it as necessary to determine the current state.
|
|
|
|
*
|
|
|
|
* For example, the ArduboyTones and ArduboyPlaytune libraries require an
|
|
|
|
* `enabled()` type function to be passed as a parameter in the constructor,
|
|
|
|
* like so:
|
|
|
|
*
|
2018-03-07 21:49:21 +00:00
|
|
|
* \code{.cpp}
|
2016-11-21 21:31:10 +00:00
|
|
|
* #include <Arduboy2.h>
|
|
|
|
* #include <ArduboyTones.h>
|
|
|
|
*
|
|
|
|
* Arduboy2 arduboy;
|
|
|
|
* ArduboyTones sound(arduboy.audio.enabled);
|
|
|
|
* \endcode
|
|
|
|
* \endparblock
|
2016-11-22 22:45:38 +00:00
|
|
|
*
|
|
|
|
* \note
|
|
|
|
* \parblock
|
|
|
|
* A friend class named _Arduboy2Ex_ is declared by this class. The intention
|
|
|
|
* is to allow a sketch to create an _Arduboy2Ex_ class which would have access
|
|
|
|
* to the private and protected members of the Arduboy2Audio class. It is hoped
|
|
|
|
* that this may eliminate the need to create an entire local copy of the
|
|
|
|
* library, in order to extend the functionality, in most circumstances.
|
|
|
|
* \endparblock
|
2016-11-21 21:31:10 +00:00
|
|
|
*/
|
2016-10-27 18:59:56 +00:00
|
|
|
class Arduboy2Audio
|
2015-05-01 05:26:58 +00:00
|
|
|
{
|
2016-11-22 22:45:38 +00:00
|
|
|
friend class Arduboy2Ex;
|
|
|
|
|
2016-10-20 17:28:29 +00:00
|
|
|
public:
|
2016-11-21 21:31:10 +00:00
|
|
|
/** \brief
|
|
|
|
* Initialize the speaker based on the current mute setting.
|
|
|
|
*
|
|
|
|
* \details
|
|
|
|
* The speaker is initialized based on the current mute setting saved in
|
2020-09-24 21:31:27 +00:00
|
|
|
* system EEPROM.
|
|
|
|
*/
|
2020-03-16 18:44:28 +00:00
|
|
|
static void begin();
|
2016-11-21 21:31:10 +00:00
|
|
|
|
|
|
|
/** \brief
|
|
|
|
* Turn sound on.
|
|
|
|
*
|
|
|
|
* \details
|
|
|
|
* The system is configured to generate sound. This function sets the sound
|
|
|
|
* mode only until the unit is powered off. To save the current mode use
|
|
|
|
* `saveOnOff()`.
|
|
|
|
*
|
2016-12-13 16:49:29 +00:00
|
|
|
* \see off() toggle() saveOnOff()
|
2016-11-21 21:31:10 +00:00
|
|
|
*/
|
2020-03-16 18:44:28 +00:00
|
|
|
static void on();
|
2016-11-21 21:31:10 +00:00
|
|
|
|
|
|
|
/** \brief
|
|
|
|
* Turn sound off (mute).
|
|
|
|
*
|
|
|
|
* \details
|
|
|
|
* The system is configured to not produce sound (mute). This function sets
|
|
|
|
* the sound mode only until the unit is powered off. To save the current
|
|
|
|
* mode use `saveOnOff()`.
|
|
|
|
*
|
2016-12-13 16:49:29 +00:00
|
|
|
* \see on() toggle() saveOnOff()
|
2016-11-21 21:31:10 +00:00
|
|
|
*/
|
2020-03-16 18:44:28 +00:00
|
|
|
static void off();
|
2016-11-21 21:31:10 +00:00
|
|
|
|
2016-12-13 16:49:29 +00:00
|
|
|
/** \brief
|
|
|
|
* Toggle the sound on/off state.
|
|
|
|
*
|
|
|
|
* \details
|
|
|
|
* If the system is configured for sound on, it will be changed to sound off
|
|
|
|
* (mute). If sound is off, it will be changed to on. This function sets
|
|
|
|
* the sound mode only until the unit is powered off. To save the current
|
|
|
|
* mode use `saveOnOff()`.
|
|
|
|
*
|
|
|
|
* \see on() off() saveOnOff()
|
|
|
|
*/
|
2020-03-16 18:44:28 +00:00
|
|
|
static void toggle();
|
2016-12-13 16:49:29 +00:00
|
|
|
|
2016-11-21 21:31:10 +00:00
|
|
|
/** \brief
|
|
|
|
* Save the current sound state in EEPROM.
|
|
|
|
*
|
|
|
|
* \details
|
|
|
|
* The current sound state, set by `on()` or `off()`, is saved to the
|
|
|
|
* reserved system area in EEPROM. This allows the state to carry over between
|
|
|
|
* power cycles and after uploading a different sketch.
|
|
|
|
*
|
|
|
|
* \note
|
|
|
|
* EEPROM is limited in the number of times it can be written to. Sketches
|
|
|
|
* should not continuously change and then save the state rapidly.
|
|
|
|
*
|
2016-12-13 16:49:29 +00:00
|
|
|
* \see on() off() toggle()
|
2016-11-21 21:31:10 +00:00
|
|
|
*/
|
2020-03-16 18:44:28 +00:00
|
|
|
static void saveOnOff();
|
2016-11-21 21:31:10 +00:00
|
|
|
|
|
|
|
/** \brief
|
|
|
|
* Get the current sound state.
|
|
|
|
*
|
|
|
|
* \return `true` if sound is currently enabled (not muted).
|
|
|
|
*
|
|
|
|
* \details
|
|
|
|
* This function should be used by code that actually generates sound.
|
|
|
|
* If `true` is returned, sound can be produced. If `false` is returned,
|
|
|
|
* sound should be muted.
|
|
|
|
*
|
2016-12-13 16:49:29 +00:00
|
|
|
* \see on() off() toggle()
|
2016-11-21 21:31:10 +00:00
|
|
|
*/
|
2020-03-16 18:44:28 +00:00
|
|
|
static bool enabled();
|
2015-05-01 05:26:58 +00:00
|
|
|
|
2016-10-20 17:28:29 +00:00
|
|
|
protected:
|
2020-03-16 18:44:28 +00:00
|
|
|
static bool audio_enabled;
|
2015-05-01 05:26:58 +00:00
|
|
|
};
|
|
|
|
|
|
|
|
#endif
|