cedric pushed a commit to branch master.

http://git.enlightenment.org/core/elementary.git/commit/?id=cdff55ab7fd2f5f2470e28c5530df3ab5255fac8

commit cdff55ab7fd2f5f2470e28c5530df3ab5255fac8
Author: kabeer khan <kabeer.k...@samsung.com>
Date:   Tue Apr 28 11:42:55 2015 +0200

    photocam: update photocam example to demonstrate photocam orientation.
    
    Summary: Signed-off-by: kabeer khan <kabeer.k...@samsung.com>
    
    Reviewers: cedric, raster
    
    Differential Revision: https://phab.enlightenment.org/D2421
    
    Signed-off-by: Cedric BAIL <ced...@osg.samsung.com>
---
 src/examples/photocam_example_01.c | 71 +++++++++++++++++++++++++++++++++++++-
 1 file changed, 70 insertions(+), 1 deletion(-)

diff --git a/src/examples/photocam_example_01.c 
b/src/examples/photocam_example_01.c
index 596e31c..7826591 100644
--- a/src/examples/photocam_example_01.c
+++ b/src/examples/photocam_example_01.c
@@ -8,11 +8,21 @@ static void _fit(void *data, Evas_Object *obj, void 
*event_info);
 static void _unfit(void *data, Evas_Object *obj, void *event_info);
 static void _zoom(void *data, Evas_Object *obj, void *event_info);
 static void _bring_in(void *data, Evas_Object *obj, void *event_info);
+static void _orient(void *data, Evas_Object *obj, void *event_info);
+static void _orient_do(void *data, Evas_Object *obj, void *event_info);
+
+typedef struct _Orient_Data Orient_Data;
+struct _Orient_Data
+{
+   Evas_Object *ph;
+   Evas_Image_Orient orient;
+};
 
 EAPI_MAIN int
 elm_main(int argc, char **argv)
 {
-   Evas_Object *win, *obj, *photocam;
+   Evas_Object *win, *obj, *photocam, *menu;
+   Orient_Data *orient_data;
    char buf[PATH_MAX];
 
    elm_app_info_set(elm_main, "elementary", 
"images/insanely_huge_test_image.jpg");
@@ -43,6 +53,47 @@ elm_main(int argc, char **argv)
    evas_object_move(obj, 70, 410);
    evas_object_smart_callback_add(obj, "clicked", _unfit, photocam);
 
+   orient_data = (Orient_Data *)malloc(sizeof(Orient_Data));
+   orient_data->ph = photocam;
+   orient_data->orient = 0;
+   menu = elm_menu_add(win);
+   elm_menu_item_add(menu, NULL, NULL, "orient 0", _orient_do, orient_data);
+   orient_data = (Orient_Data *)malloc(sizeof(Orient_Data));
+   orient_data->ph = photocam;
+   orient_data->orient = 1;
+   elm_menu_item_add(menu, NULL, NULL, "orient 90", _orient_do, orient_data);
+   orient_data = (Orient_Data *)malloc(sizeof(Orient_Data));
+   orient_data->ph = photocam;
+   orient_data->orient = 2;
+   elm_menu_item_add(menu, NULL, NULL, "orient 180", _orient_do, orient_data);
+   orient_data = (Orient_Data *)malloc(sizeof(Orient_Data));
+   orient_data->ph = photocam;
+   orient_data->orient = 3;
+   elm_menu_item_add(menu, NULL, NULL, "orient 270", _orient_do, orient_data);
+   orient_data = (Orient_Data *)malloc(sizeof(Orient_Data));
+   orient_data->ph = photocam;
+   orient_data->orient = 4;
+   elm_menu_item_add(menu, NULL, NULL, "flip horizontal", _orient_do, 
orient_data);
+   orient_data = (Orient_Data *)malloc(sizeof(Orient_Data));
+   orient_data->ph = photocam;
+   orient_data->orient = 5;
+   elm_menu_item_add(menu, NULL, NULL, "flip vertical", _orient_do, 
orient_data);
+   orient_data = (Orient_Data *)malloc(sizeof(Orient_Data));
+   orient_data->ph = photocam;
+   orient_data->orient = 6;
+   elm_menu_item_add(menu, NULL, NULL, "flip transverse", _orient_do, 
orient_data);
+   orient_data = (Orient_Data *)malloc(sizeof(Orient_Data));
+   orient_data->ph = photocam;
+   orient_data->orient = 7;
+   elm_menu_item_add(menu, NULL, NULL, "flip transpose", _orient_do, 
orient_data);
+
+   obj = elm_button_add(win);
+   elm_object_text_set(obj, "Orient");
+   evas_object_show(obj);
+   evas_object_resize(obj, 70, 30);
+   evas_object_move(obj, 470, 410);
+   evas_object_smart_callback_add(obj, "clicked", _orient, menu);
+
    obj = elm_slider_add(win);
    elm_object_text_set(obj, "Zoom");
    evas_object_show(obj);
@@ -88,3 +139,21 @@ _zoom(void *data, Evas_Object *obj, void *event_info)
    double z = elm_slider_value_get(obj) * 8;
    elm_photocam_zoom_set(data, z);
 }
+
+static void
+_orient(void *data, Evas_Object *obj, void *event_info)
+{
+   Evas_Object *mn = data;
+   if (!mn) return;
+
+   evas_object_show(mn);
+}
+
+static void
+_orient_do(void *data, Evas_Object *obj, void *event_info)
+{
+   Orient_Data *orient_data = data;
+   if (!orient_data) return;
+
+   elm_photocam_image_orient_set(orient_data->ph, orient_data->orient);
+}

-- 


Reply via email to