Config dialogue for Display Settings (size and refresh rate)
authorChristopher Michael <cpmichael1@comcast.net>
Fri, 3 Feb 2006 21:58:28 +0000 (21:58 +0000)
committerChristopher Michael <cpmichael1@comcast.net>
Fri, 3 Feb 2006 21:58:28 +0000 (21:58 +0000)
SVN revision: 20252

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

index de41eb1..a8e9dca 100644 (file)
@@ -130,6 +130,7 @@ e_int_config_cursor.h \
 e_int_config_startup.h \
 e_int_config_performance.h \
 e_int_config_winlist.h \
+e_int_config_display.h \
 e_deskpreview.h \
 e_exebuf.h \
 e_int_config_modules.h \
@@ -249,6 +250,7 @@ e_int_config_cursor.c \
 e_int_config_startup.c \
 e_int_config_performance.c \
 e_int_config_winlist.c \
+e_int_config_display.c \
 e_deskpreview.c \
 e_exebuf.c \
 e_int_config_modules.c \
index 07fb8af..506eb26 100644 (file)
@@ -54,7 +54,8 @@ e_configure_show(E_Container *con)
    e_theme_edje_object_set(eco->edje, "base/theme/configure",
                           "widgets/configure/main");
    
-   eco->ilist = e_widget_ilist_add(eco->evas, 24, 24, NULL);
+   /* 24 */
+   eco->ilist = e_widget_ilist_add(eco->evas, 32, 32, NULL);
    e_widget_ilist_selector_set(eco->ilist, 1);
    e_widget_min_size_get(eco->ilist, &mw, &mh);
    edje_extern_object_min_size_set(eco->ilist, mw, mh);
@@ -67,6 +68,7 @@ e_configure_show(E_Container *con)
    e_configure_standard_item_add(eco, "enlightenment/modules", _("Module Settings"), e_int_config_modules);
    e_configure_standard_item_add(eco, "enlightenment/mouse", _("Cursor Settings"), e_int_config_cursor);
    e_configure_standard_item_add(eco, "enlightenment/desktops", _("Desktop Settings"), e_int_config_desks);
+   e_configure_standard_item_add(eco, "enlightenment/desktops", _("Display Settings"), e_int_config_display);
    e_configure_standard_item_add(eco, "enlightenment/e", _("Focus Settings"), e_int_config_focus);
    e_configure_standard_item_add(eco, "enlightenment/favorites", _("Menu Settings"), e_int_config_menus);
    e_configure_standard_item_add(eco, "enlightenment/configuration", _("Performance Settings"), e_int_config_performance);
index 87fc483..29a0476 100644 (file)
 #include "e_int_config_startup.h"
 #include "e_int_config_performance.h"
 #include "e_int_config_winlist.h"
+#include "e_int_config_display.h"
 #include "e_deskpreview.h"
 #include "e_exebuf.h"
 #include "e_int_config_modules.h"
diff --git a/src/bin/e_int_config_display.c b/src/bin/e_int_config_display.c
new file mode 100644 (file)
index 0000000..902dc80
--- /dev/null
@@ -0,0 +1,223 @@
+#include "e.h"
+
+/* TODO:
+ * 
+ * Give list some icons.
+ * Support XRandr Rotation
+*/
+
+static void        *_create_data             (E_Config_Dialog *cfd);
+static void         _free_data               (E_Config_Dialog *cfd, E_Config_Dialog_Data *cfdata);
+static int          _basic_apply_data        (E_Config_Dialog *cfd, E_Config_Dialog_Data *cfdata);
+static Evas_Object *_basic_create_widgets    (E_Config_Dialog *cfd, Evas *evas, E_Config_Dialog_Data *cfdata);
+static void         _load_rates              (void *data);
+static void         _ilist_item_change       (void *data);
+
+Evas_Object *rate_list = NULL;
+Evas_Object *res_list = NULL;
+
+typedef struct _Resolution Resolution;
+struct _Resolution 
+{
+   int size_id;
+   Ecore_X_Screen_Size size;
+   Ecore_X_Screen_Refresh_Rate *rates;
+};
+
+struct _E_Config_Dialog_Data 
+{
+   E_Config_Dialog *cfd;
+   Resolution *res;
+   Ecore_X_Screen_Size orig_size;
+   Ecore_X_Screen_Refresh_Rate orig_rate;
+};
+
+EAPI E_Config_Dialog *
+e_int_config_display(E_Container *con) 
+{
+   E_Config_Dialog *cfd;
+   E_Config_Dialog_View *v;
+   
+   v = E_NEW(E_Config_Dialog_View, 1);
+   v->create_cfdata = _create_data;
+   v->free_cfdata = _free_data;
+   v->basic.apply_cfdata = _basic_apply_data;
+   v->basic.create_widgets = _basic_create_widgets;
+   
+   cfd = e_config_dialog_new(con, _("Display Settings"), NULL, 0, v, NULL);
+   e_dialog_resizable_set(cfd->dia, 1);
+   return cfd;
+}
+
+static void
+_fill_data(E_Config_Dialog_Data *cfdata) 
+{
+   E_Manager *man;
+   
+   man = e_manager_current_get();
+   cfdata->orig_size = ecore_x_randr_current_screen_size_get(man->root);   
+   cfdata->orig_rate = ecore_x_randr_current_screen_refresh_rate_get(man->root);
+}
+
+static void *
+_create_data(E_Config_Dialog *cfd) 
+{
+   E_Config_Dialog_Data *cfdata;
+   cfdata = E_NEW(E_Config_Dialog_Data, 1);
+   _fill_data(cfdata);
+   cfdata->cfd = cfd;
+   return cfdata;
+}
+
+static void
+_free_data(E_Config_Dialog *cfd, E_Config_Dialog_Data *cfdata) 
+{
+   free(cfdata);
+}
+
+static int
+_basic_apply_data(E_Config_Dialog *cfd, E_Config_Dialog_Data *cfdata) 
+{
+   char *sel_res, *sel_rate;
+   int w, h, r, i, n;
+   Ecore_X_Screen_Size *sizes;
+   Ecore_X_Screen_Size size;
+   Ecore_X_Screen_Refresh_Rate *rates;   
+   Ecore_X_Screen_Refresh_Rate rate;
+   E_Manager *man;
+   
+   sel_res = (char *)e_widget_ilist_selected_label_get(res_list);
+   sel_rate = (char *)e_widget_ilist_selected_label_get(rate_list);
+   sscanf(sel_res, "%dx%d", &w, &h);
+   sscanf(sel_rate, "%d Hz", &r);
+      
+   if ((cfdata->orig_size.width == w) && 
+       (cfdata->orig_size.height == h) &&
+       (cfdata->orig_rate.rate == r))
+     return 1;
+
+   man = e_manager_current_get();
+   sizes = ecore_x_randr_screen_sizes_get(man->root, &n);
+   for (i = 0; i < n; i++) 
+     {
+       if ((sizes[i].width == w) && 
+           (sizes[i].height == h))
+         {
+            size = sizes[i];
+            int k, rr;
+            rates = ecore_x_randr_screen_refresh_rates_get(man->root, i, &rr);
+            for (k = 0; k < rr; k++) 
+              {
+                 if (rates[k].rate == r) 
+                   {
+                      rate = rates[k];
+                      break;
+                   }  
+              }
+            break;
+         }
+     }
+   
+   int ret;   
+   ret = ecore_x_randr_screen_refresh_rate_set(man->root, size, rate);
+   cfdata->orig_size = size;
+   cfdata->orig_rate = rate;
+   
+   return 1;
+}
+
+static Evas_Object *
+_basic_create_widgets(E_Config_Dialog *cfd, Evas *evas, E_Config_Dialog_Data *cfdata) 
+{
+   Evas_Object *o, *of, *ol, *rl;
+   E_Manager *man;
+   Ecore_X_Screen_Size *sizes;
+   Ecore_X_Screen_Size size;
+   int i, r, s;
+   
+   _fill_data(cfdata);
+   
+   o = e_widget_list_add(evas, 0, 0);
+   
+   of = e_widget_framelist_add(evas, _("Resolution"), 0);   
+   ol = e_widget_ilist_add(evas, 32, 32, NULL);
+   e_widget_min_size_set(ol, 140, 120);   
+   e_widget_framelist_object_append(of, ol);
+   e_widget_list_object_append(o, of, 1, 1, 0.5);
+
+   res_list = ol;
+   
+   of = e_widget_framelist_add(evas, _("Refresh Rate"), 0);   
+   rl = e_widget_ilist_add(evas, 8, 8, NULL);
+   e_widget_min_size_set(rl, 140, 90);   
+   e_widget_framelist_object_append(of, rl);
+   e_widget_list_object_append(o, of, 1, 1, 0.5);   
+   
+   rate_list = rl;
+   
+   man = e_manager_current_get();
+   sizes = ecore_x_randr_screen_sizes_get(man->root, &s);
+   size = ecore_x_randr_current_screen_size_get(man->root);
+   
+   if (sizes) 
+     { 
+       char buf[16];
+
+       for (i = 0; i < s; i++) 
+         {
+            Resolution *res;
+            
+            res = E_NEW(Resolution, 1);
+            if (!res) continue;
+                    
+            res->size = sizes[i];
+            res->size_id = i;
+            res->rates = ecore_x_randr_screen_refresh_rates_get(man->root, res->size_id, &r);
+                    
+            snprintf(buf, sizeof(buf), "%dx%d", sizes[i].width, sizes[i].height);
+            e_widget_ilist_append(ol, NULL, buf, _ilist_item_change, res, NULL);            
+
+            if ((res->size.width == size.width) && (res->size.height == size.height)) 
+              {             
+                 e_widget_ilist_selected_set(ol, i);
+                 _load_rates(res);                       
+              }
+         }     
+     }
+   
+   e_widget_ilist_go(ol);
+   e_widget_ilist_go(rl);
+   return o;
+}
+
+static void
+_load_rates(void *data) 
+{
+   int k, r;
+   E_Manager *man;
+   Resolution *res = data;
+   Ecore_X_Screen_Refresh_Rate rt;
+   Ecore_X_Screen_Refresh_Rate *rts;
+   char buf[16];
+
+   man = e_manager_current_get();   
+   rts = ecore_x_randr_screen_refresh_rates_get(man->root, res->size_id, &r);
+   rt = ecore_x_randr_current_screen_refresh_rate_get(man->root);
+
+   e_widget_ilist_clear(rate_list);
+   
+   for (k = 0; k < r; k++) 
+     { 
+
+       snprintf(buf, sizeof(buf), "%d Hz", rts[k].rate);
+       e_widget_ilist_append(rate_list, NULL, buf, NULL, NULL, NULL);
+       if (rt.rate == rts[k].rate) 
+         e_widget_ilist_selected_set(rate_list, k);
+     }   
+}
+
+static void
+_ilist_item_change(void *data) 
+{
+   _load_rates(data);
+}
diff --git a/src/bin/e_int_config_display.h b/src/bin/e_int_config_display.h
new file mode 100644 (file)
index 0000000..af6c7bd
--- /dev/null
@@ -0,0 +1,9 @@
+#ifdef E_TYPEDEFS
+#else
+#ifndef E_INT_CONFIG_DISPLAY_H
+#define E_INT_CONFIG_DISPLAY_H
+
+EAPI E_Config_Dialog *e_int_config_display(E_Container *con);
+
+#endif
+#endif