video: A composite object for video client has to be punched if it's laid above main... 45/207745/2
authorSeunghun Lee <shiin.lee@samsung.com>
Tue, 14 May 2019 06:44:19 +0000 (15:44 +0900)
committerSooChan Lim <sc1.lim@samsung.com>
Wed, 12 Jun 2019 07:23:32 +0000 (07:23 +0000)
Otherwise, Video contents which is displayed through underlay would not
be displayed on screen, because underlay is possibly covered with contents of
primary plane.

Change-Id: I31359e93936eb161ee7063fdcac122ed4e5154a9

src/bin/video/iface/e_video_hwc.c

index f9df1ecb142b209fca580603db5ce6759847990d..40eaedf3a10f21cde52a733dd2de0eacb18a296d 100644 (file)
@@ -1639,35 +1639,36 @@ e_video_hwc_client_mask_update(E_Video_Hwc *evh)
    int bw, bh;
 
    if (e_video_debug_punch_value_get())
-     {
-        punch = EINA_TRUE;
-        goto end;
-     }
-
-   topmost = e_comp_wl_topmost_parent_get(evh->ec);
-   if (topmost && topmost->argb)
-     {
-        /* FIXME: the mask obj can be drawn at the wrong position in the beginnig
-         * time. It happens caused by window manager policy.
-         */
-        if ((topmost->fullscreen || topmost->maximized) &&
-            (evh->geo.output_r.x == 0 || evh->geo.output_r.y == 0))
+     punch = EINA_TRUE;
+   else if ((topmost = e_comp_wl_topmost_parent_get(evh->ec)))
+     {
+        /* if it's laid above main surface */
+        if (eina_list_data_find(topmost->comp_data->sub.list, evh->ec))
+          punch = EINA_TRUE;
+        /* if it's laid under main surface and main surface is transparent */
+        else if (topmost->argb)
           {
-             e_pixmap_size_get(topmost->pixmap, &bw, &bh);
-
-             if (bw > 100 && bh > 100 &&
-                 evh->geo.output_r.w < 100 && evh->geo.output_r.h < 100)
+             /* FIXME: the mask obj can be drawn at the wrong position in the beginnig
+              * time. It happens caused by window manager policy.
+              */
+             if ((topmost->fullscreen || topmost->maximized) &&
+                 (evh->geo.output_r.x == 0 || evh->geo.output_r.y == 0))
                {
-                  VIN("don't punch. (%dx%d, %dx%d)", evh->ec,
-                      bw, bh, evh->geo.output_r.w, evh->geo.output_r.h);
-                  return;
+                  e_pixmap_size_get(topmost->pixmap, &bw, &bh);
+
+                  if (bw > 100 && bh > 100 &&
+                      evh->geo.output_r.w < 100 && evh->geo.output_r.h < 100)
+                    {
+                       VIN("don't punch. (%dx%d, %dx%d)", evh->ec,
+                           bw, bh, evh->geo.output_r.w, evh->geo.output_r.h);
+                       return;
+                    }
                }
-          }
 
-        punch = EINA_TRUE;
+             punch = EINA_TRUE;
+          }
      }
 
-end:
    if (punch)
      {
         if (!e_comp_object_mask_has(evh->ec->frame))