1 // Copyright (c) 2012 The Chromium Authors. All rights reserved. 2 // Use of this source code is governed by a BSD-style license that can be 3 // found in the LICENSE file. 4 5 #ifndef REMOTING_CLIENT_FRAME_CONSUMER_H_ 6 #define REMOTING_CLIENT_FRAME_CONSUMER_H_ 7 8 #include "base/basictypes.h" 9 10 namespace webrtc { 11 class DesktopFrame; 12 class DesktopRect; 13 class DesktopRegion; 14 class DesktopSize; 15 class DesktopVector; 16 } // namespace webrtc 17 18 namespace remoting { 19 20 class FrameConsumer { 21 public: 22 23 // List of supported pixel formats needed by various platforms. 24 enum PixelFormat { 25 FORMAT_BGRA, // Used by the Pepper plugin. 26 FORMAT_RGBA, // Used for Android's Bitmap class. 27 }; 28 29 // Accepts a buffer to be painted to the screen. The buffer's dimensions and 30 // relative position within the frame are specified by |clip_area|. Only 31 // pixels falling within |region| and the current clipping area are painted. 32 // The function assumes that the passed buffer was scaled to fit a window 33 // having |view_size| dimensions. 34 // 35 // N.B. Both |clip_area| and |region| are in output coordinates relative to 36 // the frame. 37 virtual void ApplyBuffer(const webrtc::DesktopSize& view_size, 38 const webrtc::DesktopRect& clip_area, 39 webrtc::DesktopFrame* buffer, 40 const webrtc::DesktopRegion& region) = 0; 41 42 // Accepts a buffer that couldn't be used for drawing for any reason (shutdown 43 // is in progress, the view area has changed, etc.). The accepted buffer can 44 // be freed or reused for another drawing operation. 45 virtual void ReturnBuffer(webrtc::DesktopFrame* buffer) = 0; 46 47 // Set the dimension of the entire host screen. 48 virtual void SetSourceSize(const webrtc::DesktopSize& source_size, 49 const webrtc::DesktopVector& dpi) = 0; 50 51 // Returns the preferred pixel encoding for the platform. 52 virtual PixelFormat GetPixelFormat() = 0; 53 54 protected: 55 FrameConsumer() {} 56 virtual ~FrameConsumer() {} 57 58 private: 59 DISALLOW_COPY_AND_ASSIGN(FrameConsumer); 60 }; 61 62 } // namespace remoting 63 64 #endif // REMOTING_CLIENT_FRAME_CONSUMER_H_ 65