Index: remoting/client/rectangle_update_decoder.h |
diff --git a/remoting/client/rectangle_update_decoder.h b/remoting/client/rectangle_update_decoder.h |
index e2833c25be0e6d15171ac4a99498ce09679cf9bf..64b00b0c2d5acb451da489c7a9dd510920cefc6d 100644 |
--- a/remoting/client/rectangle_update_decoder.h |
+++ b/remoting/client/rectangle_update_decoder.h |
@@ -8,13 +8,16 @@ |
#include "base/callback_forward.h" |
#include "base/memory/ref_counted.h" |
#include "base/memory/scoped_ptr.h" |
-#include "media/base/video_frame.h" |
#include "remoting/base/decoder.h" |
namespace base { |
class MessageLoopProxy; |
} // namespace base |
+namespace pp { |
+class ImageData; |
+}; |
+ |
namespace remoting { |
class FrameConsumer; |
@@ -36,55 +39,43 @@ class RectangleUpdateDecoder : |
// Initializes decoder with the infromation from the protocol config. |
void Initialize(const protocol::SessionConfig& config); |
- // Decodes the contents of |packet| calling OnPartialFrameOutput() in the |
- // regsitered as data is avaialable. DecodePacket may keep a reference to |
+ // Decodes the contents of |packet| calling OnFrameReady() in the |
+ // registered as data is avaialable. DecodePacket may keep a reference to |
Wez
2012/02/07 01:56:31
This class doesn't have an OnFrameReady, though?
alexeypa (please no reviews)
2012/02/15 23:06:22
Done.
|
// |packet| so the |packet| must remain alive and valid until |done| is |
// executed. |
Wez
2012/02/07 01:56:31
nit: If we pass |packet| as a scoped_ptr<> then we
alexeypa (please no reviews)
2012/02/15 23:06:22
I'd postpone this change till later. This change i
|
void DecodePacket(const VideoPacket* packet, const base::Closure& done); |
- // Set the output dimensions to scale video output to. |
- void SetOutputSize(const SkISize& size); |
- |
- // Set a new clipping rectangle for the decoder. Decoder should respect |
- // this clipping rectangle and only decode content in this rectangle and |
- // report dirty rectangles accordingly to enhance performance. |
- void UpdateClipRect(const SkIRect& clip_rect); |
- |
// Force the decoder to output the last decoded video frame without any |
// clipping. |
void RefreshFullFrame(); |
private: |
friend class base::RefCountedThreadSafe<RectangleUpdateDecoder>; |
- friend class PartialFrameCleanup; |
~RectangleUpdateDecoder(); |
- void AllocateFrame(const VideoPacket* packet, const base::Closure& done); |
- void ProcessPacketData(const VideoPacket* packet, const base::Closure& done); |
- |
// Obtain updated rectangles from decoder and submit it to the consumer. |
void SubmitToConsumer(); |
- // Use |refresh_rects_| to do a refresh to the backing video frame. |
- // When done the affected rectangles are submitted to the consumer. |
- void DoRefresh(); |
- |
- // Callback for FrameConsumer::OnPartialFrameOutput() |
- void OnFrameConsumed(SkRegion* region); |
+ // Callback for FrameConsumer::OnFrameReady() |
+ void OnPaintFrame(); |
scoped_refptr<base::MessageLoopProxy> message_loop_; |
FrameConsumer* consumer_; |
+ scoped_ptr<Decoder> decoder_; |
+ |
+ // Remote screen size in pixels. |
SkISize screen_size_; |
- SkIRect clip_rect_; |
- SkRegion refresh_region_; |
- scoped_ptr<Decoder> decoder_; |
- bool decoder_needs_reset_; |
+ // True while drawing operation is in progress. |
+ bool update_pending_; |
- // The video frame that the decoder writes to. |
- scoped_refptr<media::VideoFrame> frame_; |
+ // Frame consumer's data captured for the duration of drawing to |
+ // the backing store. |
+ SkISize view_size_; |
+ SkIRect clip_area_; |
+ scoped_ptr<pp::ImageData> backing_store_; |
}; |
} // namespace remoting |