}
static bool
-desktop_surface_check_last_remote_surfaces(struct ivi_compositor *ivi, enum ivi_surface_role role)
+desktop_surface_check_last_surfaces(struct ivi_output *ivi_output, enum ivi_surface_role role)
{
int count = 0;
struct ivi_surface *surf;
- wl_list_for_each(surf, &ivi->surfaces, link)
- if (surf->role == role)
+ wl_list_for_each(surf, &ivi_output->ivi->surfaces, link)
+ if (surf->role == role &&
+ surf->current_completed_output == ivi_output)
count++;
return (count == 1);
/* check if there's a last 'remote' surface and insert a black
* surface view if there's no background set for that output
*/
- if (desktop_surface_check_last_remote_surfaces(output->ivi, IVI_SURFACE_ROLE_REMOTE) ||
- desktop_surface_check_last_remote_surfaces(output->ivi, IVI_SURFACE_ROLE_DESKTOP))
+ if (desktop_surface_check_last_surfaces(output, IVI_SURFACE_ROLE_REMOTE) ||
+ desktop_surface_check_last_surfaces(output, IVI_SURFACE_ROLE_DESKTOP))
if (!output->background)
- insert_black_surface(output);
+ insert_black_curtain(output);
if (weston_surface_is_mapped(wsurface)) {
struct weston_desktop_surface *dsurface;
struct weston_view *view;
struct ivi_output *hidden_layer_output;
+ struct ivi_output *current_completed_output;
struct wl_list link;
int focus_count;
ivi_layout_get_output_from_surface(struct ivi_surface *surf);
void
-insert_black_surface(struct ivi_output *output);
+insert_black_curtain(struct ivi_output *output);
void
-remove_black_surface(struct ivi_output *output);
+remove_black_curtain(struct ivi_output *output);
+
+bool
+output_has_black_curtain(struct ivi_output *output);
const char *
ivi_layout_get_surface_role_name(struct ivi_surface *surf);
weston_view_update_transform(view);
}
+ if (output_has_black_curtain(output)) {
+ if (!output->background) {
+ weston_log("Found that we have no background surface "
+ "for output %s. Using black curtain as background\n",
+ output->output->name);
+
+ struct weston_view *ev =
+ output->fullscreen_view.fs->view;
+
+ /* use the black curtain as background when we have
+ * none added by the shell client. */
+ weston_layer_entry_remove(&ev->layer_link);
+ weston_layer_entry_insert(&ivi->normal.view_list,
+ &ev->layer_link);
+ weston_view_geometry_dirty(ev);
+ weston_surface_damage(ev->surface);
+ } else {
+ remove_black_curtain(output);
+ }
+ }
+
+
weston_view_set_output(view, woutput);
weston_view_set_position(view,
woutput->x + output->area.x,
}
output->previous_active = output->active;
output->active = surf;
+ surf->current_completed_output = output;
weston_layer_entry_insert(&ivi->normal.view_list, &view->layer_link);
weston_view_geometry_dirty(view);
if (r_output) {
struct weston_view *view = r_output->fullscreen_view.fs->view;
if (view->is_mapped || view->surface->is_mapped)
- remove_black_surface(r_output);
+ remove_black_curtain(r_output);
}
#endif
static void
-create_black_surface_view(struct ivi_output *output);
+create_black_curtain_view(struct ivi_output *output);
void
agl_shell_desktop_advertise_application_id(struct ivi_compositor *ivi,
* just being added */
view = output->fullscreen_view.fs->view;
if (view->is_mapped || view->surface->is_mapped)
- remove_black_surface(output);
+ remove_black_curtain(output);
if (output->type == OUTPUT_WALTHAM)
ivi_output_notify_waltham_plugin(surface);
struct ivi_output *out;
wl_list_for_each(out, &ivi->outputs, link) {
- create_black_surface_view(out);
- insert_black_surface(out);
+ create_black_curtain_view(out);
+ insert_black_curtain(out);
}
}
}
static void
-destroy_black_view(struct wl_listener *listener, void *data)
+destroy_black_curtain_view(struct wl_listener *listener, void *data)
{
struct fullscreen_view *fs =
wl_container_of(listener, fs, fs_destroy);
static void
-create_black_surface_view(struct ivi_output *output)
+create_black_curtain_view(struct ivi_output *output)
{
struct weston_surface *surface = NULL;
struct weston_view *view;
}
output->fullscreen_view.fs->view = view;
- output->fullscreen_view.fs_destroy.notify = destroy_black_view;
+ output->fullscreen_view.fs_destroy.notify = destroy_black_curtain_view;
wl_signal_add(&woutput->destroy_signal,
&output->fullscreen_view.fs_destroy);
}
+bool
+output_has_black_curtain(struct ivi_output *output)
+{
+ return (output->fullscreen_view.fs->view &&
+ output->fullscreen_view.fs->view->is_mapped &&
+ output->fullscreen_view.fs->view->surface->is_mapped);
+}
+
void
-remove_black_surface(struct ivi_output *output)
+remove_black_curtain(struct ivi_output *output)
{
struct weston_view *view;
weston_view_update_transform(view);
weston_view_damage_below(view);
+
+ weston_log("Removed black curtain from output %s\n", output->output->name);
}
void
-insert_black_surface(struct ivi_output *output)
+insert_black_curtain(struct ivi_output *output)
{
struct weston_view *view;
weston_view_update_transform(view);
weston_view_damage_below(view);
+
+ weston_log("Added black curtain to output %s\n", output->output->name);
}
static void
wl_list_for_each(output, &ivi->outputs, link) {
if (output->background)
- remove_black_surface(output);
+ remove_black_curtain(output);
ivi_layout_init(ivi, output);
}
output->active = NULL;
}
- insert_black_surface(output);
+ insert_black_curtain(output);
}
wl_list_for_each_safe(surf, surf_tmp, &ivi->surfaces, link) {