mirror of
https://gitlab.winehq.org/wine/wine-gecko.git
synced 2024-09-13 09:24:08 -07:00
27cb259315
In Gecko (and everywhere else, but sometimes not in the WebRTC code), a "frame" or "sample-frames" is the set of all sample that will play at the same time on all channels, whereas a "sample" is a single value on a specific channel.
56 lines
1.4 KiB
C++
56 lines
1.4 KiB
C++
/* This Source Code Form is subject to the terms of the Mozilla Public
|
|
* License, v. 2.0. If a copy of the MPL was not distributed with this file,
|
|
* You can obtain one at http://mozilla.org/MPL/2.0/. */
|
|
|
|
#ifndef AUDIOOUTPUTOBSERVER_H_
|
|
#define AUDIOOUTPUTOBSERVER_H_
|
|
|
|
#include "mozilla/StaticPtr.h"
|
|
|
|
namespace webrtc {
|
|
class SingleRwFifo;
|
|
}
|
|
|
|
namespace mozilla {
|
|
|
|
typedef struct FarEndAudioChunk_ {
|
|
uint16_t mSamples;
|
|
bool mOverrun;
|
|
int16_t mData[1]; // variable-length
|
|
} FarEndAudioChunk;
|
|
|
|
// XXX Really a singleton currently
|
|
class AudioOutputObserver // : public MSGOutputObserver
|
|
{
|
|
public:
|
|
AudioOutputObserver();
|
|
virtual ~AudioOutputObserver();
|
|
|
|
void Clear();
|
|
void InsertFarEnd(const AudioDataValue *aBuffer, uint32_t aFrames, bool aOverran,
|
|
int aFreq, int aChannels, AudioSampleFormat aFormat);
|
|
uint32_t PlayoutFrequency() { return mPlayoutFreq; }
|
|
uint32_t PlayoutChannels() { return mPlayoutChannels; }
|
|
|
|
FarEndAudioChunk *Pop();
|
|
uint32_t Size();
|
|
|
|
private:
|
|
uint32_t mPlayoutFreq;
|
|
uint32_t mPlayoutChannels;
|
|
|
|
nsAutoPtr<webrtc::SingleRwFifo> mPlayoutFifo;
|
|
uint32_t mChunkSize;
|
|
|
|
// chunking to 10ms support
|
|
FarEndAudioChunk *mSaved; // can't be nsAutoPtr since we need to use moz_free()
|
|
uint32_t mSamplesSaved;
|
|
};
|
|
|
|
// XXX until there's a registration API in MSG
|
|
extern StaticAutoPtr<AudioOutputObserver> gFarendObserver;
|
|
|
|
}
|
|
|
|
#endif
|