Chromium Code Reviews| OLD | NEW |
|---|---|
| 1 // Copyright 2017 The Chromium Authors. All rights reserved. | 1 // Copyright 2017 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_TILES_CHECKER_IMAGE_TRACKER_H_ | 5 #ifndef CC_TILES_CHECKER_IMAGE_TRACKER_H_ |
| 6 #define CC_TILES_CHECKER_IMAGE_TRACKER_H_ | 6 #define CC_TILES_CHECKER_IMAGE_TRACKER_H_ |
| 7 | 7 |
| 8 #include <unordered_map> | 8 #include <unordered_map> |
| 9 #include <vector> | 9 #include <vector> |
| 10 | 10 |
| (...skipping 36 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 47 void FilterImagesForCheckeringForTile(std::vector<DrawImage>* images, | 47 void FilterImagesForCheckeringForTile(std::vector<DrawImage>* images, |
| 48 ImageIdFlatSet* checkered_images, | 48 ImageIdFlatSet* checkered_images, |
| 49 WhichTree tree); | 49 WhichTree tree); |
| 50 | 50 |
| 51 // Returns the set of images to invalidate on the sync tree. | 51 // Returns the set of images to invalidate on the sync tree. |
| 52 const ImageIdFlatSet& TakeImagesToInvalidateOnSyncTree(); | 52 const ImageIdFlatSet& TakeImagesToInvalidateOnSyncTree(); |
| 53 | 53 |
| 54 void DidActivateSyncTree(); | 54 void DidActivateSyncTree(); |
| 55 | 55 |
| 56 private: | 56 private: |
| 57 enum class AsyncDecodeVetoState { | |
|
vmpstr
2017/04/11 18:42:55
s/AsyncDecodeVetoState/DecodePolicy/
Khushal
2017/04/12 20:31:17
Done.
| |
| 58 // The image can be decoded asynchronously from raster. | |
| 59 ASYNC, | |
| 60 // The image has been decoded asynchronously once and should now be | |
| 61 // synchronously rasterized with the content. | |
| 62 SYNC_DECODED_ONCE, | |
|
vmpstr
2017/04/11 18:42:55
Is there any semantic difference between the last
Khushal
2017/04/12 20:31:17
Done.
| |
| 63 // The image has been permanently vetoed from being decoded async. | |
| 64 SYNC_PERMANENT, | |
| 65 }; | |
| 66 | |
| 57 void DidFinishImageDecode(ImageId image_id, | 67 void DidFinishImageDecode(ImageId image_id, |
| 58 ImageController::ImageDecodeRequestId request_id, | 68 ImageController::ImageDecodeRequestId request_id, |
| 59 ImageController::ImageDecodeResult result); | 69 ImageController::ImageDecodeResult result); |
| 60 | 70 |
| 61 // Returns true if the decode for |image| will be deferred to the image decode | 71 // Returns true if the decode for |image| will be deferred to the image decode |
| 62 // service and it should be be skipped during raster. | 72 // service and it should be be skipped during raster. |
| 63 bool ShouldCheckerImage(const sk_sp<const SkImage>& image, | 73 bool ShouldCheckerImage(const sk_sp<const SkImage>& image, WhichTree tree); |
| 64 WhichTree tree) const; | |
| 65 | 74 |
| 66 void ScheduleImageDecodeIfNecessary(const sk_sp<const SkImage>& image); | 75 void ScheduleImageDecodeIfNecessary(const sk_sp<const SkImage>& image); |
| 67 | 76 |
| 68 ImageController* image_controller_; | 77 ImageController* image_controller_; |
| 69 CheckerImageTrackerClient* client_; | 78 CheckerImageTrackerClient* client_; |
| 70 const bool enable_checker_imaging_; | 79 const bool enable_checker_imaging_; |
| 71 | 80 |
| 72 // A set of images which have been decoded and are pending invalidation for | 81 // A set of images which have been decoded and are pending invalidation for |
| 73 // raster on the checkered tiles. | 82 // raster on the checkered tiles. |
| 74 ImageIdFlatSet images_pending_invalidation_; | 83 ImageIdFlatSet images_pending_invalidation_; |
| 75 | 84 |
| 76 // A set of images which were invalidated on the current sync tree. | 85 // A set of images which were invalidated on the current sync tree. |
| 77 ImageIdFlatSet invalidated_images_on_current_sync_tree_; | 86 ImageIdFlatSet invalidated_images_on_current_sync_tree_; |
| 78 | 87 |
| 79 // A set of images which are currently pending decode from the image decode | 88 // A set of images which are currently pending decode from the image decode |
| 80 // service. | 89 // service. |
| 81 // TODO(khushalsagar): This should be a queue that gets re-built each time we | 90 // TODO(khushalsagar): This should be a queue that gets re-built each time we |
| 82 // do a PrepareTiles? See crbug.com/689184. | 91 // do a PrepareTiles? See crbug.com/689184. |
| 83 ImageIdFlatSet pending_image_decodes_; | 92 ImageIdFlatSet pending_image_decodes_; |
| 84 | 93 |
| 85 // A set of images which have been decoded at least once from the | 94 // A map of ImageId to its permitted AsyncDecodeVetoState. |
|
vmpstr
2017/04/11 18:42:55
nit: s/permitted //
Khushal
2017/04/12 20:31:17
Done.
| |
| 86 // ImageDecodeService and should not be checkered again. | |
| 87 // TODO(khushalsagar): Limit the size of this set. | 95 // TODO(khushalsagar): Limit the size of this set. |
| 88 // TODO(khushalsagar): Plumb navigation changes here to reset this. See | 96 // TODO(khushalsagar): Plumb navigation changes here to reset this. See |
| 89 // crbug.com/693228. | 97 // crbug.com/693228. |
| 90 std::unordered_set<ImageId> images_decoded_once_; | 98 std::unordered_map<ImageId, AsyncDecodeVetoState> image_async_decode_state_; |
| 91 | 99 |
| 92 // A map of image id to image decode request id for images to be unlocked. | 100 // A map of image id to image decode request id for images to be unlocked. |
| 93 std::unordered_map<ImageId, ImageController::ImageDecodeRequestId> | 101 std::unordered_map<ImageId, ImageController::ImageDecodeRequestId> |
| 94 image_id_to_decode_request_id_; | 102 image_id_to_decode_request_id_; |
| 95 | 103 |
| 96 base::WeakPtrFactory<CheckerImageTracker> weak_factory_; | 104 base::WeakPtrFactory<CheckerImageTracker> weak_factory_; |
| 97 }; | 105 }; |
| 98 | 106 |
| 99 } // namespace cc | 107 } // namespace cc |
| 100 | 108 |
| 101 #endif // CC_TILES_CHECKER_IMAGE_TRACKER_H_ | 109 #endif // CC_TILES_CHECKER_IMAGE_TRACKER_H_ |
| OLD | NEW |