Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(998)

Side by Side Diff: remoting/client/frame_consumer.h

Issue 18233015: Abstract PPAPI's ImageData behind webrtc::DesktopFrame interface (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: Implement Wez's final corrections Created 7 years, 5 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View unified diff | Download patch
« no previous file with comments | « remoting/client/DEPS ('k') | remoting/client/frame_consumer_proxy.h » ('j') | no next file with comments »
Toggle Intra-line Diffs ('i') | Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
OLDNEW
1 // Copyright (c) 2012 The Chromium Authors. All rights reserved. 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 2 // Use of this source code is governed by a BSD-style license that can be
3 // found in the LICENSE file. 3 // found in the LICENSE file.
4 4
5 #ifndef REMOTING_CLIENT_FRAME_CONSUMER_H_ 5 #ifndef REMOTING_CLIENT_FRAME_CONSUMER_H_
6 #define REMOTING_CLIENT_FRAME_CONSUMER_H_ 6 #define REMOTING_CLIENT_FRAME_CONSUMER_H_
7 7
8 #include "third_party/skia/include/core/SkRect.h" 8 #include "third_party/skia/include/core/SkRect.h"
9 #include "third_party/skia/include/core/SkRegion.h" 9 #include "third_party/skia/include/core/SkRegion.h"
10 #include "third_party/skia/include/core/SkSize.h" 10 #include "third_party/skia/include/core/SkSize.h"
11 11
12 namespace pp { 12 namespace webrtc {
13 class ImageData; 13 class DesktopFrame;
14 } // namespace pp 14 } // namespace webrtc
15 15
16 namespace remoting { 16 namespace remoting {
17 17
18 class FrameConsumer { 18 class FrameConsumer {
19 public: 19 public:
20 // Accepts a buffer to be painted to the screen. The buffer's dimensions and 20 // Accepts a buffer to be painted to the screen. The buffer's dimensions and
21 // relative position within the frame are specified by |clip_area|. Only 21 // relative position within the frame are specified by |clip_area|. Only
22 // pixels falling within |region| and the current clipping area are painted. 22 // pixels falling within |region| and the current clipping area are painted.
23 // The function assumes that the passed buffer was scaled to fit a window 23 // The function assumes that the passed buffer was scaled to fit a window
24 // having |view_size| dimensions. 24 // having |view_size| dimensions.
25 // 25 //
26 // N.B. Both |clip_area| and |region| are in output coordinates relative to 26 // N.B. Both |clip_area| and |region| are in output coordinates relative to
27 // the frame. 27 // the frame.
28 virtual void ApplyBuffer(const SkISize& view_size, 28 virtual void ApplyBuffer(const SkISize& view_size,
29 const SkIRect& clip_area, 29 const SkIRect& clip_area,
30 pp::ImageData* buffer, 30 webrtc::DesktopFrame* buffer,
31 const SkRegion& region) = 0; 31 const SkRegion& region) = 0;
32 32
33 // Accepts a buffer that couldn't be used for drawing for any reason (shutdown 33 // Accepts a buffer that couldn't be used for drawing for any reason (shutdown
34 // is in progress, the view area has changed, etc.). The accepted buffer can 34 // is in progress, the view area has changed, etc.). The accepted buffer can
35 // be freed or reused for another drawing operation. 35 // be freed or reused for another drawing operation.
36 virtual void ReturnBuffer(pp::ImageData* buffer) = 0; 36 virtual void ReturnBuffer(webrtc::DesktopFrame* buffer) = 0;
37 37
38 // Set the dimension of the entire host screen. 38 // Set the dimension of the entire host screen.
39 virtual void SetSourceSize(const SkISize& source_size, 39 virtual void SetSourceSize(const SkISize& source_size,
40 const SkIPoint& dpi) = 0; 40 const SkIPoint& dpi) = 0;
41 41
42 protected: 42 protected:
43 FrameConsumer() {} 43 FrameConsumer() {}
44 virtual ~FrameConsumer() {} 44 virtual ~FrameConsumer() {}
45 45
46 private: 46 private:
47 DISALLOW_COPY_AND_ASSIGN(FrameConsumer); 47 DISALLOW_COPY_AND_ASSIGN(FrameConsumer);
48 }; 48 };
49 49
50 } // namespace remoting 50 } // namespace remoting
51 51
52 #endif // REMOTING_CLIENT_FRAME_CONSUMER_H_ 52 #endif // REMOTING_CLIENT_FRAME_CONSUMER_H_
OLDNEW
« no previous file with comments | « remoting/client/DEPS ('k') | remoting/client/frame_consumer_proxy.h » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698