#ifndef CC_LAYERS_PICTURE_LAYER_IMPL_H_
#define CC_LAYERS_PICTURE_LAYER_IMPL_H_
#include <stddef.h>
#include <algorithm>
#include <map>
#include <memory>
#include <set>
#include <string>
#include <vector>
#include "base/containers/flat_set.h"
#include "base/memory/ptr_util.h"
#include "base/memory/raw_ptr.h"
#include "base/memory/raw_ptr_exclusion.h"
#include "cc/cc_export.h"
#include "cc/layers/layer.h"
#include "cc/layers/tile_based_layer_impl.h"
#include "cc/layers/tile_size_calculator.h"
#include "cc/paint/discardable_image_map.h"
#include "cc/paint/image_id.h"
#include "cc/raster/lcd_text_disallowed_reason.h"
#include "cc/tiles/picture_layer_tiling.h"
#include "cc/tiles/picture_layer_tiling_set.h"
#include "cc/tiles/tile_index.h"
#include "cc/tiles/tile_priority.h"
#include "cc/tiles/tiling_set_eviction_queue.h"
#include "cc/trees/image_animation_controller.h"
namespace cc {
class AppendQuadsData;
class MicroBenchmarkImpl;
class Tile;
class CC_EXPORT PictureLayerImpl
: public TileBasedLayerImpl<PictureLayerTiling>,
public PictureLayerTilingClient,
public ImageAnimationController::AnimationDriver {
public:
static std::unique_ptr<PictureLayerImpl> Create(LayerTreeImpl* tree_impl,
int id) {
return base::WrapUnique(new PictureLayerImpl(tree_impl, id));
}
PictureLayerImpl(const PictureLayerImpl&) = delete;
~PictureLayerImpl() override;
PictureLayerImpl& operator=(const PictureLayerImpl&) = delete;
mojom::LayerType GetLayerType() const override;
std::unique_ptr<LayerImpl> CreateLayerImpl(
LayerTreeImpl* tree_impl) const override;
void PushPropertiesTo(LayerImpl* layer) override;
void NotifyTileStateChanged(const Tile* tile, bool update_damage) override;
gfx::Rect GetDamageRect() const override;
void ResetChangeTracking() override;
void ResetRasterScale();
void DidBeginTracing() override;
void ReleaseResources() override;
void ReleaseTileResources() override;
void RecreateTileResources() override;
Region GetInvalidationRegionForDebugging() override;
gfx::Rect GetEnclosingVisibleRectInTargetSpace() const override;
gfx::ContentColorUsage GetContentColorUsage() const override;
DamageReasonSet GetDamageReasons() const override;
std::unique_ptr<Tile> CreateTile(const Tile::CreateInfo& info) override;
gfx::Size CalculateTileSize(const gfx::Size& content_bounds) override;
const Region* GetPendingInvalidation() override;
const PictureLayerTiling* GetPendingOrActiveTwinTiling(
const PictureLayerTiling* tiling) const override;
bool HasValidTilePriorities() const override;
bool RequiresHighResToDraw() const override;
const PaintWorkletRecordMap& GetPaintWorkletRecords() const override;
std::vector<const DrawImage*> GetDiscardableImagesInRect(
const gfx::Rect& rect) const override;
ScrollOffsetMap GetRasterInducingScrollOffsets() const override;
const GlobalStateThatImpactsTilePriority& global_tile_state() const override;
bool ShouldAnimate(PaintImage::Id paint_image_id) const override;
void set_gpu_raster_max_texture_size(gfx::Size gpu_raster_max_texture_size) {
if (gpu_raster_max_texture_size_ == gpu_raster_max_texture_size) {
return;
}
gpu_raster_max_texture_size_ = gpu_raster_max_texture_size;
SetNeedsPushProperties();
}
gfx::Size gpu_raster_max_texture_size() {
return gpu_raster_max_texture_size_;
}
void UpdateRasterSource(scoped_refptr<RasterSource> raster_source,
Region* new_invalidation);
void SetRasterSourceForTesting(scoped_refptr<RasterSource> raster_source,
const Region& invalidation = Region());
void RegenerateDiscardableImageMap();
bool UpdateTiles();
void GetContentsResourceId(viz::ResourceId* resource_id,
gfx::Size* resource_size,
gfx::SizeF* resource_uv_size) const override;
size_t GPUMemoryUsageInBytes() const override;
void RunMicroBenchmark(MicroBenchmarkImpl* benchmark) override;
bool CanHaveTilings() const;
PictureLayerTilingSet* picture_layer_tiling_set() { return tilings_.get(); }
PictureLayerImpl* GetPendingOrActiveTwinLayer() const;
bool IsOnActiveOrPendingTree() const;
RasterSource* GetRasterSource() const { return raster_source_.get(); }
enum class ImageInvalidationResult {
kNoImages,
kNoInvalidation,
kInvalidated,
};
ImageInvalidationResult InvalidateRegionForImages(
const PaintImageIdFlatSet& images_to_invalidate);
void InvalidateRasterInducingScrolls(
const base::flat_set<ElementId>& scrolls_to_invalidate);
bool can_use_lcd_text() const {
return lcd_text_disallowed_reason_ == LCDTextDisallowedReason::kNone;
}
LCDTextDisallowedReason lcd_text_disallowed_reason() const {
return lcd_text_disallowed_reason_;
}
LCDTextDisallowedReason ComputeLCDTextDisallowedReasonForTesting() const;
const Region& InvalidationForTesting() const { return invalidation_; }
void SetPaintWorkletRecord(scoped_refptr<const PaintWorkletInput>,
PaintRecord);
const PaintWorkletRecordMap& GetPaintWorkletRecordMap() const {
return paint_worklet_records_;
}
void InvalidatePaintWorklets(const PaintWorkletInput::PropertyKey& key,
const PaintWorkletInput::PropertyValue& prev,
const PaintWorkletInput::PropertyValue& next);
void set_has_non_animated_image_update_rect() {
has_non_animated_image_update_rect_ = true;
}
using TileUpdateSet = std::map<float, std::set<TileIndex>>;
TileUpdateSet TakeUpdatedTiles();
std::vector<float> TakeProposedTilingScalesForDeletion();
TileUpdateSet TakeAllTiles();
bool IsDirectlyCompositedImage() const override;
bool nearest_neighbor() const { return nearest_neighbor_; }
void set_should_batch_updated_tiles() { should_batch_updated_tiles_ = true; }
bool should_batch_updated_tiles() const {
return should_batch_updated_tiles_;
}
void SetRasterContentsScaleForTesting(float scale) {
raster_contents_scale_ = gfx::Vector2dF(scale, scale);
}
std::vector<raw_ptr<PictureLayerTiling, VectorExperimental>>&
GetLastAppendQuadsTilingsForTesting() {
return last_append_quads_tilings_;
}
void ClearLastAppendQuadsTilingsForTesting() {
last_append_quads_tilings_.clear();
}
protected:
friend class RasterizeAndRecordBenchmarkImpl;
PictureLayerImpl(LayerTreeImpl* tree_impl, int id);
PictureLayerTiling* AddTiling(const gfx::AxisTransform2d& contents_transform);
void RemoveAllTilings();
bool CanRecreateHighResTilingForLCDTextAndRasterTransform(
const PictureLayerTiling& high_res) const;
void UpdateTilingsForRasterScaleAndTranslation(bool adjusted_raster_scale);
bool ShouldAdjustRasterScale() const;
void RecalculateRasterScales();
void AdjustRasterScaleForTransformAnimation(
const gfx::Vector2dF& preserved_raster_contents_scale);
float MinimumRasterContentsScaleForWillChangeTransform() const;
bool CalculateRasterTranslation(gfx::Vector2dF& raster_translation) const;
void CleanUpTilingsOnActiveLayer();
float MinimumContentsScale() const;
float MaximumContentsScale() const;
void UpdateViewportRectForTilePriorityInContentSpace();
PictureLayerImpl* GetRecycledTwinLayer() const;
bool ShouldDirectlyCompositeImage(float raster_scale) const;
float CalculateDirectlyCompositedImageRasterScale() const;
void UpdateRasterSourceInternal(
scoped_refptr<RasterSource> raster_source,
Region* new_invalidation,
const PictureLayerTilingSet* pending_set,
const PaintWorkletRecordMap* pending_paint_worklet_records,
const DiscardableImageMap* pending_discardable_image_map);
void UpdateDirectlyCompositedImageFromRasterSource();
void SanityCheckTilingState() const;
void GetDebugBorderProperties(SkColor4f* color, float* width) const override;
void GetAllPrioritizedTilesForTracing(
std::vector<PrioritizedTile>* prioritized_tiles) const override;
void AsValueInto(base::trace_event::TracedValue* dict) const override;
void UpdateIdealScales();
float MaximumTilingContentsScale() const;
std::unique_ptr<PictureLayerTilingSet> CreatePictureLayerTilingSet();
void RegisterAnimatedImages();
void UnregisterAnimatedImages();
void SetPaintWorkletInputs(
const DiscardableImageMap::PaintWorkletInputs& inputs);
LCDTextDisallowedReason ComputeLCDTextDisallowedReason(
bool raster_translation_aligns_pixels) const;
void UpdateCanUseLCDText(bool raster_translation_aligns_pixels);
bool AffectedByWillChangeTransformHint() const;
RAW_PTR_EXCLUSION PictureLayerImpl* twin_layer_ = nullptr;
TileUpdateSet updated_tiles_;
base::flat_set<float> proposed_tiling_scales_for_deletion_;
bool should_batch_updated_tiles_ = true;
std::unique_ptr<PictureLayerTilingSet> tilings_ =
CreatePictureLayerTilingSet();
scoped_refptr<RasterSource> raster_source_;
Region invalidation_;
scoped_refptr<const DiscardableImageMap> discardable_image_map_;
float ideal_page_scale_ = 0.f;
float ideal_device_scale_ = 0.f;
gfx::Vector2dF ideal_source_scale_;
gfx::Vector2dF ideal_contents_scale_;
float raster_page_scale_ = 0.f;
float raster_device_scale_ = 0.f;
gfx::Vector2dF raster_source_scale_;
gfx::Vector2dF raster_contents_scale_;
float ideal_source_scale_key() const {
return std::max(ideal_source_scale_.x(), ideal_source_scale_.y());
}
float GetIdealContentsScaleKey() const override;
float raster_source_scale_key() const {
return std::max(raster_source_scale_.x(), raster_source_scale_.y());
}
float raster_contents_scale_key() const {
return std::max(raster_contents_scale_.x(), raster_contents_scale_.y());
}
bool was_screen_space_transform_animating_ : 1 = false;
bool produced_tile_last_append_quads_ : 1 = true;
bool nearest_neighbor_ : 1 = false;
bool raster_source_size_changed_ : 1 = false;
bool directly_composited_image_default_raster_scale_changed_ : 1 = false;
bool has_animated_image_update_rect_ : 1 = false;
bool has_non_animated_image_update_rect_ : 1 = false;
LCDTextDisallowedReason lcd_text_disallowed_reason_ =
LCDTextDisallowedReason::kNoText;
public:
void CleanUpTilings(const std::vector<float>& tiling_scales_to_clean_up);
protected:
float directly_composited_image_default_raster_scale_ = 0;
gfx::Rect viewport_rect_for_tile_priority_in_content_space_;
gfx::Size gpu_raster_max_texture_size_;
std::vector<raw_ptr<PictureLayerTiling, VectorExperimental>>
last_append_quads_tilings_;
PaintWorkletRecordMap paint_worklet_records_;
TileSizeCalculator tile_size_calculator_{this};
gfx::Rect damage_rect_;
private:
void AppendQuadsSpecialization(const AppendQuadsContext& context,
viz::CompositorRenderPass* render_pass,
AppendQuadsData* append_quads_data,
viz::SharedQuadState* shared_quad_state,
const Occlusion& scaled_occlusion,
const gfx::Vector2d& quad_offset) override;
float GetMaximumContentsScaleForUseInAppendQuads() override;
void AppendQuadsForResourcelessSoftwareDraw(
const AppendQuadsContext& context,
viz::CompositorRenderPass* render_pass,
AppendQuadsData* append_quads_data,
viz::SharedQuadState* shared_quad_state,
const Occlusion& scaled_occlusion) override;
TilingSetCoverageIterator<PictureLayerTiling> Cover(
const gfx::Rect& coverage_rect,
float coverage_scale,
float ideal_contents_scale) override;
TilingResolution GetTilingResolutionForDebugBorders(
const PictureLayerTiling* tiling) const override;
};
}
#endif