2018-04-17 22:28:13 -04:00
|
|
|
//
|
|
|
|
// AudioToggle.hpp
|
|
|
|
// Clock Signal
|
|
|
|
//
|
|
|
|
// Created by Thomas Harte on 17/04/2018.
|
2018-05-13 15:19:52 -04:00
|
|
|
// Copyright 2018 Thomas Harte. All rights reserved.
|
2018-04-17 22:28:13 -04:00
|
|
|
//
|
|
|
|
|
|
|
|
#ifndef AudioToggle_hpp
|
|
|
|
#define AudioToggle_hpp
|
|
|
|
|
|
|
|
#include "../../Outputs/Speaker/Implementation/SampleSource.hpp"
|
|
|
|
#include "../../Concurrency/AsyncTaskQueue.hpp"
|
|
|
|
|
|
|
|
namespace Audio {
|
|
|
|
|
|
|
|
/*!
|
|
|
|
Provides a sample source that can programmatically be set to one of two values.
|
|
|
|
*/
|
|
|
|
class Toggle: public Outputs::Speaker::SampleSource {
|
|
|
|
public:
|
2022-07-16 14:41:04 -04:00
|
|
|
Toggle(Concurrency::AsyncTaskQueue<false> &audio_queue);
|
2018-04-17 22:28:13 -04:00
|
|
|
|
|
|
|
void get_samples(std::size_t number_of_samples, std::int16_t *target);
|
|
|
|
void set_sample_volume_range(std::int16_t range);
|
|
|
|
void skip_samples(const std::size_t number_of_samples);
|
|
|
|
|
|
|
|
void set_output(bool enabled);
|
2020-05-09 21:22:51 -04:00
|
|
|
bool get_output() const;
|
2018-04-17 22:28:13 -04:00
|
|
|
|
|
|
|
private:
|
2018-04-21 14:56:50 -07:00
|
|
|
// Accessed on the calling thread.
|
2018-04-17 22:28:13 -04:00
|
|
|
bool is_enabled_ = false;
|
2022-07-16 14:41:04 -04:00
|
|
|
Concurrency::AsyncTaskQueue<false> &audio_queue_;
|
2018-04-21 14:56:50 -07:00
|
|
|
|
|
|
|
// Accessed on the audio thread.
|
|
|
|
int16_t level_ = 0, volume_ = 0;
|
2018-04-17 22:28:13 -04:00
|
|
|
};
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
#endif /* AudioToggle_hpp */
|