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

Side by Side Diff: cc/output/software_renderer.cc

Issue 14417014: cc: Add tile-free software compositing mode. (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: Rebase to 199251 Created 7 years, 7 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 | Annotate | Revision Log
« no previous file with comments | « cc/output/software_renderer.h ('k') | cc/resources/picture_pile_impl.cc » ('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 2012 The Chromium Authors. All rights reserved. 1 // Copyright 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 #include "cc/output/software_renderer.h" 5 #include "cc/output/software_renderer.h"
6 6
7 #include "base/debug/trace_event.h" 7 #include "base/debug/trace_event.h"
8 #include "cc/base/math_util.h" 8 #include "cc/base/math_util.h"
9 #include "cc/output/compositor_frame.h" 9 #include "cc/output/compositor_frame.h"
10 #include "cc/output/compositor_frame_ack.h" 10 #include "cc/output/compositor_frame_ack.h"
11 #include "cc/output/compositor_frame_metadata.h" 11 #include "cc/output/compositor_frame_metadata.h"
12 #include "cc/output/output_surface.h" 12 #include "cc/output/output_surface.h"
13 #include "cc/output/software_output_device.h" 13 #include "cc/output/software_output_device.h"
14 #include "cc/quads/debug_border_draw_quad.h" 14 #include "cc/quads/debug_border_draw_quad.h"
15 #include "cc/quads/picture_draw_quad.h"
15 #include "cc/quads/render_pass_draw_quad.h" 16 #include "cc/quads/render_pass_draw_quad.h"
16 #include "cc/quads/solid_color_draw_quad.h" 17 #include "cc/quads/solid_color_draw_quad.h"
17 #include "cc/quads/texture_draw_quad.h" 18 #include "cc/quads/texture_draw_quad.h"
18 #include "cc/quads/tile_draw_quad.h" 19 #include "cc/quads/tile_draw_quad.h"
19 #include "third_party/skia/include/core/SkCanvas.h" 20 #include "third_party/skia/include/core/SkCanvas.h"
20 #include "third_party/skia/include/core/SkColor.h" 21 #include "third_party/skia/include/core/SkColor.h"
21 #include "third_party/skia/include/core/SkDevice.h" 22 #include "third_party/skia/include/core/SkDevice.h"
22 #include "third_party/skia/include/core/SkMatrix.h" 23 #include "third_party/skia/include/core/SkMatrix.h"
23 #include "third_party/skia/include/core/SkShader.h" 24 #include "third_party/skia/include/core/SkShader.h"
24 #include "third_party/skia/include/effects/SkLayerRasterizer.h" 25 #include "third_party/skia/include/effects/SkLayerRasterizer.h"
(...skipping 39 matching lines...) Expand 10 before | Expand all | Expand 10 after
64 SoftwareRenderer::SoftwareRenderer(RendererClient* client, 65 SoftwareRenderer::SoftwareRenderer(RendererClient* client,
65 OutputSurface* output_surface, 66 OutputSurface* output_surface,
66 ResourceProvider* resource_provider) 67 ResourceProvider* resource_provider)
67 : DirectRenderer(client, resource_provider), 68 : DirectRenderer(client, resource_provider),
68 visible_(true), 69 visible_(true),
69 is_scissor_enabled_(false), 70 is_scissor_enabled_(false),
70 is_viewport_changed_(true), 71 is_viewport_changed_(true),
71 output_surface_(output_surface), 72 output_surface_(output_surface),
72 output_device_(output_surface->software_device()), 73 output_device_(output_surface->software_device()),
73 current_canvas_(NULL) { 74 current_canvas_(NULL) {
74 capabilities_.max_texture_size = resource_provider_->max_texture_size(); 75 if (resource_provider_) {
75 capabilities_.best_texture_format = resource_provider_->best_texture_format(); 76 capabilities_.max_texture_size = resource_provider_->max_texture_size();
77 capabilities_.best_texture_format =
78 resource_provider_->best_texture_format();
79 }
76 capabilities_.using_set_visibility = true; 80 capabilities_.using_set_visibility = true;
77 // The updater can access bitmaps while the SoftwareRenderer is using them. 81 // The updater can access bitmaps while the SoftwareRenderer is using them.
78 capabilities_.allow_partial_texture_updates = true; 82 capabilities_.allow_partial_texture_updates = true;
79 capabilities_.using_partial_swap = true; 83 capabilities_.using_partial_swap = true;
80 if (Settings().compositor_frame_message && client_->HasImplThread()) 84 if (Settings().compositor_frame_message && client_->HasImplThread())
81 capabilities_.using_swap_complete_callback = true; 85 capabilities_.using_swap_complete_callback = true;
82 compositor_frame_.software_frame_data.reset(new SoftwareFrameData()); 86 compositor_frame_.software_frame_data.reset(new SoftwareFrameData());
83 } 87 }
84 88
85 SoftwareRenderer::~SoftwareRenderer() {} 89 SoftwareRenderer::~SoftwareRenderer() {}
(...skipping 151 matching lines...) Expand 10 before | Expand all | Expand 10 after
237 current_paint_.setAlpha(quad->opacity() * 255); 241 current_paint_.setAlpha(quad->opacity() * 255);
238 current_paint_.setXfermodeMode(SkXfermode::kSrcOver_Mode); 242 current_paint_.setXfermodeMode(SkXfermode::kSrcOver_Mode);
239 } else { 243 } else {
240 current_paint_.setXfermodeMode(SkXfermode::kSrc_Mode); 244 current_paint_.setXfermodeMode(SkXfermode::kSrc_Mode);
241 } 245 }
242 246
243 switch (quad->material) { 247 switch (quad->material) {
244 case DrawQuad::DEBUG_BORDER: 248 case DrawQuad::DEBUG_BORDER:
245 DrawDebugBorderQuad(frame, DebugBorderDrawQuad::MaterialCast(quad)); 249 DrawDebugBorderQuad(frame, DebugBorderDrawQuad::MaterialCast(quad));
246 break; 250 break;
251 case DrawQuad::PICTURE_CONTENT:
252 DrawPictureQuad(frame, PictureDrawQuad::MaterialCast(quad));
253 break;
247 case DrawQuad::SOLID_COLOR: 254 case DrawQuad::SOLID_COLOR:
248 DrawSolidColorQuad(frame, SolidColorDrawQuad::MaterialCast(quad)); 255 DrawSolidColorQuad(frame, SolidColorDrawQuad::MaterialCast(quad));
249 break; 256 break;
250 case DrawQuad::TEXTURE_CONTENT: 257 case DrawQuad::TEXTURE_CONTENT:
251 DrawTextureQuad(frame, TextureDrawQuad::MaterialCast(quad)); 258 DrawTextureQuad(frame, TextureDrawQuad::MaterialCast(quad));
252 break; 259 break;
253 case DrawQuad::TILED_CONTENT: 260 case DrawQuad::TILED_CONTENT:
254 DrawTileQuad(frame, TileDrawQuad::MaterialCast(quad)); 261 DrawTileQuad(frame, TileDrawQuad::MaterialCast(quad));
255 break; 262 break;
256 case DrawQuad::RENDER_PASS: 263 case DrawQuad::RENDER_PASS:
(...skipping 19 matching lines...) Expand all
276 current_canvas_->resetMatrix(); 283 current_canvas_->resetMatrix();
277 284
278 current_paint_.setColor(quad->color); 285 current_paint_.setColor(quad->color);
279 current_paint_.setAlpha(quad->opacity() * SkColorGetA(quad->color)); 286 current_paint_.setAlpha(quad->opacity() * SkColorGetA(quad->color));
280 current_paint_.setStyle(SkPaint::kStroke_Style); 287 current_paint_.setStyle(SkPaint::kStroke_Style);
281 current_paint_.setStrokeWidth(quad->width); 288 current_paint_.setStrokeWidth(quad->width);
282 current_canvas_->drawPoints(SkCanvas::kPolygon_PointMode, 289 current_canvas_->drawPoints(SkCanvas::kPolygon_PointMode,
283 4, transformed_vertices, current_paint_); 290 4, transformed_vertices, current_paint_);
284 } 291 }
285 292
293 void SoftwareRenderer::DrawPictureQuad(const DrawingFrame* frame,
294 const PictureDrawQuad* quad) {
295 SkMatrix content_matrix;
296 content_matrix.setRectToRect(
297 gfx::RectFToSkRect(quad->tex_coord_rect),
298 gfx::RectFToSkRect(QuadVertexRect()),
299 SkMatrix::kFill_ScaleToFit);
300 current_canvas_->concat(content_matrix);
301
302 if (quad->ShouldDrawWithBlending()) {
303 TRACE_EVENT0("cc", "SoftwareRenderer::DrawPictureQuad with blending");
304 SkBitmap temp_bitmap;
305 temp_bitmap.setConfig(SkBitmap::kARGB_8888_Config,
306 quad->texture_size.width(),
307 quad->texture_size.height());
308 temp_bitmap.allocPixels();
309 SkDevice temp_device(temp_bitmap);
310 SkCanvas temp_canvas(&temp_device);
311
312 quad->picture_pile->Raster(
313 &temp_canvas, quad->content_rect, quad->contents_scale, NULL);
314
315 current_paint_.setFilterBitmap(true);
316 current_canvas_->drawBitmap(temp_bitmap, 0, 0, &current_paint_);
317 } else {
318 TRACE_EVENT0("cc",
319 "SoftwareRenderer::DrawPictureQuad direct from PicturePile");
320 quad->picture_pile->Raster(
321 current_canvas_, quad->content_rect, quad->contents_scale, NULL);
322 }
323 }
324
286 void SoftwareRenderer::DrawSolidColorQuad(const DrawingFrame* frame, 325 void SoftwareRenderer::DrawSolidColorQuad(const DrawingFrame* frame,
287 const SolidColorDrawQuad* quad) { 326 const SolidColorDrawQuad* quad) {
288 current_paint_.setColor(quad->color); 327 current_paint_.setColor(quad->color);
289 current_paint_.setAlpha(quad->opacity() * SkColorGetA(quad->color)); 328 current_paint_.setAlpha(quad->opacity() * SkColorGetA(quad->color));
290 current_canvas_->drawRect(gfx::RectFToSkRect(QuadVertexRect()), 329 current_canvas_->drawRect(gfx::RectFToSkRect(QuadVertexRect()),
291 current_paint_); 330 current_paint_);
292 } 331 }
293 332
294 void SoftwareRenderer::DrawTextureQuad(const DrawingFrame* frame, 333 void SoftwareRenderer::DrawTextureQuad(const DrawingFrame* frame,
295 const TextureDrawQuad* quad) { 334 const TextureDrawQuad* quad) {
(...skipping 13 matching lines...) Expand all
309 SkRect sk_uv_rect = gfx::RectFToSkRect(uv_rect); 348 SkRect sk_uv_rect = gfx::RectFToSkRect(uv_rect);
310 if (quad->flipped) 349 if (quad->flipped)
311 current_canvas_->scale(1, -1); 350 current_canvas_->scale(1, -1);
312 current_canvas_->drawBitmapRectToRect(*bitmap, &sk_uv_rect, 351 current_canvas_->drawBitmapRectToRect(*bitmap, &sk_uv_rect,
313 gfx::RectFToSkRect(QuadVertexRect()), 352 gfx::RectFToSkRect(QuadVertexRect()),
314 &current_paint_); 353 &current_paint_);
315 } 354 }
316 355
317 void SoftwareRenderer::DrawTileQuad(const DrawingFrame* frame, 356 void SoftwareRenderer::DrawTileQuad(const DrawingFrame* frame,
318 const TileDrawQuad* quad) { 357 const TileDrawQuad* quad) {
358 DCHECK(!output_surface_->ForcedDrawToSoftwareDevice());
319 DCHECK(IsSoftwareResource(quad->resource_id)); 359 DCHECK(IsSoftwareResource(quad->resource_id));
320 ResourceProvider::ScopedReadLockSoftware lock(resource_provider_, 360 ResourceProvider::ScopedReadLockSoftware lock(resource_provider_,
321 quad->resource_id); 361 quad->resource_id);
322 362
323 SkRect uv_rect = gfx::RectFToSkRect(quad->tex_coord_rect); 363 SkRect uv_rect = gfx::RectFToSkRect(quad->tex_coord_rect);
324 current_paint_.setFilterBitmap(true); 364 current_paint_.setFilterBitmap(true);
325 current_canvas_->drawBitmapRectToRect(*lock.sk_bitmap(), &uv_rect, 365 current_canvas_->drawBitmapRectToRect(*lock.sk_bitmap(), &uv_rect,
326 gfx::RectFToSkRect(QuadVertexRect()), 366 gfx::RectFToSkRect(QuadVertexRect()),
327 &current_paint_); 367 &current_paint_);
328 } 368 }
(...skipping 99 matching lines...) Expand 10 before | Expand all | Expand 10 after
428 4 * rect.width()); 468 4 * rect.width());
429 } 469 }
430 470
431 void SoftwareRenderer::SetVisible(bool visible) { 471 void SoftwareRenderer::SetVisible(bool visible) {
432 if (visible_ == visible) 472 if (visible_ == visible)
433 return; 473 return;
434 visible_ = visible; 474 visible_ = visible;
435 } 475 }
436 476
437 } // namespace cc 477 } // namespace cc
OLDNEW
« no previous file with comments | « cc/output/software_renderer.h ('k') | cc/resources/picture_pile_impl.cc » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698