2016-02-21 07:13:52 -06:00
|
|
|
// Copyright 2016 Citra Emulator Project
|
|
|
|
// Licensed under GPLv2 or any later version
|
|
|
|
// Refer to the license.txt file included.
|
|
|
|
|
|
|
|
#pragma once
|
|
|
|
|
|
|
|
#include <vector>
|
|
|
|
#include "common/common_types.h"
|
|
|
|
|
|
|
|
namespace AudioCore {
|
|
|
|
|
|
|
|
/**
|
2016-09-17 19:38:01 -05:00
|
|
|
* This class is an interface for an audio sink. An audio sink accepts samples in stereo signed
|
2016-09-18 20:01:46 -05:00
|
|
|
* PCM16 format to be output. Sinks *do not* handle resampling and expect the correct sample rate.
|
|
|
|
* They are dumb outputs.
|
2016-02-21 07:13:52 -06:00
|
|
|
*/
|
|
|
|
class Sink {
|
|
|
|
public:
|
|
|
|
virtual ~Sink() = default;
|
|
|
|
|
2016-09-17 19:38:01 -05:00
|
|
|
/// The native rate of this sink. The sink expects to be fed samples that respect this. (Units:
|
|
|
|
/// samples/sec)
|
2016-04-27 04:57:29 -05:00
|
|
|
virtual unsigned int GetNativeSampleRate() const = 0;
|
2016-02-21 07:13:52 -06:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Feed stereo samples to sink.
|
2016-08-31 10:55:10 -05:00
|
|
|
* @param samples Samples in interleaved stereo PCM16 format.
|
|
|
|
* @param sample_count Number of samples.
|
2016-02-21 07:13:52 -06:00
|
|
|
*/
|
2016-08-31 10:55:10 -05:00
|
|
|
virtual void EnqueueSamples(const s16* samples, size_t sample_count) = 0;
|
2016-02-21 07:13:52 -06:00
|
|
|
|
|
|
|
/// Samples enqueued that have not been played yet.
|
|
|
|
virtual std::size_t SamplesInQueue() const = 0;
|
2017-01-25 21:33:26 -06:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Sets the desired output device.
|
2017-02-26 19:58:51 -06:00
|
|
|
* @param device_id ID of the desired device.
|
2017-01-25 21:33:26 -06:00
|
|
|
*/
|
|
|
|
virtual void SetDevice(int device_id) = 0;
|
|
|
|
|
|
|
|
/// Returns the list of available devices.
|
|
|
|
virtual std::vector<std::string> GetDeviceList() const = 0;
|
2016-02-21 07:13:52 -06:00
|
|
|
};
|
|
|
|
|
2018-03-09 11:54:43 -06:00
|
|
|
} // namespace AudioCore
|