Index: cc/output/direct_renderer.cc |
diff --git a/cc/output/direct_renderer.cc b/cc/output/direct_renderer.cc |
index ae8ff9b336335b4fc05bf32acf993de2fe891976..7d0083f73a6fa805bbe871424bcedb56ca45aef5 100644 |
--- a/cc/output/direct_renderer.cc |
+++ b/cc/output/direct_renderer.cc |
@@ -8,6 +8,7 @@ |
#include <vector> |
#include "base/debug/trace_event.h" |
+#include "base/hash_tables.h" |
#include "base/metrics/histogram.h" |
#include "cc/base/math_util.h" |
#include "cc/quads/draw_quad.h" |
@@ -192,9 +193,19 @@ void DirectRenderer::DrawFrame(RenderPassList* render_passes_in_draw_order) { |
root_render_pass->damage_rect : root_render_pass->output_rect; |
frame.root_damage_rect.Intersect(gfx::Rect(ViewportSize())); |
+ std::vector<base::Closure> copy_callbacks; |
+ |
BeginDrawingFrame(&frame); |
- for (size_t i = 0; i < render_passes_in_draw_order->size(); ++i) |
+ for (size_t i = 0; i < render_passes_in_draw_order->size(); ++i) { |
DrawRenderPass(&frame, render_passes_in_draw_order->at(i)); |
+ |
+ const RenderPass* pass = frame.current_render_pass; |
+ for (size_t i = 0; i < pass->copy_callbacks.size(); ++i) { |
+ scoped_ptr<SkBitmap> bitmap(new SkBitmap); |
+ CopyCurrentRenderPassToBitmap(&frame, bitmap.get()); |
+ pass->copy_callbacks[i].Run(bitmap.Pass()); |
+ } |
+ } |
FinishDrawingFrame(&frame); |
render_passes_in_draw_order->clear(); |