starterd shell for doing deskpreview smart...
authorCarsten Haitzler <raster@rasterman.com>
Tue, 22 Nov 2005 14:47:24 +0000 (14:47 +0000)
committerCarsten Haitzler <raster@rasterman.com>
Tue, 22 Nov 2005 14:47:24 +0000 (14:47 +0000)
SVN revision: 18601

src/bin/Makefile.am
src/bin/e_deskpreview.c [new file with mode: 0644]
src/bin/e_deskpreview.h [new file with mode: 0644]
src/bin/e_includes.h

index 953e85f..f290718 100644 (file)
@@ -119,7 +119,8 @@ e_slider.h \
 e_widget_slider.h \
 e_int_config_window_manipulation.h \
 e_int_config_window_display.h \
-e_int_config_background.h 
+e_int_config_background.h \
+e_deskpreview.h
 
 enlightenment_src = \
 e_user.c \
@@ -220,6 +221,7 @@ e_widget_slider.c \
 e_int_config_window_manipulation.c \
 e_int_config_window_display.c \
 e_int_config_background.c \
+e_deskpreview.c \
 $(ENLIGHTENMENTHEADERS)
 
 enlightenment_SOURCES = \
diff --git a/src/bin/e_deskpreview.c b/src/bin/e_deskpreview.c
new file mode 100644 (file)
index 0000000..cb48bc9
--- /dev/null
@@ -0,0 +1,150 @@
+/*
+ * vim:ts=8:sw=3:sts=8:noexpandtab:cino=>5n-3f0^-2{2
+ */
+#include "e.h"
+
+#define SMART_NAME "e_deskpreview"
+#define API_ENTRY E_Smart_Data *sd; sd = evas_object_smart_data_get(obj); if ((!obj) || (!sd) || (evas_object_type_get(obj) && strcmp(evas_object_type_get(obj), SMART_NAME)))
+#define INTERNAL_ENTRY E_Smart_Data *sd; sd = evas_object_smart_data_get(obj); if (!sd) return;
+typedef struct _E_Smart_Data E_Smart_Data;
+
+struct _E_Smart_Data
+{ 
+   Evas_Coord   x, y, w, h;
+   
+   Evas_Object   *smart_obj;
+};
+
+/* local subsystem functions */
+static void _e_smart_reconfigure(E_Smart_Data *sd);
+static void _e_smart_add(Evas_Object *obj);
+static void _e_smart_del(Evas_Object *obj);
+static void _e_smart_move(Evas_Object *obj, Evas_Coord x, Evas_Coord y);
+static void _e_smart_resize(Evas_Object *obj, Evas_Coord w, Evas_Coord h);
+static void _e_smart_show(Evas_Object *obj);
+static void _e_smart_hide(Evas_Object *obj);
+static void _e_smart_color_set(Evas_Object *obj, int r, int g, int b, int a);
+static void _e_smart_clip_set(Evas_Object *obj, Evas_Object * clip);
+static void _e_smart_clip_unset(Evas_Object *obj);
+static void _e_smart_init(void);
+
+/* local subsystem globals */
+static Evas_Smart *_e_smart = NULL;
+
+/* externally accessible functions */
+Evas_Object *
+e_deskpreview_add(Evas *evas)
+{
+   _e_smart_init();
+   return evas_object_smart_add(evas, _e_smart);
+}
+
+/* local subsystem functions */
+
+static void
+_e_smart_reconfigure(E_Smart_Data *sd)
+{
+//   evas_object_move(sd->edje_obj, sd->x, sd->y);
+//   evas_object_resize(sd->edje_obj, sd->w, sd->h);
+}
+
+static void
+_e_smart_add(Evas_Object *obj)
+{
+   E_Smart_Data *sd;
+   Evas_Object *o;
+   
+   sd = calloc(1, sizeof(E_Smart_Data));
+   if (!sd) return;
+   evas_object_smart_data_set(obj, sd);
+   
+   sd->smart_obj = obj;
+   sd->x = 0;
+   sd->y = 0;
+   sd->w = 0;
+   sd->h = 0;
+}
+
+static void
+_e_smart_del(Evas_Object *obj)
+{
+   INTERNAL_ENTRY;
+//   evas_object_del(sd->edje_obj);
+   free(sd);
+}
+
+static void
+_e_smart_move(Evas_Object *obj, Evas_Coord x, Evas_Coord y)
+{
+   INTERNAL_ENTRY;
+   if ((sd->x == x) && (sd->y == y)) return;
+   sd->x = x;
+   sd->y = y;
+   _e_smart_reconfigure(sd);
+}
+
+static void
+_e_smart_resize(Evas_Object *obj, Evas_Coord w, Evas_Coord h)
+{
+   INTERNAL_ENTRY;
+   if ((sd->w == w) && (sd->h == h)) return;
+   sd->w = w;
+   sd->h = h;
+   _e_smart_reconfigure(sd);
+}
+
+static void
+_e_smart_show(Evas_Object *obj)
+{
+   INTERNAL_ENTRY;
+//   evas_object_show(sd->edje_obj);
+}
+
+static void
+_e_smart_hide(Evas_Object *obj)
+{
+   INTERNAL_ENTRY;
+//   evas_object_hide(sd->edje_obj);
+}
+
+static void
+_e_smart_color_set(Evas_Object *obj, int r, int g, int b, int a)
+{
+   INTERNAL_ENTRY;
+//   evas_object_color_set(sd->edje_obj, r, g, b, a);
+}
+
+static void
+_e_smart_clip_set(Evas_Object *obj, Evas_Object * clip)
+{
+   INTERNAL_ENTRY;
+//   evas_object_clip_set(sd->edje_obj, clip);
+}
+
+static void
+_e_smart_clip_unset(Evas_Object *obj)
+{
+   INTERNAL_ENTRY;
+//   evas_object_clip_unset(sd->edje_obj);
+}  
+
+/* never need to touch this */
+
+static void
+_e_smart_init(void)
+{
+   if (_e_smart) return;
+   _e_smart = evas_smart_new(SMART_NAME,
+                            _e_smart_add,
+                            _e_smart_del, 
+                            NULL, NULL, NULL, NULL, NULL,
+                            _e_smart_move,
+                            _e_smart_resize,
+                            _e_smart_show,
+                            _e_smart_hide,
+                            _e_smart_color_set,
+                            _e_smart_clip_set,
+                            _e_smart_clip_unset,
+                            NULL);
+}
+
diff --git a/src/bin/e_deskpreview.h b/src/bin/e_deskpreview.h
new file mode 100644 (file)
index 0000000..2b30f0e
--- /dev/null
@@ -0,0 +1,12 @@
+/*
+ * vim:ts=8:sw=3:sts=8:noexpandtab:cino=>5n-3f0^-2{2
+ */
+#ifdef E_TYPEDEFS
+#else
+#ifndef E_DESKPREVIEW_H
+#define E_DESKPREVIEW_H
+
+EAPI Evas_Object *e_deskpreview_add                      (Evas *evas);
+
+#endif
+#endif
index 48fafa5..bb97b44 100644 (file)
 #include "e_int_config_window_manipulation.h"
 #include "e_int_config_window_display.h"
 #include "e_int_config_background.h"
+#include "e_deskpreview.h"