[skottie] Harden motion blur
1) don't attempt to attach the effect when the layer is null 2) sksg::onRender can receive a null context - handle it gracefully TBR= Change-Id: I4fae08b15d448849c7c99b17df6811ad31f190c8 Reviewed-on: https://skia-review.googlesource.com/c/skia/+/237276 Reviewed-by: Florin Malita <fmalita@chromium.org> Commit-Queue: Florin Malita <fmalita@chromium.org>
This commit is contained in:
parent
30cd12e814
commit
3c8f9cb45d
@ -496,7 +496,7 @@ sk_sp<sksg::RenderNode> AnimationBuilder::attachLayer(const skjson::ObjectValue*
|
||||
layer_info.fOutPoint);
|
||||
|
||||
// Optional motion blur.
|
||||
if (has_animators && layerCtx->hasMotionBlur(*jlayer)) {
|
||||
if (layer && has_animators && layerCtx->hasMotionBlur(*jlayer)) {
|
||||
SkASSERT(layerCtx->fMotionBlurAngle >= 0);
|
||||
|
||||
// Wrap both the layer node and the controller.
|
||||
|
@ -88,7 +88,7 @@ void MotionBlurEffect::onRender(SkCanvas* canvas, const RenderContext* ctx) cons
|
||||
ScopedRenderContext frame_ctx(canvas, ctx);
|
||||
SkPaint frame_paint;
|
||||
|
||||
const auto isolate_frames = ctx->fBlendMode != SkBlendMode::kSrcOver;
|
||||
const auto isolate_frames = frame_ctx->fBlendMode != SkBlendMode::kSrcOver;
|
||||
if (isolate_frames) {
|
||||
frame_paint.setAlphaf(frame_alpha);
|
||||
frame_paint.setBlendMode(SkBlendMode::kPlus);
|
||||
|
@ -84,6 +84,7 @@ protected:
|
||||
}
|
||||
|
||||
operator const RenderContext* () const { return &fCtx; }
|
||||
const RenderContext* operator->() const { return &fCtx; }
|
||||
|
||||
// Add (cumulative) paint overrides to a render node sub-DAG.
|
||||
ScopedRenderContext&& modulateOpacity(float opacity);
|
||||
|
Loading…
Reference in New Issue
Block a user