From: cnook <kimcinoo@gmail.com>
authorraster <raster@7cbeb6ba-43b4-40fd-8cce-4c39aea84d33>
Wed, 7 Mar 2012 13:50:37 +0000 (13:50 +0000)
committerraster <raster@7cbeb6ba-43b4-40fd-8cce-4c39aea84d33>
Wed, 7 Mar 2012 13:50:37 +0000 (13:50 +0000)
Subject: [E-devel] [Patch][elementary_test] test_label

I have attached a patch for test_label. Please review the patch and
give any feedbacks. Thanks.

git-svn-id: svn+ssh://svn.enlightenment.org/var/svn/e/trunk/elementary@68949 7cbeb6ba-43b4-40fd-8cce-4c39aea84d33

src/bin/test.c
src/bin/test_label.c
src/bin/test_map.c
src/lib/elm_map.c
src/lib/elm_map.h

index de0e075..3c71e32 100644 (file)
@@ -131,6 +131,7 @@ void test_flip3(void *data, Evas_Object *obj, void *event_info);
 void test_flip4(void *data, Evas_Object *obj, void *event_info);
 void test_flip_page(void *data, Evas_Object *obj, void *event_info);
 void test_label(void *data, Evas_Object *obj, void *event_info);
+void test_label2(void *data, Evas_Object *obj, void *event_info);
 void test_conformant(void *data, Evas_Object *obj, void *event_info);
 void test_conformant2(void *data, Evas_Object *obj, void *event_info);
 void test_multi(void *data, Evas_Object *obj, void *event_info);
@@ -523,6 +524,7 @@ add_tests:
 
    //------------------------------//
    ADD_TEST(NULL, "Text", "Label", test_label);
+   ADD_TEST(NULL, "Text", "Label2", test_label2);
 
    //------------------------------//
    ADD_TEST(NULL, "Stored Surface Buffer", "Launcher", test_launcher);
index 073cd37..f1d46d3 100644 (file)
@@ -4,6 +4,14 @@
 #endif
 #ifndef ELM_LIB_QUICKLAUNCH
 
+enum _slide_style
+{
+   SLIDE_SHORT,
+   SLIDE_LONG,
+   SLIDE_BOUNCE,
+   SLIDE_STYLE_LAST
+};
+
 void
 test_label(void *data __UNUSED__, Evas_Object *obj __UNUSED__, void *event_info __UNUSED__)
 {
@@ -68,10 +76,149 @@ test_label(void *data __UNUSED__, Evas_Object *obj __UNUSED__, void *event_info
    elm_box_pack_end(bx, lb);
    evas_object_show(lb);
 
+
    evas_object_resize(win, 320, 300);
 
    evas_object_show(bx);
    evas_object_show(win);
    elm_win_resize_object_add(win, bx);
 }
+
+static void
+_cb_size_radio_changed(void *data, Evas_Object *obj, void *event __UNUSED__)
+{
+   Evas_Object *lb = (Evas_Object *)data;
+   int style =  elm_radio_value_get((Evas_Object *)obj);
+   switch (style)
+     {
+      case SLIDE_SHORT:
+         elm_object_style_set(lb, "slide_short");
+         break;
+
+      case SLIDE_LONG:
+         elm_object_style_set(lb, "slide_long");
+         break;
+
+      case SLIDE_BOUNCE:
+         elm_object_style_set(lb, "slide_bounce");
+         break;
+
+      default:
+         return;
+     }
+}
+
+static void
+_change_cb(void *data, Evas_Object *obj, void *event_info __UNUSED__)
+{
+   Evas_Object *lb = (Evas_Object *)data;
+   double val = elm_slider_value_get(obj);
+   elm_label_slide_set(lb, EINA_FALSE);
+   elm_label_slide_duration_set(lb, val);
+   elm_label_slide_set(lb, EINA_TRUE);
+}
+
+void
+test_label2(void *data __UNUSED__, Evas_Object *obj __UNUSED__, void *event_info __UNUSED__)
+{
+   Evas_Object *win, *gd, *rect, *lb, *rd, *rdg, *sl;
+
+   win = elm_win_util_standard_add("label2", "Label 2");
+   elm_win_autodel_set(win, EINA_TRUE);
+
+   gd = elm_grid_add(win);
+   elm_grid_size_set(gd, 100, 100);
+   evas_object_size_hint_weight_set(gd, EVAS_HINT_EXPAND, EVAS_HINT_EXPAND);
+   elm_win_resize_object_add(win, gd);
+   evas_object_show(gd);
+
+   /* Test Label Ellipsis */
+   lb = elm_label_add(win);
+   elm_object_text_set(lb, "Test Label Ellipsis:");
+   elm_label_slide_set(lb, EINA_TRUE);
+   elm_grid_pack(gd, lb, 5, 5, 90, 10);
+   evas_object_show(lb);
+
+   rect = evas_object_rectangle_add(evas_object_evas_get(win));
+   elm_grid_pack(gd, rect, 5, 15, 90, 10);
+   evas_object_color_set(rect, 255, 125, 125, 255);
+   evas_object_show(rect);
+
+   lb = elm_label_add(win);
+   elm_object_text_set(lb,
+                       "This is a label set to ellipsis. "
+                       "If set ellipsis to true and the text doesn't fit "
+                       "in the label an ellipsis(\"...\") will be shown "
+                       "at the end of the widget."
+                       );
+   elm_label_ellipsis_set(lb, EINA_TRUE);
+   elm_grid_pack(gd, lb, 5, 15, 90, 10);
+   evas_object_show(lb);
+
+   /* Test Label Slide */
+   lb = elm_label_add(win);
+   elm_object_text_set(lb, "Test Label Slide:");
+   elm_label_slide_set(lb, EINA_TRUE);
+   elm_grid_pack(gd, lb, 5, 30, 90, 10);
+   evas_object_show(lb);
+
+   rect = evas_object_rectangle_add(evas_object_evas_get(win));
+   elm_grid_pack(gd, rect, 5, 40, 90, 10);
+   evas_object_color_set(rect, 255, 125, 125, 255);
+   evas_object_show(rect);
+
+   lb = elm_label_add(win);
+   elm_object_style_set(lb, "slide_short");
+   elm_object_text_set(lb,
+                       "This is a label set to slide. "
+                       "If set slide to true the text of the label "
+                       "will slide/scroll through the length of label."
+                       "This only works with the themes \"slide_short\", "
+                       "\"slide_long\" and \"slide_bounce\"."
+                       );
+   elm_label_slide_set(lb, EINA_TRUE);
+   elm_grid_pack(gd, lb, 5, 40, 90, 10);
+   evas_object_show(lb);
+
+   rd = elm_radio_add(win);
+   elm_radio_state_value_set(rd, SLIDE_SHORT);
+   elm_object_text_set(rd, "slide_short");
+   evas_object_size_hint_weight_set(rd, EVAS_HINT_EXPAND, EVAS_HINT_FILL);
+   evas_object_smart_callback_add(rd, "changed", _cb_size_radio_changed, lb);
+   elm_grid_pack(gd, rd, 5, 50, 30, 10);
+   evas_object_show(rd);
+   rdg = rd;
+
+   rd = elm_radio_add(win);
+   elm_radio_state_value_set(rd, SLIDE_LONG);
+   elm_radio_group_add(rd, rdg);
+   elm_object_text_set(rd, "slide_long");
+   evas_object_size_hint_weight_set(rd, EVAS_HINT_EXPAND, EVAS_HINT_FILL);
+   evas_object_smart_callback_add(rd, "changed", _cb_size_radio_changed, lb);
+   elm_grid_pack(gd, rd, 35, 50, 30, 10);
+   evas_object_show(rd);
+
+   rd = elm_radio_add(win);
+   elm_radio_state_value_set(rd, SLIDE_BOUNCE);
+   elm_radio_group_add(rd, rdg);
+   elm_object_text_set(rd, "slide_bounce");
+   evas_object_size_hint_weight_set(rd, EVAS_HINT_EXPAND, EVAS_HINT_FILL);
+   evas_object_smart_callback_add(rd, "changed", _cb_size_radio_changed, lb);
+   elm_grid_pack(gd, rd, 65, 50, 30, 10);
+   evas_object_show(rd);
+
+   sl = elm_slider_add(win);
+   elm_object_text_set(sl, "Slide Duration");
+   elm_slider_unit_format_set(sl, "%1.1f units");
+   elm_slider_min_max_set(sl, 1, 20);
+   elm_slider_value_set(sl, 10);
+   evas_object_size_hint_align_set(sl, EVAS_HINT_FILL, 0.5);
+   evas_object_size_hint_weight_set(sl, EVAS_HINT_EXPAND, EVAS_HINT_EXPAND);
+   evas_object_smart_callback_add(sl, "changed", _change_cb, lb);
+   elm_grid_pack(gd, sl, 5, 60, 90, 10);
+   evas_object_show(sl);
+
+   evas_object_resize(win, 320, 320);
+   evas_object_show(win);
+}
 #endif
index d51b9d8..d6c25bd 100644 (file)
@@ -108,8 +108,6 @@ _map_clicked_double(void *data __UNUSED__, Evas_Object *obj, void *event_info)
      {
         elm_map_overlay_del(route_start);
         elm_map_overlay_del(route_end);
-// FIXME: deprecated        
-//        elm_map_route_remove(route);
         route_start = NULL;
         route_end = NULL;
         route = NULL;
@@ -148,8 +146,7 @@ _map_longpressed(void *data __UNUSED__, Evas_Object *obj, void *event_info)
    printf("longpressed, x:%d, y:%d, lon:%lf, lat:%lf\n", down->canvas.x, down->canvas.y, lon, lat);
 
    if (elm_map_zoom_get(obj) < 8) return;
-// FIXME: deprecated        
-//   if (name) elm_map_name_remove(name);
+   if (name) elm_map_name_del(name);
    name = elm_map_name_add(obj, NULL, lon, lat, NULL, NULL);
 }
 
@@ -282,13 +279,13 @@ _map_name_loaded(void *data, Evas_Object *obj __UNUSED__, void *event_info __UNU
              Eina_Bool b = elm_map_paused_get(data);
              elm_map_paused_set(data, EINA_TRUE);
              elm_map_zoom_mode_set(data, ELM_MAP_ZOOM_MODE_MANUAL);
-             elm_map_region_show(data, lon, lat);
              elm_map_zoom_set(data, elm_map_zoom_max_get(data));
+             elm_map_region_show(data, lon, lat);
              elm_map_paused_set(data, b);
           }
      }
-// FIXME: deprecated        
-//   elm_map_name_remove(name);
+
+   elm_map_name_del(name);
    name = NULL;
 }
 
@@ -718,11 +715,14 @@ _overlay_cb(void *data __UNUSED__, Evas_Object *map, void *ev)
 static void
 _parking_cb(void *data __UNUSED__, Evas_Object *map, const Elm_Map_Overlay *ovl)
 {
-   printf("Parking clicked\n");
    if (elm_map_overlay_type_get(ovl) != ELM_MAP_OVERLAY_TYPE_DEFAULT) return;
 
    double lon, lat;
+   Evas_Coord x, y;
    elm_map_overlay_region_get(ovl, &lon, &lat);
+   elm_map_region_to_canvas_convert(map, lon, lat, &x, &y);
+   printf("Parking clicked: %lf %lf %d %d\n", lon, lat, x, y);
+
    if (!bubble_parking)
      {
         Evas_Object *bubble, *label;
@@ -761,10 +761,8 @@ _del_map(void *data __UNUSED__, Evas *e __UNUSED__, Evas_Object *obj __UNUSED__,
    bubble_parking = NULL;
    route_ovl = NULL;
 
-// FIXME: deprecated        
-//   if (route) elm_map_route_remove(route);
-// FIXME: deprecated        
-//   if (name) elm_map_name_remove(name);
+   if (route) elm_map_route_del(route);
+   if (name) elm_map_name_del(name);
    route = NULL;
    name = NULL;
 }
index ac7c3b7..939f429 100644 (file)
@@ -29,6 +29,15 @@ typedef struct _Source_Tile Source_Tile;
 typedef struct _Source_Route Source_Route;
 typedef struct _Source_Name Source_Name;
 
+typedef char                      *(*Elm_Map_Module_Source_Name_Func)(void);
+typedef int                        (*Elm_Map_Module_Tile_Zoom_Min_Func)(void);
+typedef int                        (*Elm_Map_Module_Tile_Zoom_Max_Func)(void);
+typedef char                      *(*Elm_Map_Module_Tile_Url_Func)(Evas_Object *obj, int x, int y, int zoom);
+typedef Eina_Bool                  (*Elm_Map_Module_Tile_Geo_to_Coord_Func)(const Evas_Object *obj, int zoom, double lon, double lat, int size, int *x, int *y);
+typedef Eina_Bool                  (*Elm_Map_Module_Tile_Coord_to_Geo_Func)(const Evas_Object *obj, int zoom, int x, int y, int size, double *lon, double *lat);
+typedef char                      *(*Elm_Map_Module_Route_Url_Func)(Evas_Object *obj, const char *type_name, int method, double flon, double flat, double tlon, double tlat);
+typedef char                      *(*Elm_Map_Module_Name_Url_Func)(Evas_Object *obj, int method, const char *name, double lon, double lat);
+
 #define ROUND(z)                (((z) < 0) ? (int)ceil((z) - 0.005) : (int)floor((z) + 0.005))
 #define EVAS_MAP_POINT          4
 #define DEFAULT_TILE_SIZE       256
@@ -398,14 +407,17 @@ struct _Widget_Data
    Evas_Object *sep_maps_markers; // Tiles are below this and overlays are on top
    Evas_Map *map;
 
+   Eina_Array *src_tile_mods;
    Source_Tile *src_tile;
    Eina_List *src_tiles;
    const char **src_tile_names;
 
+   Eina_Array *src_route_mods;
    Source_Route *src_route;
    Eina_List *src_routes;
    const char **src_route_names;
 
+   Eina_Array *src_name_mods;
    Source_Name *src_name;
    Eina_List *src_names;
    const char **src_name_names;
@@ -649,7 +661,7 @@ _coord_to_region_convert(Widget_Data *wd, Evas_Coord x, Evas_Coord y, Evas_Coord
 }
 
 static void
-_geo_to_coord_convert(Widget_Data *wd, double lon, double lat, Evas_Coord size, Evas_Coord *x, Evas_Coord *y)
+_region_to_coord_convert(Widget_Data *wd, double lon, double lat, Evas_Coord size, Evas_Coord *x, Evas_Coord *y)
 {
    EINA_SAFETY_ON_NULL_RETURN(wd);
 
@@ -665,7 +677,6 @@ _geo_to_coord_convert(Widget_Data *wd, double lon, double lat, Evas_Coord size,
                  / ELM_PI) / 2.0 * size);
 }
 
-
 static void
 _viewport_size_get(Widget_Data *wd, Evas_Coord *vw, Evas_Coord *vh)
 {
@@ -702,7 +713,7 @@ _region_show(void *data)
    Delayed_Data *dd = data;
    int x, y, w, h;
 
-   _geo_to_coord_convert(dd->wd, dd->lon, dd->lat, dd->wd->size.w, &x, &y);
+   _region_to_coord_convert(dd->wd, dd->lon, dd->lat, dd->wd->size.w, &x, &y);
    _viewport_size_get(dd->wd, &w, &h);
    x = x - (w / 2);
    y = y - (h / 2);
@@ -1020,7 +1031,7 @@ _marker_update(Elm_Map_Marker *marker)
         icon = clas->func.icon_get(marker->wd->obj, marker, marker->data);
         elm_object_part_content_set(marker->obj, "elm.icon", icon);
      }
-   _geo_to_coord_convert(marker->wd, marker->longitude, marker->latitude,
+   _region_to_coord_convert(marker->wd, marker->longitude, marker->latitude,
                          marker->wd->size.w, &(marker->x), &(marker->y));
 
     if (marker->bubble)
@@ -1521,8 +1532,8 @@ _track_place(Widget_Data *wd)
         double lat_min, lat_max;
         elm_route_longitude_min_max_get(route, &lon_min, &lon_max);
         elm_route_latitude_min_max_get(route, &lat_min, &lat_max);
-        _geo_to_coord_convert(wd, lon_min, lat_max, size, &xmin, &ymin);
-        _geo_to_coord_convert(wd, lon_max, lat_min, size, &xmax, &ymax);
+        _region_to_coord_convert(wd, lon_min, lat_max, size, &xmin, &ymin);
+        _region_to_coord_convert(wd, lon_max, lat_min, size, &xmax, &ymax);
 
         if( !(xmin < px && xmax < px) && !(xmin > px+ow && xmax > px+ow))
         {
@@ -1855,7 +1866,7 @@ _icon_dup(Evas_Object *icon, Evas_Object *parent)
    const char *file = NULL, *group = NULL;
    Eina_Bool size_up, size_down;
    Evas_Object *dupp;
-   
+
    dupp = elm_icon_add(parent);
    elm_icon_file_get(icon, &file, &group);
    elm_icon_file_set(dupp, file, group);
@@ -1976,7 +1987,7 @@ _overlay_default_update(Widget_Data *wd, Overlay_Default *ovl, Evas_Object *obj,
    EINA_SAFETY_ON_NULL_RETURN(wd);
    EINA_SAFETY_ON_NULL_RETURN(ovl);
 
-   _geo_to_coord_convert(wd, ovl->lon, ovl->lat, wd->size.w, &ovl->x, &ovl->y);
+   _region_to_coord_convert(wd, ovl->lon, ovl->lat, wd->size.w, &ovl->x, &ovl->y);
 
    if (obj)
      {
@@ -2203,7 +2214,7 @@ _overlay_bubble_update(Overlay_Bubble *bubble)
    EINA_SAFETY_ON_NULL_RETURN(bubble);
    if ((!bubble->pobj) && (bubble->lon >= 0) && (bubble->lat >= 0))
      {
-        _geo_to_coord_convert(bubble->wd, bubble->lon, bubble->lat,
+        _region_to_coord_convert(bubble->wd, bubble->lon, bubble->lat,
                               bubble->wd->size.w, &bubble->x, &bubble->y);
      }
 }
@@ -2361,7 +2372,7 @@ _overlay_route_show(Overlay_Route *r)
             ((n->idx % (int)ceil((double)cnt/(double)size*100.0))))) continue;
         if (r->inbound)
           {
-             _geo_to_coord_convert(wd, n->pos.lon, n->pos.lat, size,
+             _region_to_coord_convert(wd, n->pos.lon, n->pos.lat, size,
                                    &x, &y);
              if ((x >= px - ow) && (x <= (px + ow*2)) &&
                  (y >= py - oh) && (y <= (py + oh*2)))
@@ -2399,7 +2410,7 @@ _overlay_route_show(Overlay_Route *r)
           }
         else
           {
-             _geo_to_coord_convert(wd, n->pos.lon, n->pos.lat, size,
+             _region_to_coord_convert(wd, n->pos.lon, n->pos.lat, size,
                                    &x, &y);
              if ((x >= px - ow) && (x <= (px + ow*2)) &&
                  (y >= py - oh) && (y <= (py + oh*2)))
@@ -2638,8 +2649,8 @@ _overlays_show(void *data)
      {
         Evas_Coord size, max_x, max_y, min_x, min_y;
         size = pow(2.0, zoom) * dd->wd->tsize;
-        _geo_to_coord_convert(dd->wd, min_lon, max_lat, size, &min_x, &max_y);
-        _geo_to_coord_convert(dd->wd, max_lon, min_lat, size, &max_x, &min_y);
+        _region_to_coord_convert(dd->wd, min_lon, max_lat, size, &min_x, &max_y);
+        _region_to_coord_convert(dd->wd, max_lon, min_lat, size, &max_x, &min_y);
         if ((max_x - min_x) > vw || (max_y - min_y) > vh) break;
         zoom++;
      }
@@ -2810,196 +2821,6 @@ _elm_map_marker_remove(Elm_Map_Marker *marker)
 #endif
 }
 
-static void
-_on_focus_hook(void *data __UNUSED__, Evas_Object *obj)
-{
-   ELM_CHECK_WIDTYPE(obj, widtype);
-   Widget_Data *wd = elm_widget_data_get(obj);
-   EINA_SAFETY_ON_NULL_RETURN(wd);
-
-   if (elm_widget_focus_get(obj))
-     {
-        edje_object_signal_emit(elm_smart_scroller_edje_object_get(wd->scr), "elm,action,focus", "elm");
-        evas_object_focus_set(wd->obj, EINA_TRUE);
-     }
-   else
-     {
-        edje_object_signal_emit(elm_smart_scroller_edje_object_get(wd->scr), "elm,action,unfocus", "elm");
-        evas_object_focus_set(wd->obj, EINA_FALSE);
-     }
-}
-
-static void
-_del_hook(Evas_Object *obj)
-{
-   ELM_CHECK_WIDTYPE(obj, widtype);
-   Widget_Data *wd = elm_widget_data_get(obj);
-   EINA_SAFETY_ON_NULL_RETURN(wd);
-
-   if (wd->map) evas_map_free(wd->map);
-   free(wd);
-}
-
-static void
-_del_pre_hook(Evas_Object *obj)
-{
-   ELM_CHECK_WIDTYPE(obj, widtype);
-   Widget_Data *wd = elm_widget_data_get(obj);
-   EINA_SAFETY_ON_NULL_RETURN(wd);
-
-   Eina_List *l, *ll;
-   Elm_Map_Route *r;
-   Elm_Map_Name *na;
-   Evas_Object *track;
-   Elm_Map_Marker *marker;
-   Elm_Map_Group_Class *group_clas;
-   Elm_Map_Marker_Class *clas;
-   Elm_Map_Overlay *overlay;
-   Delayed_Data *dd;
-   int idx = 0;
-   Source_Tile *ts;
-   Source_Route *rs;
-   Source_Name *ns;
-
-   EINA_LIST_FOREACH_SAFE(wd->routes, l, ll, r) elm_map_route_del(r);
-   eina_list_free(wd->routes);
-
-   EINA_LIST_FOREACH_SAFE(wd->names, l, ll, na) elm_map_name_del(na);
-   eina_list_free(wd->names);
-
-   EINA_LIST_FOREACH_SAFE(wd->overlays, l, ll, overlay)
-      elm_map_overlay_del(overlay);
-   eina_list_free(wd->overlays);
-
-   EINA_LIST_FREE(wd->track, track) evas_object_del(track);
-
-   EINA_LIST_FOREACH_SAFE(wd->markers, l, ll, marker)
-     _elm_map_marker_remove(marker);
-   eina_list_free(wd->markers);
-
-   EINA_LIST_FREE(wd->group_classes, group_clas)
-     {
-        eina_list_free(group_clas->markers);
-        if (group_clas->style) eina_stringshare_del(group_clas->style);
-        free(group_clas);
-     }
-   EINA_LIST_FREE(wd->marker_classes, clas)
-     {
-        if (clas->style) eina_stringshare_del(clas->style);
-        free(clas);
-     }
-
-   if (wd->scr_timer) ecore_timer_del(wd->scr_timer);
-   if (wd->long_timer) ecore_timer_del(wd->long_timer);
-
-   if (wd->delayed_jobs) EINA_LIST_FREE(wd->delayed_jobs, dd) free(dd);
-
-   if (wd->user_agent) eina_stringshare_del(wd->user_agent);
-   if (wd->ua) eina_hash_free(wd->ua);
-
-   if (wd->zoom_timer) ecore_timer_del(wd->zoom_timer);
-   if (wd->zoom_animator) ecore_animator_del(wd->zoom_animator);
-
-   _grid_all_clear(wd);
-   // Removal of download list should be after grid clear.
-   if (wd->download_idler) ecore_idler_del(wd->download_idler);
-   eina_list_free(wd->download_list);
-
-   for (idx = 0; wd->src_tile_names[idx]; idx++)
-      eina_stringshare_del(wd->src_tile_names[idx]);
-   EINA_LIST_FREE(wd->src_tiles, ts) free(ts);
-
-   for (idx = 0; wd->src_route_names[idx]; idx++)
-      eina_stringshare_del(wd->src_route_names[idx]);
-   EINA_LIST_FREE(wd->src_routes, rs) free(rs);
-
-   for (idx = 0; wd->src_name_names[idx]; idx++)
-      eina_stringshare_del(wd->src_name_names[idx]);
-   EINA_LIST_FREE(wd->src_names, ns) free(ns);
-
-   if (!ecore_file_recursive_rm(CACHE_ROOT))
-      ERR("Deletion of %s failed", CACHE_ROOT);
-}
-
-static void
-_theme_hook(Evas_Object *obj)
-{
-   ELM_CHECK_WIDTYPE(obj, widtype);
-   Widget_Data *wd = elm_widget_data_get(obj);
-   EINA_SAFETY_ON_NULL_RETURN(wd);
-
-   elm_smart_scroller_object_theme_set(obj, wd->scr, "map", "base", elm_widget_style_get(obj));
-   _sizing_eval(wd);
-}
-
-static Eina_Bool
-_event_hook(Evas_Object *obj, Evas_Object *src __UNUSED__, Evas_Callback_Type type, void *event_info)
-{
-   ELM_CHECK_WIDTYPE(obj, widtype) EINA_FALSE;
-   Widget_Data *wd = elm_widget_data_get(obj);
-   EINA_SAFETY_ON_NULL_RETURN_VAL(wd, EINA_FALSE);
-
-   Evas_Coord x, y;
-   Evas_Coord vh;
-   Evas_Coord step_x, step_y, page_x, page_y;
-
-   if (type != EVAS_CALLBACK_KEY_DOWN) return EINA_FALSE;
-   Evas_Event_Key_Down *ev = event_info;
-   if (ev->event_flags & EVAS_EVENT_FLAG_ON_HOLD) return EINA_FALSE;
-
-   elm_smart_scroller_child_pos_get(wd->scr, &x, &y);
-   elm_smart_scroller_step_size_get(wd->scr, &step_x, &step_y);
-   elm_smart_scroller_page_size_get(wd->scr, &page_x, &page_y);
-   _viewport_size_get(wd, NULL, &vh);
-
-   if ((!strcmp(ev->keyname, "Left")) || (!strcmp(ev->keyname, "KP_Left")))
-     {
-        x -= step_x;
-     }
-   else if ((!strcmp(ev->keyname, "Right")) || (!strcmp(ev->keyname, "KP_Right")))
-     {
-        x += step_x;
-     }
-   else if ((!strcmp(ev->keyname, "Up"))  || (!strcmp(ev->keyname, "KP_Up")))
-     {
-        y -= step_y;
-     }
-   else if ((!strcmp(ev->keyname, "Down")) || (!strcmp(ev->keyname, "KP_Down")))
-     {
-        y += step_y;
-     }
-   else if ((!strcmp(ev->keyname, "Prior")) || (!strcmp(ev->keyname, "KP_Prior")))
-     {
-        if (page_y < 0)
-          y -= -(page_y * vh) / 100;
-        else
-          y -= page_y;
-     }
-   else if ((!strcmp(ev->keyname, "Next")) || (!strcmp(ev->keyname, "KP_Next")))
-     {
-        if (page_y < 0)
-          y += -(page_y * vh) / 100;
-        else
-          y += page_y;
-     }
-   else if (!strcmp(ev->keyname, "KP_Add"))
-     {
-        zoom_with_animation(wd, wd->zoom + 1, 10);
-        return EINA_TRUE;
-     }
-   else if (!strcmp(ev->keyname, "KP_Subtract"))
-     {
-        zoom_with_animation(wd, wd->zoom - 1, 10);
-        return EINA_TRUE;
-     }
-   else return EINA_FALSE;
-
-   ev->event_flags |= EVAS_EVENT_FLAG_ON_HOLD;
-   elm_smart_scroller_child_pos_set(wd->scr, x, y);
-
-   return EINA_TRUE;
-}
-
 static Eina_Bool
 cb_dump_name_attrs(void *data, const char *key, const char *value)
 {
@@ -3462,7 +3283,6 @@ _source_tile_mod_cb(Eina_Module *m, void *data)
    s->coord_to_geo = coord_to_geo;
    wd->src_tiles = eina_list_append(wd->src_tiles, s);
 
-   eina_module_unload(m);
    return EINA_TRUE;
 }
 
@@ -3472,7 +3292,6 @@ _source_tile_load(Widget_Data *wd)
    unsigned int idx;
    Eina_List *l;
    Source_Tile *s;
-   Eina_Array *modules = NULL;
 
    // Load from hard coded data
    for (idx = 0; idx < (sizeof(src_tiles) / sizeof(Source_Tile)); idx++)
@@ -3488,8 +3307,8 @@ _source_tile_load(Widget_Data *wd)
      }
 
    // Load from modules
-   modules = eina_module_list_get(modules, MODULES_PATH, 1, &_source_tile_mod_cb, wd);
-   eina_array_free(modules);
+   wd->src_tile_mods = eina_module_list_get(wd->src_tile_mods, MODULES_PATH, 1,
+                                            &_source_tile_mod_cb, wd);
 
    // Set default source
    wd->src_tile = eina_list_nth(wd->src_tiles, 0);
@@ -3507,6 +3326,18 @@ _source_tile_load(Widget_Data *wd)
 }
 
 static void
+_source_tile_unload(Widget_Data *wd)
+{
+   int idx = 0;
+   Source_Tile *s;
+
+   for (idx = 0; wd->src_tile_names[idx]; idx++)
+      eina_stringshare_del(wd->src_tile_names[idx]);
+   EINA_LIST_FREE(wd->src_tiles, s) free(s);
+   eina_module_list_free(wd->src_tile_mods);
+}
+
+static void
 _source_tile_set(Widget_Data *wd, const char *source_name)
 {
    EINA_SAFETY_ON_NULL_RETURN(wd);
@@ -3589,7 +3420,6 @@ _source_route_load(Widget_Data *wd)
    unsigned int idx;
    Eina_List *l;
    Source_Route *s;
-   Eina_Array *modules = NULL;
 
    // Load from hard coded data
    for (idx = 0; idx < (sizeof(src_routes) / sizeof(Source_Route)); idx++)
@@ -3601,8 +3431,8 @@ _source_route_load(Widget_Data *wd)
      }
 
    // Load from modules
-   modules = eina_module_list_get(modules, MODULES_PATH, 1, &_source_route_mod_cb, wd);
-   eina_array_free(modules);
+   wd->src_route_mods = eina_module_list_get(wd->src_route_mods, MODULES_PATH,
+                                            1, &_source_route_mod_cb, wd);
 
    // Set default source
    wd->src_route = eina_list_nth(wd->src_routes, 0);
@@ -3620,6 +3450,18 @@ _source_route_load(Widget_Data *wd)
 }
 
 static void
+_source_route_unload(Widget_Data *wd)
+{
+   int idx = 0;
+   Source_Route *s;
+
+   for (idx = 0; wd->src_route_names[idx]; idx++)
+      eina_stringshare_del(wd->src_route_names[idx]);
+   EINA_LIST_FREE(wd->src_routes, s) free(s);
+   eina_module_list_free(wd->src_route_mods);
+}
+
+static void
 _source_route_set(Widget_Data *wd, const char *source_name)
 {
    EINA_SAFETY_ON_NULL_RETURN(wd);
@@ -3688,7 +3530,6 @@ _source_name_load(Widget_Data *wd)
    unsigned int idx;
    Eina_List *l;
    Source_Name *s;
-   Eina_Array *modules = NULL;
 
    // Load from hard coded data
    for (idx = 0; idx < (sizeof(src_names) / sizeof(Source_Name)); idx++)
@@ -3700,8 +3541,8 @@ _source_name_load(Widget_Data *wd)
      }
 
    // Load from modules
-   modules = eina_module_list_get(modules, MODULES_PATH, 1, &_source_name_mod_cb, wd);
-   eina_array_free(modules);
+   wd->src_name_mods = eina_module_list_get(wd->src_name_mods, MODULES_PATH, 1,
+                                            &_source_name_mod_cb, wd);
 
    // Set default source
    wd->src_name = eina_list_nth(wd->src_names, 0);
@@ -3719,6 +3560,18 @@ _source_name_load(Widget_Data *wd)
 }
 
 static void
+_source_name_unload(Widget_Data *wd)
+{
+   int idx = 0;
+   Source_Name *s;
+
+   for (idx = 0; wd->src_name_names[idx]; idx++)
+      eina_stringshare_del(wd->src_name_names[idx]);
+   EINA_LIST_FREE(wd->src_names, s) free(s);
+   eina_module_list_free(wd->src_name_mods);
+}
+
+static void
 _source_name_set(Widget_Data *wd, const char *source_name)
 {
    EINA_SAFETY_ON_NULL_RETURN(wd);
@@ -3754,6 +3607,15 @@ _source_all_load(Widget_Data *wd)
 }
 
 static void
+_source_all_unload(Widget_Data *wd)
+{
+   EINA_SAFETY_ON_NULL_RETURN(wd);
+   _source_tile_unload(wd);
+   _source_route_unload(wd);
+   _source_name_unload(wd);
+}
+
+static void
 _zoom_mode_set(void *data)
 {
    EINA_SAFETY_ON_NULL_RETURN(data);
@@ -3842,7 +3704,7 @@ _region_bring_in(void *data)
    Delayed_Data *dd = data;
    int x, y, w, h;
 
-   _geo_to_coord_convert(dd->wd, dd->lon, dd->lat, dd->wd->size.w, &x, &y);
+   _region_to_coord_convert(dd->wd, dd->lon, dd->lat, dd->wd->size.w, &x, &y);
    _viewport_size_get(dd->wd, &w, &h);
    x = x - (w / 2);
    y = y - (h / 2);
@@ -3877,8 +3739,8 @@ _marker_list_show(void *data)
      {
         Evas_Coord size, max_x, max_y, min_x, min_y;
         size = pow(2.0, zoom) * dd->wd->tsize;
-        _geo_to_coord_convert(dd->wd, min_lon, max_lat, size, &min_x, &max_y);
-        _geo_to_coord_convert(dd->wd, max_lon, min_lat, size, &max_x, &min_y);
+        _region_to_coord_convert(dd->wd, min_lon, max_lat, size, &min_x, &max_y);
+        _region_to_coord_convert(dd->wd, max_lon, min_lat, size, &max_x, &min_y);
         if ((max_x - min_x) > vw || (max_y - min_y) > vh) break;
         zoom++;
      }
@@ -4015,8 +3877,181 @@ _nominatim_url_cb(Evas_Object *obj, int method, const char *name, double lon, do
    return strdup(buf);
 }
 
+static void
+_on_focus_hook(void *data __UNUSED__, Evas_Object *obj)
+{
+   ELM_CHECK_WIDTYPE(obj, widtype);
+   Widget_Data *wd = elm_widget_data_get(obj);
+   EINA_SAFETY_ON_NULL_RETURN(wd);
+
+   if (elm_widget_focus_get(obj))
+     {
+        edje_object_signal_emit(elm_smart_scroller_edje_object_get(wd->scr), "elm,action,focus", "elm");
+        evas_object_focus_set(wd->obj, EINA_TRUE);
+     }
+   else
+     {
+        edje_object_signal_emit(elm_smart_scroller_edje_object_get(wd->scr), "elm,action,unfocus", "elm");
+        evas_object_focus_set(wd->obj, EINA_FALSE);
+     }
+}
+
+static void
+_del_hook(Evas_Object *obj)
+{
+   ELM_CHECK_WIDTYPE(obj, widtype);
+   Widget_Data *wd = elm_widget_data_get(obj);
+   EINA_SAFETY_ON_NULL_RETURN(wd);
 
+   if (wd->map) evas_map_free(wd->map);
+   free(wd);
+}
 
+static void
+_del_pre_hook(Evas_Object *obj)
+{
+   ELM_CHECK_WIDTYPE(obj, widtype);
+   Widget_Data *wd = elm_widget_data_get(obj);
+   EINA_SAFETY_ON_NULL_RETURN(wd);
+
+   Eina_List *l, *ll;
+   Elm_Map_Route *r;
+   Elm_Map_Name *na;
+   Evas_Object *track;
+   Elm_Map_Marker *marker;
+   Elm_Map_Group_Class *group_clas;
+   Elm_Map_Marker_Class *clas;
+   Elm_Map_Overlay *overlay;
+   Delayed_Data *dd;
+
+   EINA_LIST_FOREACH_SAFE(wd->routes, l, ll, r) elm_map_route_del(r);
+   eina_list_free(wd->routes);
+
+   EINA_LIST_FOREACH_SAFE(wd->names, l, ll, na) elm_map_name_del(na);
+   eina_list_free(wd->names);
+
+   EINA_LIST_FOREACH_SAFE(wd->overlays, l, ll, overlay)
+      elm_map_overlay_del(overlay);
+   eina_list_free(wd->overlays);
+
+   EINA_LIST_FREE(wd->track, track) evas_object_del(track);
+
+   EINA_LIST_FOREACH_SAFE(wd->markers, l, ll, marker)
+      _elm_map_marker_remove(marker);
+   eina_list_free(wd->markers);
+
+   EINA_LIST_FREE(wd->group_classes, group_clas)
+     {
+        eina_list_free(group_clas->markers);
+        if (group_clas->style) eina_stringshare_del(group_clas->style);
+        free(group_clas);
+     }
+   EINA_LIST_FREE(wd->marker_classes, clas)
+     {
+        if (clas->style) eina_stringshare_del(clas->style);
+        free(clas);
+     }
+
+   if (wd->scr_timer) ecore_timer_del(wd->scr_timer);
+   if (wd->long_timer) ecore_timer_del(wd->long_timer);
+
+   if (wd->delayed_jobs) EINA_LIST_FREE(wd->delayed_jobs, dd) free(dd);
+
+   if (wd->user_agent) eina_stringshare_del(wd->user_agent);
+   if (wd->ua) eina_hash_free(wd->ua);
+
+   if (wd->zoom_timer) ecore_timer_del(wd->zoom_timer);
+   if (wd->zoom_animator) ecore_animator_del(wd->zoom_animator);
+
+   _grid_all_clear(wd);
+   // Removal of download list should be after grid clear.
+   if (wd->download_idler) ecore_idler_del(wd->download_idler);
+   eina_list_free(wd->download_list);
+
+   _source_all_unload(wd);
+
+   if (!ecore_file_recursive_rm(CACHE_ROOT))
+      ERR("Deletion of %s failed", CACHE_ROOT);
+}
+
+static void
+_theme_hook(Evas_Object *obj)
+{
+   ELM_CHECK_WIDTYPE(obj, widtype);
+   Widget_Data *wd = elm_widget_data_get(obj);
+   EINA_SAFETY_ON_NULL_RETURN(wd);
+
+   elm_smart_scroller_object_theme_set(obj, wd->scr, "map", "base", elm_widget_style_get(obj));
+   _sizing_eval(wd);
+}
+
+static Eina_Bool
+_event_hook(Evas_Object *obj, Evas_Object *src __UNUSED__, Evas_Callback_Type type, void *event_info)
+{
+   ELM_CHECK_WIDTYPE(obj, widtype) EINA_FALSE;
+   Widget_Data *wd = elm_widget_data_get(obj);
+   EINA_SAFETY_ON_NULL_RETURN_VAL(wd, EINA_FALSE);
+
+   Evas_Coord x, y;
+   Evas_Coord vh;
+   Evas_Coord step_x, step_y, page_x, page_y;
+
+   if (type != EVAS_CALLBACK_KEY_DOWN) return EINA_FALSE;
+   Evas_Event_Key_Down *ev = event_info;
+   if (ev->event_flags & EVAS_EVENT_FLAG_ON_HOLD) return EINA_FALSE;
+
+   elm_smart_scroller_child_pos_get(wd->scr, &x, &y);
+   elm_smart_scroller_step_size_get(wd->scr, &step_x, &step_y);
+   elm_smart_scroller_page_size_get(wd->scr, &page_x, &page_y);
+   _viewport_size_get(wd, NULL, &vh);
+
+   if ((!strcmp(ev->keyname, "Left")) || (!strcmp(ev->keyname, "KP_Left")))
+     {
+        x -= step_x;
+     }
+   else if ((!strcmp(ev->keyname, "Right")) || (!strcmp(ev->keyname, "KP_Right")))
+     {
+        x += step_x;
+     }
+   else if ((!strcmp(ev->keyname, "Up"))  || (!strcmp(ev->keyname, "KP_Up")))
+     {
+        y -= step_y;
+     }
+   else if ((!strcmp(ev->keyname, "Down")) || (!strcmp(ev->keyname, "KP_Down")))
+     {
+        y += step_y;
+     }
+   else if ((!strcmp(ev->keyname, "Prior")) || (!strcmp(ev->keyname, "KP_Prior")))
+     {
+        if (page_y < 0)
+          y -= -(page_y * vh) / 100;
+        else
+          y -= page_y;
+     }
+   else if ((!strcmp(ev->keyname, "Next")) || (!strcmp(ev->keyname, "KP_Next")))
+     {
+        if (page_y < 0)
+          y += -(page_y * vh) / 100;
+        else
+          y += page_y;
+     }
+   else if (!strcmp(ev->keyname, "KP_Add"))
+     {
+        zoom_with_animation(wd, wd->zoom + 1, 10);
+        return EINA_TRUE;
+     }
+   else if (!strcmp(ev->keyname, "KP_Subtract"))
+     {
+        zoom_with_animation(wd, wd->zoom - 1, 10);
+        return EINA_TRUE;
+     }
+   else return EINA_FALSE;
+
+   ev->event_flags |= EVAS_EVENT_FLAG_ON_HOLD;
+   elm_smart_scroller_child_pos_set(wd->scr, x, y);
+
+   return EINA_TRUE;
+}
 #endif
 
 EAPI Evas_Object *
@@ -4523,8 +4558,6 @@ elm_map_canvas_to_region_convert(const Evas_Object *obj, Evas_Coord x, Evas_Coor
 #endif
 }
 
-// FIXME: Make it!
-/*
 EAPI void
 elm_map_region_to_canvas_convert(const Evas_Object *obj, double lon, double lat, Evas_Coord *x, Evas_Coord *y)
 {
@@ -4535,6 +4568,14 @@ elm_map_region_to_canvas_convert(const Evas_Object *obj, double lon, double lat,
    EINA_SAFETY_ON_NULL_RETURN(x);
    EINA_SAFETY_ON_NULL_RETURN(y);
 
+   Evas_Coord px, py, vw, vh;
+   _pan_geometry_get(wd, &px, &py);
+   _viewport_size_get(wd, &vw, &vh);
+   _region_to_coord_convert(wd, lon, lat, wd->size.w, x, y);
+   _coord_rotate(*x, *y, (vw / 2) - px, (vh / 2) - py, wd->rotate.d,
+                 x, y);
+   *x += px;
+   *y += py;
 #else
    (void) obj;
    (void) lon;
@@ -4542,7 +4583,7 @@ elm_map_region_to_canvas_convert(const Evas_Object *obj, double lon, double lat,
    (void) x;
    (void) y;
 #endif
-}*/
+}
 
 EAPI void
 elm_map_user_agent_set(Evas_Object *obj, const char *user_agent)
@@ -5718,7 +5759,7 @@ elm_map_utils_convert_geo_into_coord(const Evas_Object *obj, double lon, double
    Widget_Data *wd = elm_widget_data_get(obj);
    EINA_SAFETY_ON_NULL_RETURN(wd);
 
-   _geo_to_coord_convert(wd, lon, lat, size, x, y);
+   _region_to_coord_convert(wd, lon, lat, size, x, y);
 #else
    (void) obj;
    (void) lon;
index 26992d2..93aed6e 100644 (file)
@@ -185,15 +185,6 @@ typedef void                       (*Elm_Map_Overlay_Get_Cb)(void *data, Evas_Ob
 typedef void                       (*Elm_Map_Name_Cb)(void *data, Evas_Object *map, const Elm_Map_Name *name);                /**< Async-callback function for the name request. */
 typedef void                       (*Elm_Map_Route_Cb)(void *data, Evas_Object *map, const Elm_Map_Route *route);             /**< Async-callback function for the route request. */
 
-typedef char                      *(*Elm_Map_Module_Source_Name_Func)(void);
-typedef int                        (*Elm_Map_Module_Tile_Zoom_Min_Func)(void);
-typedef int                        (*Elm_Map_Module_Tile_Zoom_Max_Func)(void);
-typedef char                      *(*Elm_Map_Module_Tile_Url_Func)(Evas_Object *obj, int x, int y, int zoom);
-typedef Eina_Bool                  (*Elm_Map_Module_Tile_Geo_to_Coord_Func)(const Evas_Object *obj, int zoom, double lon, double lat, int size, int *x, int *y);
-typedef Eina_Bool                  (*Elm_Map_Module_Tile_Coord_to_Geo_Func)(const Evas_Object *obj, int zoom, int x, int y, int size, double *lon, double *lat);
-typedef char                      *(*Elm_Map_Module_Route_Url_Func)(Evas_Object *obj, const char *type_name, int method, double flon, double flat, double tlon, double tlat);
-typedef char                      *(*Elm_Map_Module_Name_Url_Func)(Evas_Object *obj, int method, const char *name, double lon, double lat);
-
 /**
  * Add a new map widget to the given parent Elementary (container) object.
  *
@@ -394,7 +385,7 @@ EAPI void                  elm_map_region_bring_in(Evas_Object *obj, double lon,
 EAPI void                  elm_map_region_show(Evas_Object *obj, double lon, double lat);
 
 /**
- * Convert canvas coordinates into a geographic coordinate
+ * Convert canvas coordinates into geographic coordinates
  * (longitude, latitude).
  *
  * @param obj The map object.
@@ -406,13 +397,32 @@ EAPI void                  elm_map_region_show(Evas_Object *obj, double lon, dou
  * This gets longitude and latitude from canvas x, y coordinates. The canvas
  * coordinates mean x, y coordinate from current viewport.
  *
- * see elm_map_rotate_get()
+ * see elm_map_region_to_canvas_convert()
  *
  * @ingroup Map
  */
 EAPI void                  elm_map_canvas_to_region_convert(const Evas_Object *obj, const Evas_Coord x, const Evas_Coord y, double *lon, double *lat);
 
 /**
+ * Convert geographic coordinates (longitude, latitude)
+ * into canvas coordinates.
+ *
+ * @param obj The map object.
+ * @param lon The longitude to convert.
+ * @param lat The latitude to convert.
+ * @param x   A pointer to horizontal coordinate.
+ * @param y   A pointer to vertical coordinatet.
+ *
+ * This gets canvas x, y coordinates from longitude and latitude. The canvas
+ * coordinates mean x, y coordinate from current viewport.
+ *
+ * see elm_map_canvas_to_region_convert()
+ *
+ * @ingroup Map
+ */
+EAPI void                  elm_map_region_to_canvas_convert(const Evas_Object *obj, double lon, double lat, Evas_Coord *x, Evas_Coord *y);
+
+/**
  * Pause or unpause the map.
  *
  * @param obj The map object.
@@ -1365,3 +1375,4 @@ EAPI Evas_Object          *elm_map_track_add(Evas_Object *obj, void *emap);
  * @ingroup Map
  */
 EAPI void                  elm_map_track_remove(Evas_Object *obj, Evas_Object *route);
+