| OLD | NEW |
| (Empty) |
| 1 /* | |
| 2 * Copyright (c) 2011 The WebRTC project authors. All Rights Reserved. | |
| 3 * | |
| 4 * Use of this source code is governed by a BSD-style license | |
| 5 * that can be found in the LICENSE file in the root of the source | |
| 6 * tree. An additional intellectual property rights grant can be found | |
| 7 * in the file PATENTS. All contributing project authors may | |
| 8 * be found in the AUTHORS file in the root of the source tree. | |
| 9 */ | |
| 10 | |
| 11 // This sub-API supports the following functionalities: | |
| 12 // | |
| 13 // - File playback. | |
| 14 // - File recording. | |
| 15 // - File conversion. | |
| 16 // | |
| 17 // Usage example, omitting error checking: | |
| 18 // | |
| 19 // using namespace webrtc; | |
| 20 // VoiceEngine* voe = VoiceEngine::Create(); | |
| 21 // VoEBase* base = VoEBase::GetInterface(voe); | |
| 22 // VoEFile* file = VoEFile::GetInterface(voe); | |
| 23 // base->Init(); | |
| 24 // int ch = base->CreateChannel(); | |
| 25 // ... | |
| 26 // base->StartPlayout(ch); | |
| 27 // file->StartPlayingFileAsMicrophone(ch, "data_file_16kHz.pcm", true); | |
| 28 // ... | |
| 29 // file->StopPlayingFileAsMicrophone(ch); | |
| 30 // base->StopPlayout(ch); | |
| 31 // ... | |
| 32 // base->DeleteChannel(ch); | |
| 33 // base->Terminate(); | |
| 34 // base->Release(); | |
| 35 // file->Release(); | |
| 36 // VoiceEngine::Delete(voe); | |
| 37 // | |
| 38 #ifndef VOICE_ENGINE_VOE_FILE_H_ | |
| 39 #define VOICE_ENGINE_VOE_FILE_H_ | |
| 40 | |
| 41 #include "common_types.h" // NOLINT(build/include) | |
| 42 | |
| 43 namespace webrtc { | |
| 44 | |
| 45 class VoiceEngine; | |
| 46 | |
| 47 class WEBRTC_DLLEXPORT VoEFile { | |
| 48 public: | |
| 49 // Factory for the VoEFile sub-API. Increases an internal | |
| 50 // reference counter if successful. Returns NULL if the API is not | |
| 51 // supported or if construction fails. | |
| 52 static VoEFile* GetInterface(VoiceEngine* voiceEngine); | |
| 53 | |
| 54 // Releases the VoEFile sub-API and decreases an internal | |
| 55 // reference counter. Returns the new reference count. This value should | |
| 56 // be zero for all sub-API:s before the VoiceEngine object can be safely | |
| 57 // deleted. | |
| 58 virtual int Release() = 0; | |
| 59 | |
| 60 // Starts playing and mixing files with the local speaker signal for | |
| 61 // playout. | |
| 62 virtual int StartPlayingFileLocally( | |
| 63 int channel, | |
| 64 const char fileNameUTF8[1024], | |
| 65 bool loop = false, | |
| 66 FileFormats format = kFileFormatPcm16kHzFile, | |
| 67 float volumeScaling = 1.0, | |
| 68 int startPointMs = 0, | |
| 69 int stopPointMs = 0) = 0; | |
| 70 | |
| 71 // Starts playing and mixing streams with the local speaker signal for | |
| 72 // playout. | |
| 73 virtual int StartPlayingFileLocally( | |
| 74 int channel, | |
| 75 InStream* stream, | |
| 76 FileFormats format = kFileFormatPcm16kHzFile, | |
| 77 float volumeScaling = 1.0, | |
| 78 int startPointMs = 0, | |
| 79 int stopPointMs = 0) = 0; | |
| 80 | |
| 81 // Stops playback of a file on a specific |channel|. | |
| 82 virtual int StopPlayingFileLocally(int channel) = 0; | |
| 83 | |
| 84 // Returns the current file playing state for a specific |channel|. | |
| 85 virtual int IsPlayingFileLocally(int channel) = 0; | |
| 86 | |
| 87 // Starts reading data from a file and transmits the data either | |
| 88 // mixed with or instead of the microphone signal. | |
| 89 virtual int StartPlayingFileAsMicrophone( | |
| 90 int channel, | |
| 91 const char fileNameUTF8[1024], | |
| 92 bool loop = false, | |
| 93 bool mixWithMicrophone = false, | |
| 94 FileFormats format = kFileFormatPcm16kHzFile, | |
| 95 float volumeScaling = 1.0) = 0; | |
| 96 | |
| 97 // Starts reading data from a stream and transmits the data either | |
| 98 // mixed with or instead of the microphone signal. | |
| 99 virtual int StartPlayingFileAsMicrophone( | |
| 100 int channel, | |
| 101 InStream* stream, | |
| 102 bool mixWithMicrophone = false, | |
| 103 FileFormats format = kFileFormatPcm16kHzFile, | |
| 104 float volumeScaling = 1.0) = 0; | |
| 105 | |
| 106 // Stops playing of a file as microphone signal for a specific |channel|. | |
| 107 virtual int StopPlayingFileAsMicrophone(int channel) = 0; | |
| 108 | |
| 109 // Returns whether the |channel| is currently playing a file as microphone. | |
| 110 virtual int IsPlayingFileAsMicrophone(int channel) = 0; | |
| 111 | |
| 112 // Starts recording the mixed playout audio. | |
| 113 virtual int StartRecordingPlayout(int channel, | |
| 114 const char* fileNameUTF8, | |
| 115 CodecInst* compression = NULL, | |
| 116 int maxSizeBytes = -1) = 0; | |
| 117 | |
| 118 // Stops recording the mixed playout audio. | |
| 119 virtual int StopRecordingPlayout(int channel) = 0; | |
| 120 | |
| 121 virtual int StartRecordingPlayout(int channel, | |
| 122 OutStream* stream, | |
| 123 CodecInst* compression = NULL) = 0; | |
| 124 | |
| 125 // Starts recording the microphone signal to a file. | |
| 126 virtual int StartRecordingMicrophone(const char* fileNameUTF8, | |
| 127 CodecInst* compression = NULL, | |
| 128 int maxSizeBytes = -1) = 0; | |
| 129 | |
| 130 // Starts recording the microphone signal to a stream. | |
| 131 virtual int StartRecordingMicrophone(OutStream* stream, | |
| 132 CodecInst* compression = NULL) = 0; | |
| 133 | |
| 134 // Stops recording the microphone signal. | |
| 135 virtual int StopRecordingMicrophone() = 0; | |
| 136 | |
| 137 protected: | |
| 138 VoEFile() {} | |
| 139 virtual ~VoEFile() {} | |
| 140 }; | |
| 141 | |
| 142 } // namespace webrtc | |
| 143 | |
| 144 #endif // VOICE_ENGINE_VOE_FILE_H_ | |
| OLD | NEW |