Chromium Code Reviews| Index: cc/quads/render_pass.cc |
| diff --git a/cc/quads/render_pass.cc b/cc/quads/render_pass.cc |
| index 61fcb255f348a0186ed2fef5f60711f0d908fdf5..830e6df0b5ab3d71b06e3f109b3da0b801d8eac8 100644 |
| --- a/cc/quads/render_pass.cc |
| +++ b/cc/quads/render_pass.cc |
| @@ -8,9 +8,19 @@ |
| #include "cc/base/math_util.h" |
| #include "cc/debug/traced_value.h" |
| #include "cc/output/copy_output_request.h" |
| +#include "cc/quads/checkerboard_draw_quad.h" |
| +#include "cc/quads/debug_border_draw_quad.h" |
| #include "cc/quads/draw_quad.h" |
| +#include "cc/quads/io_surface_draw_quad.h" |
| +#include "cc/quads/picture_draw_quad.h" |
| #include "cc/quads/render_pass_draw_quad.h" |
| #include "cc/quads/shared_quad_state.h" |
| +#include "cc/quads/solid_color_draw_quad.h" |
| +#include "cc/quads/stream_video_draw_quad.h" |
| +#include "cc/quads/surface_draw_quad.h" |
| +#include "cc/quads/texture_draw_quad.h" |
| +#include "cc/quads/tile_draw_quad.h" |
| +#include "cc/quads/yuv_video_draw_quad.h" |
| namespace { |
| const size_t kDefaultNumSharedQuadStatesToReserve = 32; |
| @@ -174,4 +184,69 @@ SharedQuadState* RenderPass::CreateAndAppendSharedQuadState() { |
| return shared_quad_state_list.back(); |
| } |
| +RenderPassDrawQuad* RenderPass::CopyFromAndAppendRenderPassDrawQuad( |
| + const RenderPassDrawQuad* quad, |
| + const SharedQuadState* shared_quad_state, |
| + RenderPass::Id render_pass_id) { |
| + RenderPassDrawQuad* copy_quad = |
| + CopyFromAndAppendTypedDrawQuad<RenderPassDrawQuad>(quad); |
| + copy_quad->shared_quad_state = shared_quad_state; |
| + copy_quad->render_pass_id = render_pass_id; |
| + return copy_quad; |
| +} |
| + |
| +DrawQuad* RenderPass::CopyFromAndAppendDrawQuad( |
| + const DrawQuad* quad, |
| + const SharedQuadState* shared_quad_state) { |
| + switch (quad->material) { |
| + case DrawQuad::CHECKERBOARD: { |
|
danakj
2014/07/09 17:59:14
don't need the {}'s for each of these cases
weiliangc
2014/07/09 20:59:09
Done.
|
| + CopyFromAndAppendTypedDrawQuad<CheckerboardDrawQuad>(quad); |
| + break; |
| + } |
| + case DrawQuad::DEBUG_BORDER: { |
| + CopyFromAndAppendTypedDrawQuad<DebugBorderDrawQuad>(quad); |
| + break; |
| + } |
| + case DrawQuad::IO_SURFACE_CONTENT: { |
| + CopyFromAndAppendTypedDrawQuad<IOSurfaceDrawQuad>(quad); |
| + break; |
| + } |
| + case DrawQuad::PICTURE_CONTENT: { |
| + CopyFromAndAppendTypedDrawQuad<PictureDrawQuad>(quad); |
| + break; |
| + } |
| + case DrawQuad::TEXTURE_CONTENT: { |
| + CopyFromAndAppendTypedDrawQuad<TextureDrawQuad>(quad); |
| + break; |
| + } |
| + case DrawQuad::SOLID_COLOR: { |
| + CopyFromAndAppendTypedDrawQuad<SolidColorDrawQuad>(quad); |
| + break; |
| + } |
| + case DrawQuad::TILED_CONTENT: { |
| + CopyFromAndAppendTypedDrawQuad<TileDrawQuad>(quad); |
| + break; |
| + } |
| + case DrawQuad::STREAM_VIDEO_CONTENT: { |
| + CopyFromAndAppendTypedDrawQuad<StreamVideoDrawQuad>(quad); |
| + break; |
| + } |
| + case DrawQuad::SURFACE_CONTENT: { |
| + CopyFromAndAppendTypedDrawQuad<SurfaceDrawQuad>(quad); |
| + break; |
| + } |
| + case DrawQuad::YUV_VIDEO_CONTENT: { |
| + CopyFromAndAppendTypedDrawQuad<YUVVideoDrawQuad>(quad); |
| + break; |
| + } |
| + case DrawQuad::RENDER_PASS |
| + : // RenderPass quads need to use typed copy from function. |
|
danakj
2014/07/09 17:59:14
errr can this : be on the previous line?
weiliangc
2014/07/09 20:59:09
Done.
|
| + case DrawQuad::INVALID: |
| + LOG(FATAL) << "Invalid DrawQuad material " << quad->material; |
| + break; |
| + } |
| + quad_list.back()->shared_quad_state = shared_quad_state; |
| + return quad_list.back(); |
| +} |
| + |
| } // namespace cc |