// 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_PRODUCER_H_ #define REMOTING_CLIENT_FRAME_PRODUCER_H_ #include "base/callback_forward.h" namespace webrtc { class DesktopFrame; class DesktopRect; class DesktopRegion; class DesktopSize; } // namespace webrtc namespace remoting { class FrameProducer { public: FrameProducer() {} // Adds an image buffer to the pool of pending buffers for subsequent drawing. // Once drawing is completed the buffer will be returned to the consumer via // the FrameConsumer::ApplyBuffer() call. Alternatively an empty buffer could // be returned via the FrameConsumer::ReturnBuffer() call. // // The passed buffer must be large enough to hold the whole clipping area. virtual void DrawBuffer(webrtc::DesktopFrame* buffer) = 0; // Requests repainting of the specified |region| of the frame as soon as // possible. |region| is specified in output coordinates relative to // the beginning of the frame. virtual void InvalidateRegion(const webrtc::DesktopRegion& region) = 0; // Requests returing of all pending buffers to the consumer via // FrameConsumer::ReturnBuffer() calls. virtual void RequestReturnBuffers(const base::Closure& done) = 0; // Notifies the producer of changes to the output view size or clipping area. // Implementations must cope with empty |view_size| or |clip_area|. virtual void SetOutputSizeAndClip(const webrtc::DesktopSize& view_size, const webrtc::DesktopRect& clip_area) = 0; // Returns a reference to the shape of the most recently drawn buffer. virtual const webrtc::DesktopRegion* GetBufferShape() = 0; protected: virtual ~FrameProducer() {} private: DISALLOW_COPY_AND_ASSIGN(FrameProducer); }; } // namespace remoting #endif // REMOTING_CLIENT_FRAME_PRODUCER_H_