OLD | NEW |
---|---|
(Empty) | |
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_PRODUCER_H_ | |
6 #define REMOTING_CLIENT_FRAME_PRODUCER_H_ | |
7 | |
8 #include "base/callback_forward.h" | |
9 #include "third_party/skia/include/core/SkRect.h" | |
10 #include "third_party/skia/include/core/SkRegion.h" | |
11 #include "third_party/skia/include/core/SkSize.h" | |
12 | |
13 namespace pp { | |
14 class ImageData; | |
15 } // namespace pp | |
16 | |
17 namespace remoting { | |
18 | |
19 class FrameProducer { | |
20 public: | |
21 FrameProducer() {} | |
22 virtual ~FrameProducer() {} | |
23 | |
24 // This routine drains the queue returning all pending buffers to | |
25 // the consumer. | |
Wez
2012/02/17 23:42:17
nit: "Request that all pending buffers be returned
alexeypa (please no reviews)
2012/02/21 23:00:44
Done.
| |
26 virtual void DrainQueue(const base::Closure& done) = 0; | |
27 | |
28 // This routine submits an image buffer for subsequent drawing. Once any part | |
29 // of the frame within the clipping area is invalidated, the producer copies | |
30 // the updated pixels to one of the pending buffers and return it to | |
31 // the consumer via the FrameConsumer::PaintBuffer() call. | |
32 // | |
33 // The passed buffer must be large enough to hold the whole clipping area. | |
Wez
2012/02/17 23:42:17
I think this method needs a better name, and descr
alexeypa (please no reviews)
2012/02/21 23:00:44
AddBuffer() because no user method calls these buf
Wez
2012/02/23 00:11:09
Wouldn't DrawBuffer be more appropriate, then, sin
alexeypa (please no reviews)
2012/02/23 17:10:33
FrameProducer::AddBuffer -> FrameProducer::DrawBuf
| |
34 virtual void EnqueueBuffer(pp::ImageData* buffer) = 0; | |
35 | |
36 // The frame consumer can call this routine requesting the frame to be | |
37 // repainted. The specified region of the frame is will be invalided. | |
38 // The region is given in client's coordinates relative to the beginning of | |
39 // the frame. | |
Wez
2012/02/17 23:42:17
nit: Comment style, e.g:
"Requests that the speci
alexeypa (please no reviews)
2012/02/21 23:00:44
Done.
| |
40 virtual void Invalidate(const SkRegion& region) = 0; | |
Wez
2012/02/17 23:42:17
Consider calling this RequestRegion() or Invalidat
alexeypa (please no reviews)
2012/02/21 23:00:44
Done.
| |
41 | |
42 // The frame consumer calls this function to notify the producer about view | |
43 // area changes. This can result in producer immediately returning some of or | |
44 // all enqueued buffers to the consumer for reuse or reallocation. | |
Wez
2012/02/17 23:42:17
nit: Comment style, e.g:
"Notifies the producer o
alexeypa (please no reviews)
2012/02/21 23:00:44
Done.
| |
45 virtual void SetView(const SkISize& view_size, const SkIRect& clip_area) = 0; | |
Wez
2012/02/17 23:42:17
"View" is a Pepper term; in abstract terms this se
alexeypa (please no reviews)
2012/02/21 23:00:44
It should be SetScalingFactorAndClipArea() then. I
Wez
2012/02/23 00:11:09
The API doesn't take a scaling factor, it takes an
alexeypa (please no reviews)
2012/02/23 17:10:33
Done.
| |
46 | |
47 private: | |
48 DISALLOW_COPY_AND_ASSIGN(FrameProducer); | |
49 }; | |
50 | |
51 } // namespace remoting | |
52 | |
53 #endif // REMOTING_CLIENT_FRAME_PRODUCER_H_ | |
OLD | NEW |