| OLD | NEW |
| 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 #ifndef CC_RESOURCES_PICTURE_PILE_IMPL_H_ | 5 #ifndef CC_RESOURCES_PICTURE_PILE_IMPL_H_ |
| 6 #define CC_RESOURCES_PICTURE_PILE_IMPL_H_ | 6 #define CC_RESOURCES_PICTURE_PILE_IMPL_H_ |
| 7 | 7 |
| 8 #include <list> | 8 #include <list> |
| 9 #include <map> | 9 #include <map> |
| 10 #include <set> | 10 #include <set> |
| 11 #include <vector> | 11 #include <vector> |
| 12 | 12 |
| 13 #include "base/time/time.h" | 13 #include "base/time/time.h" |
| 14 #include "cc/base/cc_export.h" | 14 #include "cc/base/cc_export.h" |
| 15 #include "cc/debug/rendering_stats_instrumentation.h" | 15 #include "cc/debug/rendering_stats_instrumentation.h" |
| 16 #include "cc/resources/picture_pile_base.h" | 16 #include "cc/resources/picture_pile_base.h" |
| 17 #include "cc/resources/raster_source.h" |
| 17 #include "skia/ext/analysis_canvas.h" | 18 #include "skia/ext/analysis_canvas.h" |
| 18 #include "skia/ext/refptr.h" | 19 #include "skia/ext/refptr.h" |
| 19 #include "third_party/skia/include/core/SkPicture.h" | 20 #include "third_party/skia/include/core/SkPicture.h" |
| 20 | 21 |
| 21 namespace cc { | 22 namespace cc { |
| 22 | 23 |
| 23 class CC_EXPORT PicturePileImpl : public PicturePileBase { | 24 class CC_EXPORT PicturePileImpl : public PicturePileBase, public RasterSource { |
| 24 public: | 25 public: |
| 25 static scoped_refptr<PicturePileImpl> Create(); | 26 static scoped_refptr<PicturePileImpl> Create(); |
| 26 static scoped_refptr<PicturePileImpl> CreateFromOther( | 27 static scoped_refptr<PicturePileImpl> CreateFromOther( |
| 27 const PicturePileBase* other); | 28 const PicturePileBase* other); |
| 28 | 29 |
| 29 // Raster a subrect of this PicturePileImpl into the given canvas. It is | 30 // RasterSource overrides. See RasterSource header for full description. |
| 30 // assumed that contents_scale has already been applied to this canvas. | 31 // When slow-down-raster-scale-factor is set to a value greater than 1, the |
| 31 // Writes the total number of pixels rasterized and the time spent | 32 // reported rasterize time (in stats_instrumentation) is the minimum measured |
| 32 // rasterizing to the stats if the respective pointer is not NULL. When | 33 // value over all runs. |
| 33 // slow-down-raster-scale-factor is set to a value greater than 1, the | 34 void RasterToBitmap( |
| 34 // reported rasterize time is the minimum measured value over all runs. | 35 SkCanvas* canvas, |
| 36 const gfx::Rect& canvas_rect, |
| 37 float contents_scale, |
| 38 RenderingStatsInstrumentation* stats_instrumentation) const override; |
| 39 void AnalyzeInRect( |
| 40 const gfx::Rect& content_rect, |
| 41 float contents_scale, |
| 42 RasterSource::Analysis* analysis, |
| 43 RenderingStatsInstrumentation* stats_instrumentation) const override; |
| 44 void GatherPixelRefs(const gfx::Rect& content_rect, |
| 45 float contents_scale, |
| 46 std::vector<SkPixelRef*>* pixel_refs) const override; |
| 47 bool RasterCoversRect(const gfx::Rect& content_rect, |
| 48 float contents_scale) const override; |
| 49 bool SuitableForDistanceFieldText() const override; |
| 50 |
| 51 // Raster into the canvas without applying clips. |
| 35 void RasterDirect( | 52 void RasterDirect( |
| 36 SkCanvas* canvas, | 53 SkCanvas* canvas, |
| 37 const gfx::Rect& canvas_rect, | 54 const gfx::Rect& canvas_rect, |
| 38 float contents_scale, | 55 float contents_scale, |
| 39 RenderingStatsInstrumentation* rendering_stats_instrumentation); | 56 RenderingStatsInstrumentation* rendering_stats_instrumentation) const; |
| 40 | 57 |
| 41 // Similar to the above RasterDirect method, but this is a convenience method | 58 // Tracing functionality. |
| 42 // for when it is known that the raster is going to an intermediate bitmap | 59 void DidBeginTracing(); |
| 43 // that itself will then be blended and thus that a canvas clear is required. | |
| 44 // Note that this function may write outside the canvas_rect. | |
| 45 void RasterToBitmap( | |
| 46 SkCanvas* canvas, | |
| 47 const gfx::Rect& canvas_rect, | |
| 48 float contents_scale, | |
| 49 RenderingStatsInstrumentation* stats_instrumentation) const; | |
| 50 | |
| 51 // Called when analyzing a tile. We can use AnalysisCanvas as | |
| 52 // SkDrawPictureCallback, which allows us to early out from analysis. | |
| 53 void RasterForAnalysis( | |
| 54 skia::AnalysisCanvas* canvas, | |
| 55 const gfx::Rect& canvas_rect, | |
| 56 float contents_scale, | |
| 57 RenderingStatsInstrumentation* stats_instrumentation) const; | |
| 58 | |
| 59 skia::RefPtr<SkPicture> GetFlattenedPicture(); | 60 skia::RefPtr<SkPicture> GetFlattenedPicture(); |
| 60 | 61 |
| 61 bool likely_to_be_used_for_transform_animation() const { | |
| 62 return likely_to_be_used_for_transform_animation_; | |
| 63 } | |
| 64 void set_likely_to_be_used_for_transform_animation() { | 62 void set_likely_to_be_used_for_transform_animation() { |
| 65 likely_to_be_used_for_transform_animation_ = true; | 63 likely_to_be_used_for_transform_animation_ = true; |
| 66 } | 64 } |
| 67 | 65 |
| 68 struct CC_EXPORT Analysis { | 66 // Iterator used to return SkPixelRefs from this picture pile. |
| 69 Analysis(); | 67 // Public for testing. |
| 70 ~Analysis(); | |
| 71 | |
| 72 bool is_solid_color; | |
| 73 SkColor solid_color; | |
| 74 }; | |
| 75 | |
| 76 void AnalyzeInRect(const gfx::Rect& content_rect, | |
| 77 float contents_scale, | |
| 78 Analysis* analysis) const; | |
| 79 | |
| 80 void AnalyzeInRect( | |
| 81 const gfx::Rect& content_rect, | |
| 82 float contents_scale, | |
| 83 Analysis* analysis, | |
| 84 RenderingStatsInstrumentation* stats_instrumentation) const; | |
| 85 | |
| 86 class CC_EXPORT PixelRefIterator { | 68 class CC_EXPORT PixelRefIterator { |
| 87 public: | 69 public: |
| 88 PixelRefIterator(const gfx::Rect& content_rect, | 70 PixelRefIterator(const gfx::Rect& content_rect, |
| 89 float contents_scale, | 71 float contents_scale, |
| 90 const PicturePileImpl* picture_pile); | 72 const PicturePileImpl* picture_pile); |
| 91 ~PixelRefIterator(); | 73 ~PixelRefIterator(); |
| 92 | 74 |
| 93 SkPixelRef* operator->() const { return *pixel_ref_iterator_; } | 75 SkPixelRef* operator->() const { return *pixel_ref_iterator_; } |
| 94 SkPixelRef* operator*() const { return *pixel_ref_iterator_; } | 76 SkPixelRef* operator*() const { return *pixel_ref_iterator_; } |
| 95 PixelRefIterator& operator++(); | 77 PixelRefIterator& operator++(); |
| 96 operator bool() const { return pixel_ref_iterator_; } | 78 operator bool() const { return pixel_ref_iterator_; } |
| 97 | 79 |
| 98 private: | 80 private: |
| 99 void AdvanceToTilePictureWithPixelRefs(); | 81 void AdvanceToTilePictureWithPixelRefs(); |
| 100 | 82 |
| 101 const PicturePileImpl* picture_pile_; | 83 const PicturePileImpl* picture_pile_; |
| 102 gfx::Rect layer_rect_; | 84 gfx::Rect layer_rect_; |
| 103 TilingData::Iterator tile_iterator_; | 85 TilingData::Iterator tile_iterator_; |
| 104 Picture::PixelRefIterator pixel_ref_iterator_; | 86 Picture::PixelRefIterator pixel_ref_iterator_; |
| 105 std::set<const void*> processed_pictures_; | 87 std::set<const void*> processed_pictures_; |
| 106 }; | 88 }; |
| 107 | 89 |
| 108 void DidBeginTracing(); | |
| 109 | |
| 110 protected: | 90 protected: |
| 111 friend class PicturePile; | 91 friend class PicturePile; |
| 112 friend class PixelRefIterator; | 92 friend class PixelRefIterator; |
| 113 | 93 |
| 114 PicturePileImpl(); | 94 PicturePileImpl(); |
| 115 explicit PicturePileImpl(const PicturePileBase* other); | 95 explicit PicturePileImpl(const PicturePileBase* other); |
| 116 ~PicturePileImpl() override; | 96 ~PicturePileImpl() override; |
| 117 | 97 |
| 118 private: | 98 private: |
| 119 typedef std::map<const Picture*, Region> PictureRegionMap; | 99 typedef std::map<const Picture*, Region> PictureRegionMap; |
| 120 | 100 |
| 101 // Called when analyzing a tile. We can use AnalysisCanvas as |
| 102 // SkDrawPictureCallback, which allows us to early out from analysis. |
| 103 void RasterForAnalysis( |
| 104 skia::AnalysisCanvas* canvas, |
| 105 const gfx::Rect& canvas_rect, |
| 106 float contents_scale, |
| 107 RenderingStatsInstrumentation* stats_instrumentation) const; |
| 108 |
| 121 void CoalesceRasters(const gfx::Rect& canvas_rect, | 109 void CoalesceRasters(const gfx::Rect& canvas_rect, |
| 122 const gfx::Rect& content_rect, | 110 const gfx::Rect& content_rect, |
| 123 float contents_scale, | 111 float contents_scale, |
| 124 PictureRegionMap* result) const; | 112 PictureRegionMap* result) const; |
| 125 | 113 |
| 126 void RasterCommon( | 114 void RasterCommon( |
| 127 SkCanvas* canvas, | 115 SkCanvas* canvas, |
| 128 SkDrawPictureCallback* callback, | 116 SkDrawPictureCallback* callback, |
| 129 const gfx::Rect& canvas_rect, | 117 const gfx::Rect& canvas_rect, |
| 130 float contents_scale, | 118 float contents_scale, |
| 131 RenderingStatsInstrumentation* rendering_stats_instrumentation, | 119 RenderingStatsInstrumentation* rendering_stats_instrumentation, |
| 132 bool is_analysis) const; | 120 bool is_analysis) const; |
| 133 | 121 |
| 134 bool likely_to_be_used_for_transform_animation_; | 122 bool likely_to_be_used_for_transform_animation_; |
| 135 | 123 |
| 136 DISALLOW_COPY_AND_ASSIGN(PicturePileImpl); | 124 DISALLOW_COPY_AND_ASSIGN(PicturePileImpl); |
| 137 }; | 125 }; |
| 138 | 126 |
| 139 } // namespace cc | 127 } // namespace cc |
| 140 | 128 |
| 141 #endif // CC_RESOURCES_PICTURE_PILE_IMPL_H_ | 129 #endif // CC_RESOURCES_PICTURE_PILE_IMPL_H_ |
| OLD | NEW |