mirror of
https://github.com/thorvg/thorvg.git
synced 2025-06-14 12:04:29 +00:00
gl_engine: add support for stroke/fill ordering
This commit is contained in:
parent
97f85d44cb
commit
758aa932d7
1 changed files with 26 additions and 15 deletions
|
@ -1093,24 +1093,35 @@ bool GlRenderer::renderShape(RenderData data)
|
||||||
|
|
||||||
if (flags & (RenderUpdateFlag::Stroke | RenderUpdateFlag::GradientStroke)) drawDepth2 = currentPass()->nextDrawDepth();
|
if (flags & (RenderUpdateFlag::Stroke | RenderUpdateFlag::GradientStroke)) drawDepth2 = currentPass()->nextDrawDepth();
|
||||||
|
|
||||||
|
|
||||||
if (!sdata->clips.empty()) drawClip(sdata->clips);
|
if (!sdata->clips.empty()) drawClip(sdata->clips);
|
||||||
|
|
||||||
if (flags & (RenderUpdateFlag::Color | RenderUpdateFlag::Gradient))
|
auto processFill = [&]() {
|
||||||
{
|
if (flags & (RenderUpdateFlag::Color | RenderUpdateFlag::Gradient)) {
|
||||||
auto gradient = sdata->rshape->fill;
|
if (const auto& gradient = sdata->rshape->fill) {
|
||||||
if (gradient) drawPrimitive(*sdata, gradient, RenderUpdateFlag::Gradient, drawDepth1);
|
drawPrimitive(*sdata, gradient, RenderUpdateFlag::Gradient, drawDepth1);
|
||||||
else if (sdata->rshape->color.a > 0) drawPrimitive(*sdata, sdata->rshape->color, RenderUpdateFlag::Color, drawDepth1);
|
} else if (sdata->rshape->color.a > 0) {
|
||||||
}
|
drawPrimitive(*sdata, sdata->rshape->color, RenderUpdateFlag::Color, drawDepth1);
|
||||||
|
}
|
||||||
if (flags & (RenderUpdateFlag::Stroke | RenderUpdateFlag::GradientStroke))
|
|
||||||
{
|
|
||||||
auto gradient = sdata->rshape->strokeFill();
|
|
||||||
if (gradient) {
|
|
||||||
drawPrimitive(*sdata, gradient, RenderUpdateFlag::GradientStroke, drawDepth2);
|
|
||||||
} else if (sdata->rshape->stroke && sdata->rshape->stroke->color.a > 0) {
|
|
||||||
drawPrimitive(*sdata, sdata->rshape->stroke->color, RenderUpdateFlag::Stroke, drawDepth2);
|
|
||||||
}
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
auto processStroke = [&]() {
|
||||||
|
if (!sdata->rshape->stroke) return;
|
||||||
|
if (flags & (RenderUpdateFlag::Stroke | RenderUpdateFlag::GradientStroke)) {
|
||||||
|
if (const auto& gradient = sdata->rshape->strokeFill()) {
|
||||||
|
drawPrimitive(*sdata, gradient, RenderUpdateFlag::GradientStroke, drawDepth2);
|
||||||
|
} else if (sdata->rshape->stroke->color.a > 0) {
|
||||||
|
drawPrimitive(*sdata, sdata->rshape->stroke->color, RenderUpdateFlag::Stroke, drawDepth2);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
if (sdata->rshape->stroke && sdata->rshape->stroke->strokeFirst) {
|
||||||
|
processStroke();
|
||||||
|
processFill();
|
||||||
|
} else {
|
||||||
|
processFill();
|
||||||
|
processStroke();
|
||||||
}
|
}
|
||||||
|
|
||||||
return true;
|
return true;
|
||||||
|
|
Loading…
Add table
Reference in a new issue