ivi-shell: support surface screen shot of ivi_layout by using weston_surface_copy_content
authorNobuhiko Tanibata <NOBUHIKO_TANIBATA@xddp.denso.co.jp>
Mon, 20 Apr 2015 17:13:15 +0000 (02:13 +0900)
committerPekka Paalanen <pekka.paalanen@collabora.co.uk>
Tue, 21 Apr 2015 08:15:29 +0000 (11:15 +0300)
The reason why the result is not output in the method is that it avoids
to have dependency on CAIRO. If user want to output it to file, user
shall link CAIRO on its controller.

ivi_layout_surface_get_size is also supported here because user needs
stride to call ivi_layout_surafce_dump.

Signed-off-by: Nobuhiko Tanibata <NOBUHIKO_TANIBATA@xddp.denso.co.jp>
Reviewed-by: Pekka Paalanen <pekka.paalanen@collabora.co.uk>
ivi-shell/ivi-layout-export.h
ivi-shell/ivi-layout.c

index 8848fb1af5a3f7360f4df72f772de6709272088f..4b4328ca4fd4cbd87c9d0572cd22bfeea51a96c5 100644 (file)
@@ -768,6 +768,18 @@ struct ivi_controller_interface {
                                       uint32_t is_fade_in,
                                       double start_alpha, double end_alpha);
 
+       /**
+        * surface content dumping for debugging
+        */
+       int32_t (*surface_get_size)(struct ivi_layout_surface *ivisurf,
+                                   int32_t *width, int32_t *height,
+                                   int32_t *stride);
+
+       int32_t (*surface_dump)(struct weston_surface *surface,
+                               void *target, size_t size,
+                               int32_t x, int32_t y,
+                               int32_t width, int32_t height);
+
 };
 
 #ifdef __cplusplus
index cd4a171f3a09f443a4b911ec9c7e1d797c0c98d9..0c394a9d969cfd1851eee2132fa1005664c0da37 100644 (file)
@@ -2458,6 +2458,34 @@ ivi_layout_surface_get_weston_surface(struct ivi_layout_surface *ivisurf)
        return ivisurf != NULL ? ivisurf->surface : NULL;
 }
 
+static int32_t
+ivi_layout_surface_get_size(struct ivi_layout_surface *ivisurf,
+                           int32_t *width, int32_t *height,
+                           int32_t *stride)
+{
+       int32_t w;
+       int32_t h;
+       const size_t bytespp = 4; /* PIXMAN_a8b8g8r8 */
+
+       if (ivisurf == NULL || ivisurf->surface == NULL) {
+               weston_log("%s: invalid argument\n", __func__);
+               return IVI_FAILED;
+       }
+
+       weston_surface_get_content_size(ivisurf->surface, &w, &h);
+
+       if (width != NULL)
+               *width = w;
+
+       if (height != NULL)
+               *height = h;
+
+       if (stride != NULL)
+               *stride = w * bytespp;
+
+       return IVI_SUCCEEDED;
+}
+
 static int32_t
 ivi_layout_layer_add_notification(struct ivi_layout_layer *ivilayer,
                                  layer_property_notification_func callback,
@@ -2666,6 +2694,25 @@ ivi_layout_surface_set_transition(struct ivi_layout_surface *ivisurf,
        return 0;
 }
 
+static int32_t
+ivi_layout_surface_dump(struct weston_surface *surface,
+                       void *target, size_t size,int32_t x, int32_t y,
+                       int32_t width, int32_t height)
+{
+       int result = 0;
+
+       if (surface == NULL) {
+               weston_log("%s: invalid argument\n", __func__);
+               return IVI_FAILED;
+       }
+
+       result = weston_surface_copy_content(
+               surface, target, size,
+               x, y, width, height);
+
+       return result == 0 ? IVI_SUCCEEDED : IVI_FAILED;
+}
+
 /**
  * methods of interaction between ivi-shell with ivi-layout
  */
@@ -2930,7 +2977,13 @@ static struct ivi_controller_interface ivi_controller_interface = {
         * animation
         */
        .transition_move_layer_cancel   = ivi_layout_transition_move_layer_cancel,
-       .layer_set_fade_info            = ivi_layout_layer_set_fade_info
+       .layer_set_fade_info            = ivi_layout_layer_set_fade_info,
+
+       /**
+        * surface content dumping for debugging
+        */
+       .surface_get_size               = ivi_layout_surface_get_size,
+       .surface_dump                   = ivi_layout_surface_dump,
 };
 
 int