| /* | 
 |  *  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. | 
 |  */ | 
 |  | 
 | #ifndef WEBRTC_TEST_TESTSUPPORT_FRAME_WRITER_H_ | 
 | #define WEBRTC_TEST_TESTSUPPORT_FRAME_WRITER_H_ | 
 |  | 
 | #include <stdio.h> | 
 |  | 
 | #include <string> | 
 |  | 
 | #include "webrtc/api/video/video_frame.h" | 
 | #include "webrtc/typedefs.h" | 
 |  | 
 | namespace webrtc { | 
 | namespace test { | 
 |  | 
 | // Handles writing of video files. | 
 | class FrameWriter { | 
 |  public: | 
 |   virtual ~FrameWriter() {} | 
 |  | 
 |   // Initializes the file handler, i.e. opens the input and output files etc. | 
 |   // This must be called before reading or writing frames has started. | 
 |   // Returns false if an error has occurred, in addition to printing to stderr. | 
 |   virtual bool Init() = 0; | 
 |  | 
 |   // Writes a frame of the configured frame length to the output file. | 
 |   // Returns true if the write was successful, false otherwise. | 
 |   virtual bool WriteFrame(uint8_t* frame_buffer) = 0; | 
 |  | 
 |   // Closes the output file if open. Essentially makes this class impossible | 
 |   // to use anymore. Will also be invoked by the destructor. | 
 |   virtual void Close() = 0; | 
 |  | 
 |   // Frame length in bytes of a single frame image. | 
 |   virtual size_t FrameLength() = 0; | 
 | }; | 
 |  | 
 | // Writes raw I420 frames in sequence. | 
 | class YuvFrameWriterImpl : public FrameWriter { | 
 |  public: | 
 |   // Creates a file handler. The input file is assumed to exist and be readable | 
 |   // and the output file must be writable. | 
 |   // Parameters: | 
 |   //   output_filename         The file to write. Will be overwritten if already | 
 |   //                           existing. | 
 |   //   width, height           Size of each frame to read. | 
 |   YuvFrameWriterImpl(std::string output_filename, int width, int height); | 
 |   ~YuvFrameWriterImpl() override; | 
 |   bool Init() override; | 
 |   bool WriteFrame(uint8_t* frame_buffer) override; | 
 |   void Close() override; | 
 |   size_t FrameLength() override; | 
 |  | 
 |  protected: | 
 |   const std::string output_filename_; | 
 |   size_t frame_length_in_bytes_; | 
 |   const int width_; | 
 |   const int height_; | 
 |   FILE* output_file_; | 
 | }; | 
 |  | 
 | // Writes raw I420 frames in sequence, but with Y4M file and frame headers for | 
 | // more convenient playback in external media players. | 
 | class Y4mFrameWriterImpl : public YuvFrameWriterImpl { | 
 |  public: | 
 |   Y4mFrameWriterImpl(std::string output_filename, | 
 |                      int width, | 
 |                      int height, | 
 |                      int frame_rate); | 
 |   ~Y4mFrameWriterImpl() override; | 
 |   bool Init() override; | 
 |   bool WriteFrame(uint8_t* frame_buffer) override; | 
 |  | 
 |  private: | 
 |   const int frame_rate_; | 
 | }; | 
 |  | 
 | // LibJpeg is not available on iOS. This class will do nothing on iOS. | 
 | class JpegFrameWriter { | 
 |  public: | 
 |   JpegFrameWriter(const std::string &output_filename); | 
 |   // Quality can be from 0 (worst) to 100 (best). Best quality is still lossy. | 
 |   // WriteFrame can be called only once. Subsequent calls will fail. | 
 |   bool WriteFrame(const VideoFrame& input_frame, int quality); | 
 |  | 
 | #if !defined(WEBRTC_IOS) | 
 |  private: | 
 |   bool frame_written_; | 
 |   const std::string output_filename_; | 
 |   FILE* output_file_; | 
 | #endif | 
 | }; | 
 |  | 
 | }  // namespace test | 
 | }  // namespace webrtc | 
 |  | 
 | #endif  // WEBRTC_TEST_TESTSUPPORT_FRAME_WRITER_H_ |