From: Shinwoo Kim Date: Thu, 17 Sep 2020 01:40:24 +0000 (+0900) Subject: evas vg: check object changed as well 2 X-Git-Tag: accepted/tizen/unified/20200923.024030~5 X-Git-Url: http://review.tizen.org/git/?a=commitdiff_plain;h=68145cae65a3ec8406d2fb82766d721bed45a5ff;p=platform%2Fupstream%2Fefl.git evas vg: check object changed as well 2 Summary: evas cannot render vg object if Efl_Canvas_Vg_Node_Data flag is not EFL_GFX_CHANGE_FLAG_NONE and Evas_Object_Protected_Data.changed is FALSE, when vg object marks its node as changed. Above case could be possible if vg object render_pre is not called, and only nd->vd->obj->changed is set to false by evas_object_change_reset. Reviewers: Hermet, jsuya, herb Reviewed By: Hermet Subscribers: cedric, #reviewers, #committers Tags: #efl Differential Revision: https://phab.enlightenment.org/D12142 Change-Id: I628b3596c282354005ae2a36209460d68bb43c01 --- diff --git a/src/lib/evas/canvas/efl_canvas_vg_node.c b/src/lib/evas/canvas/efl_canvas_vg_node.c index a076136..f2bead5 100644 --- a/src/lib/evas/canvas/efl_canvas_vg_node.c +++ b/src/lib/evas/canvas/efl_canvas_vg_node.c @@ -19,7 +19,15 @@ static const Efl_Canvas_Vg_Interpolation interpolation_identity = { static void _node_change(Efl_VG *obj, Efl_Canvas_Vg_Node_Data *nd) { - if (!nd || nd->flags != EFL_GFX_CHANGE_FLAG_NONE) return; + if (!nd) return; + if (nd->flags != EFL_GFX_CHANGE_FLAG_NONE) + { + if ((nd->vd && nd->vd->obj) && + (!nd->vd->obj || !nd->vd->obj->changed)) + efl_canvas_vg_object_change(nd->vd); + + return; + } nd->flags = EFL_GFX_CHANGE_FLAG_ALL; Eo *p = obj;