ivi-shell: support surface screen shot of ivi_layout by using weston_surface_copy_content
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>
This commit is contained in:
parent
e12a186ab0
commit
c3fd624e29
@ -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
|
||||
|
@ -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
|
||||
|
Loading…
Reference in New Issue
Block a user