fixed problem with next theme
[livewp] / applet / src / livewp-scene.c
index dca13f0..e0a8f11 100644 (file)
 */
 /*******************************************************************************/
 #include "livewp-scene.h" 
+/* This code form X11-utils */
+Window Window_With_Name( Display *dpy, Window top, char *name)
+{
+       Window *children, dummy;
+       unsigned int nchildren;
+       int i;
+       Window w=0;
+       char *window_name;
+
+    XClassHint *class_hint;
+    class_hint = XAllocClassHint();
+    XGetClassHint(dpy, top, class_hint);
+    if (class_hint->res_name && name && !strcmp(class_hint->res_name, name)){
+      XFree(class_hint->res_class);
+      XFree(class_hint->res_name);
+           return(top);
+    }
+    XFree(class_hint->res_class);
+    XFree(class_hint->res_name);
+
+       if (XFetchName(dpy, top, &window_name) && !strcmp(window_name, name))
+         return(top);
+
+       if (!XQueryTree(dpy, top, &dummy, &dummy, &children, &nchildren))
+         return(0);
+
+       for (i=0; i<nchildren; i++) {
+               w = Window_With_Name(dpy, children[i], name);
+               if (w)
+                 break;
+       }
+       if (children) XFree ((char *)children);
+       return(w);
+}
+
+/*******************************************************************************/
 
 void 
 destroy_scene(AWallpaperPlugin *desktop_plugin)
 {
+    int status = 0;
+     
     if (desktop_plugin->priv->scene){
            GSList * tmp = desktop_plugin->priv->scene->actors;
            while (tmp != NULL){
@@ -48,15 +86,21 @@ destroy_scene(AWallpaperPlugin *desktop_plugin)
     }
     if (desktop_plugin->priv->podpid > 1){
         kill (desktop_plugin->priv->podpid, SIGTERM);
+        while (TRUE){
+            if (wait(&status) == desktop_plugin->priv->podpid) 
+                break;
+        } 
         desktop_plugin->priv->podpid = -1;
+        desktop_plugin->priv->running = FALSE;
     }
 }
 /*******************************************************************************/
 void
 reload_scene(AWallpaperPlugin *desktop_plugin)
 {
-    /* fprintf(stderr,"Reload scene %s\n", desktop_plugin->priv->theme); */
+     fprintf(stderr,"Reload scene %s\n", desktop_plugin->priv->theme); 
     destroy_scene(desktop_plugin);
+    fill_priv(desktop_plugin->priv);
     init_scene_theme(desktop_plugin);
 }
 /*******************************************************************************/
@@ -68,6 +112,7 @@ init_scene_Accel(AWallpaperPlugin *desktop_plugin)
     GPtrArray *child;
     gint now = time(NULL);
     gchar *str;
+    gchar *bgfile = NULL;
     gint sizes1[4] = {57, 76, 43, 50},
          n, j;
     
@@ -76,7 +121,8 @@ init_scene_Accel(AWallpaperPlugin *desktop_plugin)
     scene->actors = NULL;
     desktop_plugin->priv->scene = scene;
     
-    actor = init_object(desktop_plugin, "background", "bg.png", 
+    bgfile = g_strdup_printf("/home/user/.backgrounds/background-%i.png", desktop_plugin->priv->view);
+    actor = init_object(desktop_plugin, "original", bgfile, 
                       0, 0, 0, 800, 480, 
                       TRUE, TRUE, 100, 255, 
                       NULL, NULL, NULL);
@@ -169,27 +215,62 @@ bus_call (GstBus *bus, GstMessage *msg, AWallpaperPlugin *desktop_plugin)
 
 /*******************************************************************************/
 void
-init_scene_Xsnow(AWallpaperPlugin *desktop_plugin){
-    fprintf(stderr,"init_scene_Xsnow\n");
-    char* child_argv[128];
+init_scene_External(AWallpaperPlugin *desktop_plugin){
+
+    char* child_argv[2048];
     char *run_string = NULL;
-#if 0
-    fprintf(stderr, "PARAMETR %s\n",  desktop_plugin->priv->theme_string_parametr1);
-    run_string = g_strdup_printf("/usr/bin/mplayer -vo x11 -wid %d %s\n", \
-                                GDK_WINDOW_XID(desktop_plugin->priv->window->window), desktop_plugin->priv->theme_string_parametr1);
-#endif
+    gchar *exec_path = NULL,
+        *window_id = NULL,
+        *window_name = NULL,
+        *view = NULL,
+        *strwin = NULL,
+        *strview =NULL;
+    gint i;
+    Window  id_xwindow;
     if (!desktop_plugin->priv->visible)
         return;
-    run_string= g_strdup_printf("/usr/bin/xsnow");
+    
+    exec_path = g_strdup(g_hash_table_lookup(desktop_plugin->priv->hash_theme, "exec_path"));
+    window_id = g_strdup(g_hash_table_lookup(desktop_plugin->priv->hash_theme, "window_id"));
+    view = g_strdup(g_hash_table_lookup(desktop_plugin->priv->hash_theme, "view"));
+    window_name = g_strdup(g_hash_table_lookup(desktop_plugin->priv->hash_theme, "window_name"));
+    if (!exec_path) 
+        return;
+    if (window_id){
+        strwin = g_strdup_printf(" %s %i", window_id, (gint)GDK_WINDOW_XID(desktop_plugin->priv->window->window));
+    }else
+        strwin = "";
+
+    if (view){
+        strview = g_strdup_printf(" %s %i", view, desktop_plugin->priv->view);
+    }else
+        strview = "";
+
+    run_string = g_strdup_printf("%s%s%s", exec_path, strwin, strview);
+    fprintf(stderr, "runs string = %s\n", run_string);
     parsestring(run_string, child_argv);
 
     desktop_plugin->priv->running = TRUE;
     desktop_plugin->priv->podpid = fork();
     if (desktop_plugin->priv->podpid == 0){
-       execvp("/usr/bin/xsnow", child_argv);
+        execvp(child_argv[0], child_argv);
        fprintf(stderr,"Problem with new podprocess");
     }
     g_free(run_string);
+    if (window_name){
+        /* Do 10 trying to search of window */
+        for (i=0; i<10; i++){
+            sleep(1);
+            id_xwindow = Window_With_Name(GDK_WINDOW_XDISPLAY (desktop_plugin->priv->window->window), 
+                RootWindow( GDK_WINDOW_XDISPLAY (desktop_plugin->priv->window->window), XDefaultScreen( GDK_WINDOW_XDISPLAY (desktop_plugin->priv->window->window))),
+                window_name);
+            fprintf(stderr,"name %s %i %i\n", window_name, id_xwindow, i);
+            if (id_xwindow>0){
+                set_live_bg (GDK_WINDOW_XDISPLAY (desktop_plugin->priv->window->window),  id_xwindow, desktop_plugin->priv->view);
+                break;
+            }
+        }
+    }
 }
 /*******************************************************************************/
 gboolean 
@@ -241,6 +322,12 @@ init_scene_Video(AWallpaperPlugin *desktop_plugin)
     }
     file_plus_uri = g_strdup_printf("file://%s",desktop_plugin->priv->theme_string_parametr1);
     g_object_set (G_OBJECT (bin), "uri", file_plus_uri, NULL );
+#if 0
+    /* Doesn't work in real device. Hardware volume buttons can to change volume for mutted track */
+    /* Set Mute */
+    if (!desktop_plugin->priv->theme_bool_parametr1)
+        g_object_set (G_OBJECT (bin), "mute", TRUE, NULL );
+#endif
     g_object_set (G_OBJECT (videosink), "force-aspect-ratio", TRUE, NULL  );
 
     if (GST_IS_X_OVERLAY (videosink))
@@ -869,9 +956,18 @@ init_scene_Berlin(AWallpaperPlugin *desktop_plugin)
 void 
 init_scene_theme(AWallpaperPlugin *desktop_plugin)
 {
+#if 0
     void (*func)(gpointer);
     func = g_hash_table_lookup(desktop_plugin->priv->hash_scene_func, desktop_plugin->priv->theme);
     if (func){
         (*func)(desktop_plugin);
     }
+#endif
+    fprintf(stderr, "Init_scene_theme\n");
+    void (*func)(gpointer);
+    func = desktop_plugin->priv->scene_func;
+    if (func){
+        fprintf(stderr, "Success init_scene_theme\n");
+        (*func)(desktop_plugin);
+    }
 }