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

Unified Diff: remoting/client/frame_producer.h

Issue 9331003: Improving the decoder pipeline. (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: CR feedback and a couple of fixes. Created 8 years, 10 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 side-by-side diff with in-line comments
Download patch
Index: remoting/client/frame_producer.h
diff --git a/remoting/client/frame_producer.h b/remoting/client/frame_producer.h
new file mode 100644
index 0000000000000000000000000000000000000000..aa8e0a85f46582505d31e966bbff676e874a5016
--- /dev/null
+++ b/remoting/client/frame_producer.h
@@ -0,0 +1,53 @@
+// 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"
+#include "third_party/skia/include/core/SkRect.h"
+#include "third_party/skia/include/core/SkRegion.h"
+#include "third_party/skia/include/core/SkSize.h"
+
+namespace pp {
+class ImageData;
+} // namespace pp
+
+namespace remoting {
+
+class FrameProducer {
+ public:
+ FrameProducer() {}
+ virtual ~FrameProducer() {}
+
+ // This routine drains the queue returning all pending buffers to
+ // the consumer.
+ virtual void DrainQueue(const base::Closure& done) = 0;
+
+ // This routine submits an image buffer for subsequent drawing. Once any part
+ // of the frame within the clipping area is invalidated, the producer copies
+ // the updated pixels to one of the pending buffers and return it to
+ // the consumer via the FrameConsumer::PaintBuffer() call.
+ //
+ // The passed buffer must be large enough to hold the whole clipping area.
+ virtual void EnqueueBuffer(pp::ImageData* buffer) = 0;
+
+ // The frame consumer can call this routine requesting the frame to be
+ // repainted. The specified region of the frame is will be invalided.
+ // The region is given in client's coordinates relative to the beginning of
+ // the frame.
+ virtual void Invalidate(const SkRegion& region) = 0;
+
+ // The frame consumer calls this function to notify the producer about view
+ // area changes. This can result in producer immediately returning some of or
+ // all enqueued buffers to the consumer for reuse or reallocation.
+ virtual void SetView(const SkISize& view_size, const SkIRect& clip_area) = 0;
+
+ private:
+ DISALLOW_COPY_AND_ASSIGN(FrameProducer);
+};
+
+} // namespace remoting
+
+#endif // REMOTING_CLIENT_FRAME_PRODUCER_H_

Powered by Google App Engine
This is Rietveld 408576698