cedric pushed a commit to branch master.

http://git.enlightenment.org/website/www-content.git/commit/?id=2d03ee6f2fc70c402c4d4ec5e73a838b36415ba0

commit 2d03ee6f2fc70c402c4d4ec5e73a838b36415ba0
Author: Clément Bénier <clement.ben...@openwide.fr>
Date:   Thu Jun 25 18:02:22 2015 +0200

    Wiki pages panes_tutorial created: Initializing, Creating, Configure, 
handling signals + image + code c
    
    Signed-off-by: Clément Bénier <clement.ben...@openwide.fr>
    Signed-off-by: Pierre Le Magourou <pierre.lemagou...@openwide.fr>
    Signed-off-by: Cedric BAIL <ced...@osg.samsung.com>
---
 media/code_c/tutorial/panes/panes.c | 116 +++++++++++++++++
 media/panes.png                     | Bin 0 -> 51324 bytes
 pages/docs.txt                      |   1 +
 pages/tutorial/panes_tutorial.txt   | 247 ++++++++++++++++++++++++++++++++++++
 4 files changed, 364 insertions(+)

diff --git a/media/code_c/tutorial/panes/panes.c 
b/media/code_c/tutorial/panes/panes.c
new file mode 100644
index 0000000..4ab66e3
--- /dev/null
+++ b/media/code_c/tutorial/panes/panes.c
@@ -0,0 +1,116 @@
+#include <Elementary.h>
+
+// clicked callback
+static void
+_clicked_cb(void *data, Evas_Object *obj, void *event_info)
+{
+   printf("Clicked\n");
+}
+
+// press callback
+static void
+_press_cb(void *data, Evas_Object *obj, void *event_info)
+{
+   printf("Pressed\n");
+}
+
+// unpress callback
+static void
+_unpress_cb(void *data, Evas_Object *obj, void *event_info)
+{
+   printf("Unpressed, size : %f\n", elm_panes_content_left_size_get(obj));
+}
+
+// double clicked callback
+static void
+_clicked_double_cb(void *data, Evas_Object *obj, void *event_info)
+{
+   static double size = 0.0;
+   double tmp_size = 0.0;
+   tmp_size = elm_panes_content_left_size_get(obj);
+   if (tmp_size > 0)
+     {
+        elm_panes_content_left_size_set(obj, 0.0);
+        printf("Double clicked, hidden.\n");
+     }
+   else
+     {
+        elm_panes_content_left_size_set(obj, size);
+        printf("Double clicked, restoring size.\n");
+     }
+   size = tmp_size;
+}
+
+    EAPI_MAIN int
+elm_main(int argc, char **argv)
+{
+   Evas_Object *win;
+
+   win = elm_win_util_standard_add("Panes", "Panes Tutorial");
+   elm_policy_set(ELM_POLICY_QUIT, ELM_POLICY_QUIT_LAST_WINDOW_CLOSED);
+   elm_win_autodel_set(win, EINA_TRUE);
+   //win 400x400 px
+   evas_object_resize(win, 400, 400);
+
+   Evas_Object *panes, *panes_h, *bt;
+
+   // Add an elm_panes
+   panes = elm_panes_add(win);
+   evas_object_size_hint_weight_set(panes, EVAS_HINT_EXPAND, EVAS_HINT_EXPAND);
+   elm_win_resize_object_add(win, panes);
+   evas_object_show(panes);
+
+   // Add a horizontal elm_panes
+   panes_h = elm_panes_add(win);
+   elm_panes_horizontal_set(panes_h, EINA_TRUE);
+   elm_object_part_content_set(panes, "left", panes_h);
+
+   // Create a button object
+   bt = elm_button_add(win);
+   elm_object_text_set(bt, "Right");
+   evas_object_size_hint_weight_set(bt, EVAS_HINT_EXPAND, EVAS_HINT_EXPAND);
+   evas_object_size_hint_align_set(bt, EVAS_HINT_FILL, EVAS_HINT_FILL);
+   evas_object_show(bt);
+
+   // and set it to the "right" part of the vertical Panes
+   elm_object_part_content_set(panes, "right", bt);
+
+   // Create a "Up" button
+   bt = elm_button_add(win);
+   elm_object_text_set(bt, "Up");
+   evas_object_size_hint_weight_set(bt, EVAS_HINT_EXPAND, EVAS_HINT_EXPAND);
+   evas_object_size_hint_align_set(bt, EVAS_HINT_FILL, EVAS_HINT_FILL);
+   evas_object_show(bt);
+   elm_object_part_content_set(panes_h, "left", bt);
+
+   // Create a "Down" button
+   bt = elm_button_add(win);
+   elm_object_text_set(bt, "Down");
+   evas_object_size_hint_weight_set(bt, EVAS_HINT_EXPAND, EVAS_HINT_EXPAND);
+   evas_object_size_hint_align_set(bt, EVAS_HINT_FILL, EVAS_HINT_FILL);
+   evas_object_show(bt);
+   elm_object_part_content_set(panes_h, "right", bt);
+
+   // Set the proportion of the panes to 80%
+   elm_panes_content_left_size_set(panes, 0.8);
+   elm_panes_content_left_size_set(panes_h, 0.8);
+
+   //panes callbacks
+   evas_object_smart_callback_add(panes, "clicked", _clicked_cb, panes);
+   evas_object_smart_callback_add(panes, "press", _press_cb, panes);
+   evas_object_smart_callback_add(panes, "unpress", _unpress_cb, panes);
+   evas_object_smart_callback_add(panes, "clicked,double", _clicked_double_cb,
+           panes);
+
+   //panes_h callbacks
+   evas_object_smart_callback_add(panes_h, "clicked", _clicked_cb, panes_h);
+   evas_object_smart_callback_add(panes_h, "press", _press_cb, panes_h);
+   evas_object_smart_callback_add(panes_h, "unpress", _unpress_cb, panes_h);
+   evas_object_smart_callback_add(panes_h, "clicked,double", 
_clicked_double_cb,
+           panes_h);
+
+   evas_object_show(win);
+   elm_run();
+   return 0;
+}
+ELM_MAIN()
diff --git a/media/panes.png b/media/panes.png
new file mode 100644
index 0000000..eeb3633
Binary files /dev/null and b/media/panes.png differ
diff --git a/pages/docs.txt b/pages/docs.txt
index cefed8b..40c2f2d 100644
--- a/pages/docs.txt
+++ b/pages/docs.txt
@@ -39,6 +39,7 @@ Go check the current available version of EFL on each 
distro/platform:
 
   * [[tutorial/basic_tutorial|Basic Tutorial]]
   * [[tutorial/genlist_tutorial|Genlist Tutorial]]
+  * [[tutorial/panes_tutorial|Panes Tutorial]]
 
 ----
 
diff --git a/pages/tutorial/panes_tutorial.txt 
b/pages/tutorial/panes_tutorial.txt
new file mode 100644
index 0000000..a681e85
--- /dev/null
+++ b/pages/tutorial/panes_tutorial.txt
@@ -0,0 +1,247 @@
+~~Title: Panes Tutorial~~
+==== Panes Tutorial ====
+
+This tutorial explains how to use Panes in the application.
+
+=== Table of Contents ===
+
+  * [[#Initializing_the_Application|Initializing the Application]]
+  * [[#Creating_a_Panes_Widget|Creating a Panes Widget]]
+  * [[#Configure_the_Panes|Configure the Panes]]
+  * [[#Handling_Signals|Handling Signals]]
+
+
+A panes example : {{ :panes.png?direct |list}}
+
+//**__The whole code__ : **//{{/code_c/tutorial/panes/panes.c}}
+--------
+
+=== Initializing the Application ===
+
+The code below shows a typical elementary application that creates a window
+entitled "Panes Tutorial". The panes goes inside.
+
+<code c>
+#include <Elementary.h>
+
+EAPI_MAIN int
+elm_main(int argc, char **argv)
+{
+   Evas_Object *win;
+
+   win = elm_win_util_standard_add("Panes", "Panes Tutorial");
+   elm_policy_set(ELM_POLICY_QUIT, ELM_POLICY_QUIT_LAST_WINDOW_CLOSED);
+   elm_win_autodel_set(win, EINA_TRUE);
+   //win 400x400 px
+   evas_object_resize(win, 400, 400);
+
+   //panes code here
+
+   evas_object_show(win);
+   elm_run();
+   return 0;
+}
+ELM_MAIN()
+</code>
+
+=== Creating a Panes Widget ===
+
+The elm_panes widget adds a draggable bar between two contents. When dragged,
+this bar resizes the contents. To create a new Panes into an Elementary
+object, use the ''elm_panes_add()'' function:
+
+<code c>
+// Add an elm_panes
+Evas_Object *panes;
+panes = elm_panes_add(win);
+evas_object_size_hint_weight_set(panes, EVAS_HINT_EXPAND, EVAS_HINT_EXPAND);
+elm_win_resize_object_add(win, panes);
+evas_object_show(panes);
+</code>
+
+=== Configure the Panes ===
+
+By default, the orientation of the Panes is vertical. To modify the
+orientation, use the ''elm_panes_horizontal_set()'' function.
+
+<code c>
+Evas_Object *panes_h;
+// Add a horizontal elm_panes
+panes_h = elm_panes_add(win);
+elm_panes_horizontal_set(panes_h, EINA_TRUE);
+</code>
+
+The code above creates another Panes object and sets the horizontal
+orientation. To add content in a panes, use the
+''elm_object_part_content_set()'' function. Here we add the horizontal Panes
+''panes_h'' to the "left" part of the first Panes ''panes'' created.
+
+<code c>
+elm_object_part_content_set(panes, "left", panes_h);
+</code>
+
+This is how to set a button object to the "right" side of our vertical Panes
+widget.
+
+<code c>
+// Create a button object
+bt = elm_button_add(win);
+elm_object_text_set(bt, "Right");
+evas_object_size_hint_weight_set(bt, EVAS_HINT_EXPAND, EVAS_HINT_EXPAND);
+evas_object_size_hint_align_set(bt, EVAS_HINT_FILL, EVAS_HINT_FILL);
+evas_object_show(bt);
+
+// and set it to the "right" part of the vertical Panes
+elm_object_part_content_set(panes, "right", bt);
+</code>
+
+The content of the horizontal Panes is set with two button objects (up and
+down). When populating a vertically displayed Panes, the left content is
+placed at the top, and the right content is placed at the bottom.
+
+<code c>
+// Create a "Up" button
+bt = elm_button_add(win);
+elm_object_text_set(bt, "Up");
+evas_object_size_hint_weight_set(bt, EVAS_HINT_EXPAND, EVAS_HINT_EXPAND);
+evas_object_size_hint_align_set(bt, EVAS_HINT_FILL, EVAS_HINT_FILL);
+evas_object_show(bt);
+elm_object_part_content_set(panes_h, "left", bt);
+
+// Create a "Down" button
+bt = elm_button_add(win);
+elm_object_text_set(bt, "Down");
+evas_object_size_hint_weight_set(bt, EVAS_HINT_EXPAND, EVAS_HINT_EXPAND);
+evas_object_size_hint_align_set(bt, EVAS_HINT_FILL, EVAS_HINT_FILL);
+evas_object_show(bt);
+elm_object_part_content_set(panes_h, "right", bt);
+</code>
+
+The elm_panes can be dragged with the mouse but the proportion can also be set
+with the ''elm_panes_content_left_size_set()'' and
+''elm_panes_content_right_size_set()'' functions. As an example, this is how to
+set the left size of both panes to 80%.
+
+<code c>
+// Set the proportion of the panes to 80%
+elm_panes_content_left_size_set(panes, 0.8);
+elm_panes_content_left_size_set(panes_h, 0.8);
+</code>
+
+The Panes proportions can also be fixed so that the user is not able to drag
+them. To do this, use the ''elm_panes_fixed_set()'' function.
+
+<code c>
+// Fix the Panes proportion
+elm_panes_fixed_set(panes_h, EINA_TRUE);
+</code>
+
+==== Handling Signals ====
+
+The Panes widgets emit four different signals, depending on the users'
+interaction with the draggable bar.
+
+    * "press" - The pane is pressed.
+    * "unpressed" - The pane is released after being pressed.
+    * "clicked" - The pane is clicked.
+    * "clicked,double" - The pane is double clicked.
+
+A callback function is added for each of them.
+
+//**__"click" Signal__**//
+
+The callback function for the clicked signal prints "Clicked" to standard
+output.
+
+<code c>
+// click callback
+static void
+_clicked_cb(void *data, Evas_Object *obj, void *event_info)
+{
+   printf("Clicked\n");
+}
+</code>
+
+This is how to register this callback function to the vertical panes.
+<code c>
+    evas_object_smart_callback_add(panes, "clicked", _clicked_cb, panes);
+</code>
+
+//**__"press" Signal__**//
+
+The callback function for the clicked signal prints "Clicked" to standard
+output.
+
+<code c>
+// press callback
+static void
+_press_cb(void *data, Evas_Object *obj, void *event_info)
+{
+   printf("Pressed\n");
+}
+</code>
+
+The callback function for the "press" signal prints "Pressed" to the standard
+output.
+
+<code c>
+evas_object_smart_callback_add(panes, "press", _press_cb, panes);
+</code>
+
+//**__"unpress" Signal__**//
+
+For the "unpress" signal, the proportion size of the left content of the Panes
+widget is printed to the standard output. To do this, use the
+''elm_panes_content_left_size_get()'' function.
+
+<code c>
+static void
+_unpress_cb(void *data, Evas_Object *obj, void *event_info)
+{
+   printf("Unpressed, size : %f\n", elm_panes_content_left_size_get(obj));
+}
+</code>
+
+This is how to register this callback function to the vertical panes.
+<code c>
+evas_object_smart_callback_add(panes, "unpress", _unpress_cb, panes);
+</code>
+
+//**__"clicked,double" Signal__**//
+
+Hide the left part of the Panes widget on the "clicked,double" signal and set
+the left proportion to 0.0. To restore the left part proportion with a double
+click on the hidden part of the Panes widget, use the
+''elm_panes_content_left_size_get()'' and
+''elm_panes_content_left_size_set()'' functions, and a variable to store the
+value of the current proportion.
+
+<code c>
+// double clicked callback
+static void
+_clicked_double_cb(void *data, Evas_Object *obj, void *event_info)
+{
+   static double size = 0.0;
+   double tmp_size = 0.0;
+   tmp_size = elm_panes_content_left_size_get(obj);
+   if (tmp_size > 0)
+     {
+        elm_panes_content_left_size_set(obj, 0.0);
+        printf("Double clicked, hidden.\n");
+     }
+   else
+     {
+        elm_panes_content_left_size_set(obj, size);
+        printf("Double clicked, restoring size.\n");
+     }
+   size = tmp_size;
+}
+</code>
+
+This is how to register this callback function to the Panes.
+
+<code c>
+evas_object_smart_callback_add(panes, "clicked,double", _clicked_double_cb, 
panes);
+</code>
+\\
+//**__The whole code__ : **//{{/code_c/tutorial/panes/panes.c}}

-- 


Reply via email to