ardupilot/libraries/SITL/SIM_Buzzer.cpp
2019-10-16 16:00:35 +11:00

134 lines
3.5 KiB
C++

/*
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/>.
*/
/*
simple buzzer simulator class
*/
#include <GCS_MAVLink/GCS.h>
#include <SITL/SITL.h>
#include "SIM_Buzzer.h"
#ifdef WITH_SITL_TONEALARM
#ifdef HAVE_SFML_AUDIO_H
#include <SFML/Audio.h>
#else
#include <SFML/Audio.hpp>
#endif
// need to namespace this or we end up with multiple definitions of
// things from Synth.hpp
namespace BuzzerSynth {
#include <AP_HAL_SITL/Synth.hpp>
};
#endif
using namespace SITL;
// table of user settable parameters
const AP_Param::GroupInfo Buzzer::var_info[] = {
// @Param: ENABLE
// @DisplayName: Buzzer enable/disable
// @Description: Allows you to enable (1) or disable (0) the simulated buzzer
// @Values: 0:Disabled,1:Enabled
// @User: Advanced
AP_GROUPINFO("ENABLE", 0, Buzzer, _enable, 0),
// @Param: PIN
// @DisplayName: buzzer pin
// @Description: The pin number that the Buzzer is connected to (start at 1)
// @Range: 0 15
// @User: Advanced
AP_GROUPINFO("PIN", 1, Buzzer, _pin, -1),
AP_GROUPEND
};
#ifdef WITH_SITL_TONEALARM
static sf::SoundBuffer xsoundBuffer;
static sf::Sound xdemoSound;
static uint32_t duration_ms = 10000;
Buzzer::Buzzer() {
AP_Param::setup_object_defaults(this, var_info);
};
void Buzzer::update(const struct sitl_input &input)
{
// prepare buzz tone
// BuzzerSynth::Synth::sEnvelope xenvelope;
if (!prep_done) {
BuzzerSynth::Synth::sEnvelope xenvelope;
xenvelope.dAttackTime = 0.000001;
xenvelope.dDecayTime = 0.000001;
xenvelope.dSustainTime = 10;
xenvelope.dReleaseTime = 0.00001;
xenvelope.dStartAmplitude = 1.0;
xenvelope.dSustainAmplitude = 1.0;
const uint32_t frequency = 2000;
BuzzerSynth::Synth::sTone tone;
tone.waveType = BuzzerSynth::Synth::OSC_SQUARE;
tone.dStartFrequency = frequency;
tone.dEndFrequency = frequency;
tone.dAmplitude = 1;
xenvelope.dSustainTime = duration_ms/1000.0f;
BuzzerSynth::Synth::generate(&xsoundBuffer, xenvelope, tone, 20000, 44100);
xdemoSound.setBuffer(xsoundBuffer);
prep_done = true;
}
const bool on = _pin >= 1 && (AP::sitl()->pin_mask.get() & (1<<_pin));
const uint32_t now = AP_HAL::millis();
if (on) {
if (!was_on) {
gcs().send_text(MAV_SEVERITY_WARNING, "%u: Buzzer on", now);
on_time = now;
was_on = true;
xdemoSound.play();
}
if (now - on_time > duration_ms/2) {
gcs().send_text(MAV_SEVERITY_WARNING, "%u: Buzzer on again", now);
on_time = now;
xdemoSound.play();
}
} else {
if (was_on) {
gcs().send_text(MAV_SEVERITY_WARNING, "%u: Buzzer off", now);
xdemoSound.stop();
was_on = false;
}
}
}
#else
using namespace SITL;
Buzzer::Buzzer() { };
void Buzzer::update(const struct sitl_input &input) {}
#endif