#ifndef CC_RASTER_RASTER_SOURCE_H_
#define CC_RASTER_RASTER_SOURCE_H_
#include <stddef.h>
#include <memory>
#include <string>
#include <vector>
#include "base/containers/flat_map.h"
#include "base/memory/raw_ptr.h"
#include "base/memory/ref_counted.h"
#include "cc/cc_export.h"
#include "cc/debug/rendering_stats_instrumentation.h"
#include "cc/layers/recording_source.h"
#include "cc/paint/image_id.h"
#include "cc/paint/scroll_offset_map.h"
#include "gpu/command_buffer/client/raster_interface.h"
#include "third_party/skia/include/core/SkPicture.h"
#include "ui/gfx/color_space.h"
namespace base {
namespace trace_event {
class TracedValue;
}
}
namespace gfx {
class AxisTransform2d;
}
namespace cc {
class DisplayItemList;
class ImageProvider;
class CC_EXPORT RasterSource : public base::RefCountedThreadSafe<RasterSource> {
public:
struct CC_EXPORT PlaybackSettings {
PlaybackSettings();
PlaybackSettings(const PlaybackSettings&);
PlaybackSettings(PlaybackSettings&&);
~PlaybackSettings();
bool use_lcd_text = true;
int msaa_sample_count = 0;
bool visible = false;
float hdr_headroom = 0.f;
raw_ptr<ImageProvider> image_provider = nullptr;
raw_ptr<const ScrollOffsetMap> raster_inducing_scroll_offsets = nullptr;
};
RasterSource(const RasterSource&) = delete;
RasterSource& operator=(const RasterSource&) = delete;
void PlaybackToCanvas(SkCanvas* canvas,
const gfx::Size& content_size,
const gfx::Rect& canvas_bitmap_rect,
const gfx::Rect& canvas_playback_rect,
const gfx::AxisTransform2d& raster_transform,
const PlaybackSettings& settings) const;
bool PerformSolidColorAnalysis(gfx::Rect content_rect,
SkColor4f* color,
int max_ops_to_analyze = 1) const;
bool IsSolidColor() const;
SkColor4f GetSolidColor() const;
gfx::Size size() const { return size_; }
gfx::Size GetContentSize(const gfx::Vector2dF& content_scale) const;
bool IntersectsRect(const gfx::Rect& layer_rect) const;
bool HasRecordings() const;
gfx::Rect recorded_bounds() const {
return directly_composited_image_info_ ? gfx::Rect(size_)
: recorded_bounds_;
}
void DidBeginTracing();
void AsValueInto(base::trace_event::TracedValue* array) const;
const scoped_refptr<const DisplayItemList>& GetDisplayItemList() const {
return display_list_;
}
float recording_scale_factor() const { return recording_scale_factor_; }
SkColor4f background_color() const { return background_color_; }
bool requires_clear() const { return requires_clear_; }
size_t* max_op_size_hint() { return &max_op_size_hint_; }
const std::optional<DirectlyCompositedImageInfo>&
directly_composited_image_info() const {
return directly_composited_image_info_;
}
void set_debug_name(const std::string& name) { debug_name_ = name; }
const std::string& debug_name() const { return debug_name_; }
protected:
friend class RecordingSource;
friend class base::RefCountedThreadSafe<RasterSource>;
explicit RasterSource(const RecordingSource& other);
virtual ~RasterSource();
void ClearForOpaqueRaster(SkCanvas* raster_canvas,
const gfx::AxisTransform2d& raster_transform,
const gfx::Size& content_size,
const gfx::Rect& canvas_bitmap_rect,
const gfx::Rect& canvas_playback_rect) const;
virtual void PlaybackDisplayListToCanvas(
SkCanvas* canvas,
const PlaybackSettings& settings) const;
size_t max_op_size_hint_ =
gpu::raster::RasterInterface::kDefaultMaxOpSizeHint;
const scoped_refptr<const DisplayItemList> display_list_;
const SkColor4f background_color_;
const bool requires_clear_;
const bool is_solid_color_;
const SkColor4f solid_color_;
const gfx::Rect recorded_bounds_;
const gfx::Size size_;
const int slow_down_raster_scale_factor_for_debug_;
const float recording_scale_factor_;
std::optional<DirectlyCompositedImageInfo> directly_composited_image_info_;
std::string debug_name_;
};
}
#endif