// libjingle // Copyright 2014 Google Inc. // // Redistribution and use in source and binary forms, with or without // modification, are permitted provided that the following conditions are met: // // 1. Redistributions of source code must retain the above copyright notice, // this list of conditions and the following disclaimer. // 2. Redistributions in binary form must reproduce the above copyright notice, // this list of conditions and the following disclaimer in the documentation // and/or other materials provided with the distribution. // 3. The name of the author may not be used to endorse or promote products // derived from this software without specific prior written permission. // // THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR IMPLIED // WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF // MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO // EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, // SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, // PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; // OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, // WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR // OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF // ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. // #ifndef TALK_MEDIA_BASE_VIDEOFRAMEFACTORY_H_ #define TALK_MEDIA_BASE_VIDEOFRAMEFACTORY_H_ #include "talk/media/base/videoframe.h" #include "webrtc/base/scoped_ptr.h" namespace cricket { struct CapturedFrame; class VideoFrame; // Creates cricket::VideoFrames, or a subclass of cricket::VideoFrame // depending on the subclass of VideoFrameFactory. class VideoFrameFactory { public: VideoFrameFactory() {} virtual ~VideoFrameFactory() {} // The returned frame aliases the aliased_frame if the input color // space allows for aliasing, otherwise a color conversion will // occur. For safety, |input_frame| must outlive the returned // frame. Returns NULL if conversion fails. // The returned frame will be a center crop of |input_frame| with // size |cropped_width| x |cropped_height|. virtual VideoFrame* CreateAliasedFrame(const CapturedFrame* input_frame, int cropped_width, int cropped_height) const = 0; // The returned frame will be a center crop of |input_frame| with size // |cropped_width| x |cropped_height|, scaled to |output_width| x // |output_height|. If scaling has taken place, i.e. cropped input // resolution != output resolution, the returned frame will remain valid // until this function is called again. virtual VideoFrame* CreateAliasedFrame(const CapturedFrame* input_frame, int cropped_input_width, int cropped_input_height, int output_width, int output_height) const; private: // An internal frame buffer to avoid reallocations. It is mutable because it // does not affect behaviour, only performance. mutable rtc::scoped_ptr<VideoFrame> output_frame_; }; } // namespace cricket #endif // TALK_MEDIA_BASE_VIDEOFRAMEFACTORY_H_