// Copyright (c) 2012 The Chromium Authors. All rights reserved. // Use of this source code is governed by a BSD-style license that can be // found in the LICENSE file. #ifndef REMOTING_CLIENT_FRAME_CONSUMER_H_ #define REMOTING_CLIENT_FRAME_CONSUMER_H_ #include "base/basictypes.h" namespace webrtc { class DesktopFrame; class DesktopRect; class DesktopRegion; class DesktopSize; class DesktopVector; } // namespace webrtc namespace remoting { class FrameConsumer { public: // List of supported pixel formats needed by various platforms. enum PixelFormat { FORMAT_BGRA, // Used by the Pepper plugin. FORMAT_RGBA, // Used for Android's Bitmap class. }; // Accepts a buffer to be painted to the screen. The buffer's dimensions and // relative position within the frame are specified by |clip_area|. Only // pixels falling within |region| and the current clipping area are painted. // The function assumes that the passed buffer was scaled to fit a window // having |view_size| dimensions. // // N.B. Both |clip_area| and |region| are in output coordinates relative to // the frame. virtual void ApplyBuffer(const webrtc::DesktopSize& view_size, const webrtc::DesktopRect& clip_area, webrtc::DesktopFrame* buffer, const webrtc::DesktopRegion& region) = 0; // Accepts a buffer that couldn't be used for drawing for any reason (shutdown // is in progress, the view area has changed, etc.). The accepted buffer can // be freed or reused for another drawing operation. virtual void ReturnBuffer(webrtc::DesktopFrame* buffer) = 0; // Set the dimension of the entire host screen. virtual void SetSourceSize(const webrtc::DesktopSize& source_size, const webrtc::DesktopVector& dpi) = 0; // Returns the preferred pixel encoding for the platform. virtual PixelFormat GetPixelFormat() = 0; protected: FrameConsumer() {} virtual ~FrameConsumer() {} private: DISALLOW_COPY_AND_ASSIGN(FrameConsumer); }; } // namespace remoting #endif // REMOTING_CLIENT_FRAME_CONSUMER_H_