| /* |
| * Copyright (c) 2012 The WebRTC project authors. All Rights Reserved. |
| * |
| * Use of this source code is governed by a BSD-style license |
| * that can be found in the LICENSE file in the root of the source |
| * tree. An additional intellectual property rights grant can be found |
| * in the file PATENTS. All contributing project authors may |
| * be found in the AUTHORS file in the root of the source tree. |
| */ |
| |
| // This sub-API supports the following functionalities: |
| // - File recording and playing. |
| // - Snapshots. |
| // - Background images. |
| |
| #ifndef WEBRTC_VIDEO_ENGINE_INCLUDE_VIE_FILE_H_ |
| #define WEBRTC_VIDEO_ENGINE_INCLUDE_VIE_FILE_H_ |
| |
| #include "common_types.h" |
| |
| namespace webrtc { |
| |
| class VideoEngine; |
| struct VideoCodec; |
| |
| // This structure contains picture data and describes the picture type. |
| struct ViEPicture { |
| unsigned char* data; |
| unsigned int size; |
| unsigned int width; |
| unsigned int height; |
| RawVideoType type; |
| |
| ViEPicture() { |
| data = NULL; |
| size = 0; |
| width = 0; |
| height = 0; |
| type = kVideoI420; |
| } |
| |
| // Call FreePicture to free data. |
| ~ViEPicture() { |
| data = NULL; |
| size = 0; |
| width = 0; |
| height = 0; |
| type = kVideoUnknown; |
| } |
| }; |
| |
| // This enumerator tells which audio source to use for media files. |
| enum AudioSource { |
| NO_AUDIO, |
| MICROPHONE, |
| PLAYOUT, |
| VOICECALL |
| }; |
| |
| // This class declares an abstract interface for a user defined observer. It is |
| // up to the VideoEngine user to implement a derived class which implements the |
| // observer class. The observer is registered using RegisterObserver() and |
| // deregistered using DeregisterObserver(). |
| class WEBRTC_DLLEXPORT ViEFileObserver { |
| public: |
| // This method is called when the end is reached of a played file. |
| virtual void PlayFileEnded(const WebRtc_Word32 file_id) = 0; |
| |
| protected: |
| virtual ~ViEFileObserver() {} |
| }; |
| |
| class WEBRTC_DLLEXPORT ViEFile { |
| public: |
| // Factory for the ViEFile subāAPI and increases an internal reference |
| // counter if successful. Returns NULL if the API is not supported or if |
| // construction fails. |
| static ViEFile* GetInterface(VideoEngine* video_engine); |
| |
| // Releases the ViEFile sub-API and decreases an internal reference counter. |
| // Returns the new reference count. This value should be zero |
| // for all sub-API:s before the VideoEngine object can be safely deleted. |
| virtual int Release() = 0; |
| |
| // Starts playing a video file. |
| virtual int StartPlayFile( |
| const char* file_name_utf8, |
| int& file_id, |
| const bool loop = false, |
| const FileFormats file_format = kFileFormatAviFile) = 0; |
| |
| // Stops a file from being played. |
| virtual int StopPlayFile(const int file_id) = 0; |
| |
| // Registers an instance of a user implementation of the ViEFileObserver. |
| virtual int RegisterObserver(int file_id, ViEFileObserver& observer) = 0; |
| |
| // Removes an already registered instance of ViEFileObserver. |
| virtual int DeregisterObserver(int file_id, ViEFileObserver& observer) = 0; |
| |
| // This function tells which channel, if any, the file should be sent on. |
| virtual int SendFileOnChannel(const int file_id, const int video_channel) = 0; |
| |
| // Stops a file from being sent on a a channel. |
| virtual int StopSendFileOnChannel(const int video_channel) = 0; |
| |
| // Starts playing the file audio as microphone input for the specified voice |
| // channel. |
| virtual int StartPlayFileAsMicrophone(const int file_id, |
| const int audio_channel, |
| bool mix_microphone = false, |
| float volume_scaling = 1) = 0; |
| |
| // The function stop the audio from being played on a VoiceEngine channel. |
| virtual int StopPlayFileAsMicrophone(const int file_id, |
| const int audio_channel) = 0; |
| |
| // The function plays and mixes the file audio with the local speaker signal |
| // for playout. |
| virtual int StartPlayAudioLocally(const int file_id, const int audio_channel, |
| float volume_scaling = 1) = 0; |
| |
| // Stops the audio from a file from being played locally. |
| virtual int StopPlayAudioLocally(const int file_id, |
| const int audio_channel) = 0; |
| |
| // This function starts recording the video transmitted to another endpoint. |
| virtual int StartRecordOutgoingVideo( |
| const int video_channel, |
| const char* file_name_utf8, |
| AudioSource audio_source, |
| const CodecInst& audio_codec, |
| const VideoCodec& video_codec, |
| const FileFormats file_format = kFileFormatAviFile) = 0; |
| |
| // This function starts recording the incoming video stream on a channel. |
| virtual int StartRecordIncomingVideo( |
| const int video_channel, |
| const char* file_name_utf8, |
| AudioSource audio_source, |
| const CodecInst& audio_codec, |
| const VideoCodec& video_codec, |
| const FileFormats file_format = kFileFormatAviFile) = 0; |
| |
| // Stops the file recording of the outgoing stream. |
| virtual int StopRecordOutgoingVideo(const int video_channel) = 0; |
| |
| // Stops the file recording of the incoming stream. |
| virtual int StopRecordIncomingVideo(const int video_channel) = 0; |
| |
| // Gets the audio codec, video codec and file format of a recorded file. |
| virtual int GetFileInformation( |
| const char* file_name, |
| VideoCodec& video_codec, |
| CodecInst& audio_codec, |
| const FileFormats file_format = kFileFormatAviFile) = 0; |
| |
| // The function takes a snapshot of the last rendered image for a video |
| // channel. |
| virtual int GetRenderSnapshot(const int video_channel, |
| const char* file_name_utf8) = 0; |
| |
| // The function takes a snapshot of the last rendered image for a video |
| // channel |
| virtual int GetRenderSnapshot(const int video_channel, |
| ViEPicture& picture) = 0; |
| |
| // The function takes a snapshot of the last captured image by a specified |
| // capture device. |
| virtual int GetCaptureDeviceSnapshot(const int capture_id, |
| const char* file_name_utf8) = 0; |
| |
| // The function takes a snapshot of the last captured image by a specified |
| // capture device. |
| virtual int GetCaptureDeviceSnapshot(const int capture_id, |
| ViEPicture& picture) = 0; |
| |
| virtual int FreePicture(ViEPicture& picture) = 0; |
| |
| // This function sets a jpg image to render before the first received video |
| // frame is decoded for a specified channel. |
| virtual int SetRenderStartImage(const int video_channel, |
| const char* file_name_utf8) = 0; |
| |
| // This function sets an image to render before the first received video |
| // frame is decoded for a specified channel. |
| virtual int SetRenderStartImage(const int video_channel, |
| const ViEPicture& picture) = 0; |
| |
| // This function sets a jpg image to render if no frame is decoded for a |
| // specified time interval. |
| virtual int SetRenderTimeoutImage(const int video_channel, |
| const char* file_name_utf8, |
| const unsigned int timeout_ms = 1000) = 0; |
| |
| // This function sets an image to render if no frame is decoded for a |
| // specified time interval. |
| virtual int SetRenderTimeoutImage(const int video_channel, |
| const ViEPicture& picture, |
| const unsigned int timeout_ms) = 0; |
| |
| // Enables recording of debugging information. |
| virtual int StartDebugRecording(int video_channel, |
| const char* file_name_utf8) = 0; |
| // Disables recording of debugging information. |
| virtual int StopDebugRecording(int video_channel) = 0; |
| |
| |
| protected: |
| ViEFile() {} |
| virtual ~ViEFile() {} |
| }; |
| |
| } // namespace webrtc |
| |
| #endif // WEBRTC_VIDEO_ENGINE_INCLUDE_VIE_FILE_H_ |