| Index: cc/resources/picture.h
|
| diff --git a/cc/resources/picture.h b/cc/resources/picture.h
|
| index a29d5afaa6438177def4ca4af6c58e7c629d0c8a..dd6202a1544206e5344dd4742b0f165218cfe62b 100644
|
| --- a/cc/resources/picture.h
|
| +++ b/cc/resources/picture.h
|
| @@ -5,13 +5,15 @@
|
| #ifndef CC_RESOURCES_PICTURE_H_
|
| #define CC_RESOURCES_PICTURE_H_
|
|
|
| -#include <list>
|
| #include <string>
|
| +#include <utility>
|
| #include <vector>
|
|
|
| #include "base/basictypes.h"
|
| +#include "base/hash_tables.h"
|
| #include "base/memory/ref_counted.h"
|
| #include "cc/base/cc_export.h"
|
| +#include "cc/base/hash_pair.h"
|
| #include "skia/ext/lazy_pixel_ref.h"
|
| #include "skia/ext/refptr.h"
|
| #include "third_party/skia/include/core/SkPixelRef.h"
|
| @@ -30,6 +32,11 @@ struct RenderingStats;
|
| class CC_EXPORT Picture
|
| : public base::RefCountedThreadSafe<Picture> {
|
| public:
|
| + typedef std::pair<int, int> PixelRefMapKey;
|
| + typedef base::hash_map<
|
| + PixelRefMapKey,
|
| + std::vector<skia::LazyPixelRef*> > PixelRefMap;
|
| +
|
| static scoped_refptr<Picture> Create(gfx::Rect layer_rect);
|
| static scoped_refptr<Picture> CreateFromBase64String(
|
| const std::string& encoded_string);
|
| @@ -58,12 +65,33 @@ class CC_EXPORT Picture
|
| float contents_scale,
|
| bool enable_lcd_text);
|
|
|
| - void GatherPixelRefs(
|
| - const gfx::Rect& layer_rect,
|
| - std::list<skia::LazyPixelRef*>& pixel_ref_list);
|
| -
|
| void AsBase64String(std::string* output) const;
|
|
|
| + class CC_EXPORT PixelRefIterator {
|
| + public:
|
| + PixelRefIterator();
|
| + PixelRefIterator(const PixelRefIterator& other);
|
| + PixelRefIterator(gfx::Rect layer_rect, const Picture* picture);
|
| + ~PixelRefIterator();
|
| +
|
| + skia::LazyPixelRef* operator->() const { return *current_iterator_; }
|
| + skia::LazyPixelRef* operator*() const { return *current_iterator_; }
|
| + PixelRefIterator& operator++();
|
| + PixelRefIterator& operator=(const PixelRefIterator& other);
|
| + operator bool() const { return !!*current_iterator_; }
|
| +
|
| + private:
|
| + const Picture* picture_;
|
| + std::vector<skia::LazyPixelRef*> sentinel_;
|
| + const std::vector<skia::LazyPixelRef*>* current_pixel_refs_;
|
| + std::vector<skia::LazyPixelRef*>::const_iterator current_iterator_;
|
| +
|
| + gfx::Point min_point_;
|
| + gfx::Point max_point_;
|
| + int current_x_;
|
| + int current_y_;
|
| + };
|
| +
|
| private:
|
| explicit Picture(gfx::Rect layer_rect);
|
| Picture(const std::string& encoded_string, bool* success);
|
| @@ -71,9 +99,15 @@ class CC_EXPORT Picture
|
| // ownership to this picture.
|
| Picture(const skia::RefPtr<SkPicture>&,
|
| gfx::Rect layer_rect,
|
| - gfx::Rect opaque_rect);
|
| + gfx::Rect opaque_rect,
|
| + const PixelRefMap& pixel_refs);
|
| ~Picture();
|
|
|
| + void GatherPixelRefsFromSkia(
|
| + gfx::Rect query_rect,
|
| + std::vector<skia::LazyPixelRef*>* pixel_refs);
|
| + void GatherAllPixelRefs();
|
| +
|
| gfx::Rect layer_rect_;
|
| gfx::Rect opaque_rect_;
|
| skia::RefPtr<SkPicture> picture_;
|
| @@ -81,7 +115,13 @@ class CC_EXPORT Picture
|
| typedef std::vector<scoped_refptr<Picture> > PictureVector;
|
| PictureVector clones_;
|
|
|
| + PixelRefMap pixel_refs_;
|
| + gfx::Point min_pixel_cell_;
|
| + gfx::Point max_pixel_cell_;
|
| + gfx::Size cell_size_;
|
| +
|
| friend class base::RefCountedThreadSafe<Picture>;
|
| + friend class PixelRefIterator;
|
| DISALLOW_COPY_AND_ASSIGN(Picture);
|
| };
|
|
|
|
|