32 [[nodiscard]]
const std::string&
getName()
const {
return name; }
37 [[nodiscard]] std::string_view
getDescription()
const {
return description; }
73 return {f * softwareVolumeLeft, f * softwareVolumeRight};
98 void setBalance(
unsigned channel,
float balance);
116 [[nodiscard]] std::span<const float>
getLastBuffer(
unsigned channel);
129 return inputSampleRate / 7;
145 unsigned numChannels,
unsigned inputRate,
bool stereo);
175 void setInputRate(
unsigned sampleRate) { inputSampleRate = sampleRate; }
176 [[nodiscard]]
unsigned getInputRate()
const {
return inputSampleRate; }
205 EmuTime::param time) = 0;
216 static void addFill(
float*& buffer,
float value,
unsigned num);
245 [[nodiscard]]
bool mixChannels(
float* dataOut,
size_t samples);
257 const std::string name;
260 std::array<std::optional<Wav16Writer>,
MAX_CHANNELS> writer;
262 float softwareVolumeLeft = 1.0f;
263 float softwareVolumeRight = 1.0f;
264 unsigned inputSampleRate;
265 const unsigned numChannels;
266 const unsigned stereo;
267 unsigned numRecordChannels = 0;
268 std::array<Balance, MAX_CHANNELS> channelBalance;
269 std::array<bool, MAX_CHANNELS> channelMuted;
270 bool balanceCenter =
true;
275 struct PerChannelBuffer {
276 std::vector<float> buffer;
277 unsigned stopIdx = 0;
278 unsigned requestCounter = 0;
279 unsigned silent = 999999;
281 std::array<PerChannelBuffer, MAX_CHANNELS> channelBuffers = {};
Represents a clock with a variable frequency.
This class represents a filename.
double getEffectiveSpeed() const
SoundDevice & operator=(const SoundDevice &)=delete
std::string_view getDescription() const
Gets a description of this sound device, to be presented to the user.
virtual bool updateBuffer(size_t length, float *buffer, EmuTime::param time)=0
Generate sample data.
unsigned getNumChannels() const
How many channels does this device have?
void recordChannel(unsigned channel, const Filename &filename)
bool hasStereoChannels() const
Are the individual channels of this device stereo?
void updateStream(EmuTime::param time)
unsigned getInputRate() const
SoundDevice & operator=(SoundDevice &&)=delete
unsigned getLastBufferSize() const
AmplificationFactors getAmplificationFactor() const
const std::string & getName() const
Get the unique name that identifies this sound device.
float getNativeSampleRate() const
The samples returned by 'getLastBuffer()' have this sample rate.
static void addFill(float *&buffer, float value, unsigned num)
Adds a number of samples that all have the same value.
const DynamicClock & getHostSampleClock() const
See MSXMixer::getHostSampleClock().
SoundDevice(SoundDevice &&)=delete
void setInputRate(unsigned sampleRate)
virtual void setOutputRate(unsigned hostSampleRate, double speed)=0
When a SoundDevice registers itself with the Mixer, the Mixer sets the required sampleRate through th...
void setSoftwareVolume(float volume, EmuTime::param time)
Change the 'software volume' of this sound device.
bool mixChannels(float *dataOut, size_t samples)
Calls generateChannels() and combines the output to a single channel.
static constexpr unsigned MAX_CHANNELS
void unregisterSound()
Unregisters this sound device with the Mixer.
unsigned getLastMonoBufferSize() const
getLastBuffer() with return buffers containing this many samples.
SoundDevice(const SoundDevice &)=delete
bool isStereo() const
Is the full output of this device stereo?
virtual void generateChannels(std::span< float * > buffers, unsigned num)=0
Abstract method to generate the actual sound data.
void setBalance(unsigned channel, float balance)
Change the balance of a single channel.
virtual void postSetBalance()
void registerSound(const DeviceConfig &config)
Registers this sound device with the Mixer.
std::span< const float > getLastBuffer(unsigned channel)
Query the last generated audio signal for a specific channel.
void muteChannel(unsigned channel, bool muted)
virtual float getAmplificationFactorImpl() const
Get amplification/attenuation factor for this device.
This file implemented 3 utility functions:
Gets this device its 'amplification factor'.