27 tile_mode_ = tile_mode;
31 colors_ = std::move(colors);
35 stops_ = std::move(stops);
50 for (
auto color : colors_) {
51 if (!color.IsOpaque()) {
58 #define ARRAY_LEN(a) (sizeof(a) / sizeof(a[0]))
59 #define UNIFORM_FRAG_INFO(t) \
60 t##GradientUniformFillPipeline::FragmentShader::FragInfo
61 #define UNIFORM_COLOR_SIZE ARRAY_LEN(UNIFORM_FRAG_INFO(Radial)::colors)
62 #define UNIFORM_STOP_SIZE ARRAY_LEN(UNIFORM_FRAG_INFO(Radial)::stop_pairs)
70 return RenderSSBO(renderer, entity, pass);
74 return RenderUniform(renderer, entity, pass);
76 return RenderTexture(renderer, entity, pass);
79 bool RadialGradientContents::RenderSSBO(
const ContentContext& renderer,
85 VS::FrameInfo frame_info;
92 return ColorSourceContents::DrawGeometry<VS>(
93 renderer, entity, pass, pipeline_callback, frame_info,
94 [
this, &renderer, &entity](RenderPass& pass) {
95 FS::FragInfo frag_info;
96 frag_info.center = center_;
97 frag_info.radius = radius_;
98 frag_info.tile_mode =
static_cast<Scalar>(tile_mode_);
99 frag_info.decal_border_color = decal_border_color_;
107 frag_info.colors_length = colors.size();
108 auto color_buffer = data_host_buffer.Emplace(
109 colors.data(), colors.size() *
sizeof(StopData),
110 data_host_buffer.GetMinimumUniformAlignment());
112 pass.SetCommandLabel(
"RadialGradientSSBOFill");
113 FS::BindFragInfo(pass, data_host_buffer.EmplaceUniform(frag_info));
114 FS::BindColorData(pass, color_buffer);
120 bool RadialGradientContents::RenderUniform(
const ContentContext& renderer,
121 const Entity& entity,
122 RenderPass& pass)
const {
126 VS::FrameInfo frame_info;
130 [&renderer](ContentContextOptions options) {
131 return renderer.GetRadialGradientUniformFillPipeline(options);
133 return ColorSourceContents::DrawGeometry<VS>(
134 renderer, entity, pass, pipeline_callback, frame_info,
135 [
this, &renderer, &entity](RenderPass& pass) {
136 FS::FragInfo frag_info;
137 frag_info.center = center_;
138 frag_info.radius = radius_;
139 frag_info.tile_mode =
static_cast<Scalar>(tile_mode_);
144 colors_, stops_, frag_info.colors, frag_info.stop_pairs);
145 frag_info.decal_border_color = decal_border_color_;
147 pass.SetCommandLabel(
"RadialGradientUniformFill");
150 pass, renderer.GetTransientsDataBuffer().EmplaceUniform(frag_info));
156 bool RadialGradientContents::RenderTexture(
const ContentContext& renderer,
157 const Entity& entity,
158 RenderPass& pass)
const {
163 auto gradient_texture =
165 if (gradient_texture ==
nullptr) {
169 VS::FrameInfo frame_info;
173 [&renderer](ContentContextOptions options) {
174 return renderer.GetRadialGradientFillPipeline(options);
176 return ColorSourceContents::DrawGeometry<VS>(
177 renderer, entity, pass, pipeline_callback, frame_info,
178 [
this, &renderer, &gradient_texture, &entity](RenderPass& pass) {
179 FS::FragInfo frag_info;
180 frag_info.center = center_;
181 frag_info.radius = radius_;
182 frag_info.tile_mode =
static_cast<Scalar>(tile_mode_);
183 frag_info.decal_border_color = decal_border_color_;
184 frag_info.texture_sampler_y_coord_scale =
185 gradient_texture->GetYCoordScale();
189 frag_info.half_texel =
190 Vector2(0.5 / gradient_texture->GetSize().width,
191 0.5 / gradient_texture->GetSize().height);
193 SamplerDescriptor sampler_desc;
197 pass.SetCommandLabel(
"RadialGradientFill");
200 pass, renderer.GetTransientsDataBuffer().EmplaceUniform(frag_info));
201 FS::BindTextureSampler(
202 pass, gradient_texture,
203 renderer.GetContext()->GetSamplerLibrary()->GetSampler(
212 for (
Color& color : colors_) {
213 color = color_filter_proc(color);
215 decal_border_color_ = color_filter_proc(decal_border_color_);
virtual bool SupportsSSBO() const =0
Whether the context backend supports binding Shader Storage Buffer Objects (SSBOs) to pipelines.
const Geometry * GetGeometry() const
Get the geometry that this contents will use to render.
Scalar GetOpacityFactor() const
Get the opacity factor for this color source.
bool AppliesAlphaForStrokeCoverage(const Matrix &transform) const
Whether the entity should be treated as non-opaque due to stroke geometry requiring alpha for coverag...
const Matrix & GetInverseEffectTransform() const
Set the inverted effect transform for this color source.
std::function< PipelineRef(ContentContextOptions)> PipelineBuilderCallback
const Capabilities & GetDeviceCapabilities() const
PipelineRef GetRadialGradientSSBOFillPipeline(ContentContextOptions opts) const
HostBuffer & GetTransientsDataBuffer() const
Retrieve the current host buffer for transient storage of other non-index data.
std::function< Color(Color)> ColorFilterProc
const Matrix & GetTransform() const
Get the global transform matrix for this Entity.
virtual Scalar ComputeAlphaCoverage(const Matrix &transform) const
bool IsOpaque(const Matrix &transform) const override
Whether this Contents only emits opaque source colors from the fragment stage. This value does not ac...
void SetTileMode(Entity::TileMode tile_mode)
~RadialGradientContents() override
bool Render(const ContentContext &renderer, const Entity &entity, RenderPass &pass) const override
void SetCenterAndRadius(Point center, Scalar radius)
void SetStops(std::vector< Scalar > stops)
bool ApplyColorFilter(const ColorFilterProc &color_filter_proc) override
If possible, applies a color filter to this contents inputs on the CPU.
void SetColors(std::vector< Color > colors)
const std::vector< Scalar > & GetStops() const
const std::vector< Color > & GetColors() const
Render passes encode render commands directed as one specific render target into an underlying comman...
VertexShader_ VertexShader
FragmentShader_ FragmentShader
LinePipeline::FragmentShader FS
int PopulateUniformGradientColors(const std::vector< Color > &colors, const std::vector< Scalar > &stops, Vector4 frag_info_colors[kMaxUniformGradientStops], Vector4 frag_info_stop_pairs[kMaxUniformGradientStops/2])
Populate 2 arrays with the colors and stop data for a gradient.
std::vector< StopData > CreateGradientColors(const std::vector< Color > &colors, const std::vector< Scalar > &stops)
Populate a vector with the color and stop data for a gradient.
LinePipeline::VertexShader VS
std::shared_ptr< Texture > CreateGradientTexture(const GradientData &gradient_data, const std::shared_ptr< impeller::Context > &context)
Create a host visible texture that contains the gradient defined by the provided gradient data.
GradientData CreateGradientBuffer(const std::vector< Color > &colors, const std::vector< Scalar > &stops)
Populate a vector with the interpolated color bytes for the linear gradient described by colors and s...
static constexpr uint32_t kMaxUniformGradientStops
#define UNIFORM_STOP_SIZE
#define UNIFORM_COLOR_SIZE
A 4x4 matrix using column-major storage.