Document PortAudio player, this is broken in doxygen at the moment not sure why..

Originally committed to SVN as r3323.
This commit is contained in:
Amar Takhar 2009-07-30 02:51:42 +00:00
parent 612e007be6
commit cd8bb7c241
2 changed files with 54 additions and 79 deletions

View File

@ -48,17 +48,16 @@
#include "utils.h"
#include "charset_conv.h"
// Uncomment to enable debug features.
/// @define PORTAUDIO_DEBUG Enable debugging?
//#define PORTAUDIO_DEBUG
/// DOCME
/// Reference counter
int PortAudioPlayer::pa_refcount = 0;
/// @brief Constructor
///
PortAudioPlayer::PortAudioPlayer() {
// Initialize portaudio
if (!pa_refcount) {
@ -83,7 +82,6 @@ PortAudioPlayer::PortAudioPlayer() {
/// @brief Destructor
///
PortAudioPlayer::~PortAudioPlayer() {
// Deinit portaudio
if (!--pa_refcount) Pa_Terminate();
@ -92,7 +90,6 @@ PortAudioPlayer::~PortAudioPlayer() {
/// @brief Open stream
///
void PortAudioPlayer::OpenStream() {
// Open stream
PaStreamParameters pa_output_p;
@ -132,7 +129,6 @@ void PortAudioPlayer::OpenStream() {
/// @brief Close stream
///
void PortAudioPlayer::CloseStream() {
try {
Stop(false);
@ -142,8 +138,7 @@ void PortAudioPlayer::CloseStream() {
/// @brief Called when the callback has finished.
/// @param userData
///
/// @param userData Local data to be handed to the callback.
void PortAudioPlayer::paStreamFinishedCallback(void *userData) {
PortAudioPlayer *player = (PortAudioPlayer *) userData;
@ -158,11 +153,9 @@ void PortAudioPlayer::paStreamFinishedCallback(void *userData) {
/// @brief Play
/// @param start
/// @param count
/// @return
///
/// @brief Play audio.
/// @param start Start position.
/// @param count Frame count
void PortAudioPlayer::Play(int64_t start,int64_t count) {
PaError err;
@ -199,8 +192,8 @@ void PortAudioPlayer::Play(int64_t start,int64_t count) {
/// @brief Stop
/// @param timerToo
/// @brief Stop Playback
/// @param timerToo Stop display timer?
///
void PortAudioPlayer::Stop(bool timerToo) {
//wxMutexLocker locker(PAMutex);
@ -219,13 +212,13 @@ void PortAudioPlayer::Stop(bool timerToo) {
/// @brief PortAudio callback
/// @param inputBuffer
/// @param outputBuffer
/// @param framesPerBuffer
/// @param timeInfo
/// @param statusFlags
/// @param userData
/// @return
/// @param inputBuffer Input buffer.
/// @param outputBuffer Output buffer.
/// @param framesPerBuffer Frames per buffer.
/// @param timeInfo PortAudio time information.
/// @param statusFlags Status flags
/// @param userData Local data to hand callback
/// @return Whether to stop playback.
///
int PortAudioPlayer::paCallback(const void *inputBuffer, void *outputBuffer, unsigned long framesPerBuffer, const PaStreamCallbackTimeInfo* timeInfo, PaStreamCallbackFlags statusFlags, void *userData) {
@ -261,8 +254,7 @@ int PortAudioPlayer::paCallback(const void *inputBuffer, void *outputBuffer, uns
/// @brief Get current stream position.
/// @return
///
/// @return Stream position
int64_t PortAudioPlayer::GetCurrentPosition()
{
@ -285,9 +277,9 @@ int64_t PortAudioPlayer::GetCurrentPosition()
/// @brief @param Setting from config file. Return a list of available output devices.
/// @param favorite
///
/// @brief @param Setting from config file.
/// @param favorite Favorite output device
/// @return List of available output devices.
wxArrayString PortAudioPlayer::GetOutputDevices(wxString favorite) {
wxArrayString list;
int devices = Pa_GetDeviceCount();
@ -307,5 +299,3 @@ wxArrayString PortAudioPlayer::GetOutputDevices(wxString favorite) {
}
#endif // WITH_PORTAUDIO

View File

@ -50,43 +50,41 @@ extern "C" {
/// DOCME
/// @class PortAudioPlayer
/// @brief DOCME
/// @brief PortAudio Player
///
/// DOCME
class PortAudioPlayer : public AudioPlayer {
private:
/// DOCME
static int pa_refcount;
/// DOCME
/// PortAudio Mutex
wxMutex PAMutex;
/// DOCME
/// Is playback being stopped?
volatile bool stopping;
/// DOCME
/// Currently Playing?
bool playing;
/// DOCME
/// Current volume level.
float volume;
/// DOCME
/// Playback position.
volatile int64_t playPos;
/// DOCME
/// Playback start position.
volatile int64_t startPos;
/// DOCME
/// Playback end position.
volatile int64_t endPos;
/// DOCME
/// Audio Stream
void *stream;
/// DOCME
/// PortAudio internal start position.
PaTime paStart;
static int paCallback(
@ -111,68 +109,55 @@ public:
void Play(int64_t start,int64_t count);
void Stop(bool timerToo=true);
/// @brief DOCME
/// @return
///
/// @brief Whether audio is currently being played.
/// @return Status
bool IsPlaying() { return playing; }
/// @brief DOCME
/// @return
///
/// @brief Position audio will be played from.
/// @return Start position.
int64_t GetStartPosition() { return startPos; }
/// @brief DOCME
/// @return
///
/// @brief End position playback will stop at.
/// @return End position.
int64_t GetEndPosition() { return endPos; }
int64_t GetCurrentPosition();
/// @brief DOCME
/// @param pos
///
/// @brief Set end position of playback
/// @param pos End position
void SetEndPosition(int64_t pos) { endPos = pos; }
/// @brief DOCME
/// @param pos
///
/// @brief Set current position of playback.
/// @param pos Current position
void SetCurrentPosition(int64_t pos) { playPos = pos; }
/// @brief DOCME
/// @param vol
/// @return
///
/// @brief Set volume level
/// @param vol Volume
void SetVolume(double vol) { volume = vol; }
/// @brief DOCME
/// @return
///
/// @brief Get current volume level
/// @return Volume level
double GetVolume() { return volume; }
wxArrayString GetOutputDevices(wxString favorite);
/// @brief DOCME
/// @return
/// @brief Get Mutex
/// @return Current Mutex
///
wxMutex *GetMutex() { return &PAMutex; }
};
/// DOCME
/// @class PortAudioPlayerFactory
/// @brief DOCME
///
/// DOCME
/// @brief PortAudio Player Factory
class PortAudioPlayerFactory : public AudioPlayerFactory {
public:
/// @brief DOCME
///
/// @brief Create player
/// @return New PortAudio Player
AudioPlayer *CreatePlayer() { return new PortAudioPlayer(); }
};
#endif //ifdef WITH_PORTAUDIO