Chromium Code Reviews| Index: cc/tiles/checker_image_tracker.h |
| diff --git a/cc/tiles/checker_image_tracker.h b/cc/tiles/checker_image_tracker.h |
| index 335050c6b9df5ec861be30f2f6b58f852bbebf07..b8697e8c25e8b04e72d3849cd057fa62f61038ae 100644 |
| --- a/cc/tiles/checker_image_tracker.h |
| +++ b/cc/tiles/checker_image_tracker.h |
| @@ -33,6 +33,22 @@ class CC_EXPORT CheckerImageTrackerClient { |
| // sync tree until the previous tree is activated. |
| class CC_EXPORT CheckerImageTracker { |
| public: |
| + enum class DecodeType : uint16_t { |
| + // Highest priority. Used to disable scheduling any decode work. |
| + kNone, |
|
vmpstr
2017/06/20 18:41:01
This is an awkward name. Just from looking at this
Khushal
2017/06/21 23:45:28
I just made it all internal so we wouldn't need to
|
| + // Priority for images on tiles being rasterized (visible or pre-paint). |
| + kRaster, |
| + // Lowest priority for images on tiles in pre-decode region. These are tiles |
| + // which are beyond the pre-paint region, but have their images decoded. |
| + kPreDecode |
| + }; |
| + |
| + struct ImageDecodeRequest { |
| + ImageDecodeRequest(PaintImage paint_image, DecodeType type); |
| + PaintImage paint_image; |
| + DecodeType type; |
| + }; |
| + |
| CheckerImageTracker(ImageController* image_controller, |
| CheckerImageTrackerClient* client, |
| bool enable_checker_imaging); |
| @@ -42,9 +58,13 @@ class CC_EXPORT CheckerImageTracker { |
| // service and it should be be skipped during raster. |
| bool ShouldCheckerImage(const DrawImage& image, WhichTree tree); |
| - using ImageDecodeQueue = std::vector<PaintImage>; |
| + // Provides a prioritized queue of images to decode. |
| + using ImageDecodeQueue = std::vector<ImageDecodeRequest>; |
| void ScheduleImageDecodeQueue(ImageDecodeQueue image_decode_queue); |
| + // The max decode priority type that is allowed to run. |
|
vmpstr
2017/06/20 18:41:01
Can you use the word "max" or "limit" in the funct
Khushal
2017/06/21 03:35:57
Done.
|
| + void SetCanScheduleDecodeType(DecodeType decode_type); |
| + |
| // Returns the set of images to invalidate on the sync tree. |
| const PaintImageIdFlatSet& TakeImagesToInvalidateOnSyncTree(); |
| @@ -130,6 +150,9 @@ class CC_EXPORT CheckerImageTracker { |
| // dependent on these images. |
| ImageDecodeQueue image_decode_queue_; |
| + // The max decode type that is allowed to run. |
| + DecodeType decode_type_allowed_; |
| + |
| // The currently outstanding image decode that has been scheduled with the |
| // decode service. There can be only one outstanding decode at a time. |
| base::Optional<PaintImage> outstanding_image_decode_; |