From: Bluezery <ohpowel@gmail.com>
[framework/uifw/elementary.git] / src / bin / test_map.c
index 8704ed1..bf1b0d2 100644 (file)
 #define MARKER_MAX 1000
 #define NAME_ENTRY_TEXT "Enter freeform address"
 
-typedef struct Marker_Data
+typedef struct Overlay_Data
 {
    const char *file;
-} Marker_Data;
+} Overlay_Data;
 
 typedef struct Map_Source
 {
    Evas_Object *map;
+   Elm_Map_Source_Type type;
    char *source_name;
 } Map_Source;
 
-static Elm_Map_Marker_Class *itc1, *itc2, *itc_parking;
-static Elm_Map_Group_Class *itc_group1, *itc_group2, *itc_group_parking;
-
-static Evas_Object *rect, *menu;
-static int nb_elts;
-/*static Elm_Map_Marker *markers[MARKER_MAX];*/
-static Elm_Map_Marker *route_from, *route_to;
+Overlay_Data data1 = {PACKAGE_DATA_DIR"/images/logo.png"};
+Overlay_Data data2 = {PACKAGE_DATA_DIR"/images/logo_small.png"};
+Overlay_Data data3 = {PACKAGE_DATA_DIR"/images/panel_01.jpg"};
+Overlay_Data data4 = {PACKAGE_DATA_DIR"/images/plant_01.jpg"};
+Overlay_Data data5 = {PACKAGE_DATA_DIR"/images/rock_01.jpg"};
+Overlay_Data data6 = {PACKAGE_DATA_DIR"/images/rock_02.jpg"};
+Overlay_Data data7 = {PACKAGE_DATA_DIR"/images/sky_01.jpg"};
+Overlay_Data data8 = {PACKAGE_DATA_DIR"/images/sky_02.jpg"};
+Overlay_Data data9 = {PACKAGE_DATA_DIR"/images/sky_03.jpg"};
+Overlay_Data data10 = {PACKAGE_DATA_DIR"/images/sky_03.jpg"};
+Overlay_Data data11= {PACKAGE_DATA_DIR"/images/wood_01.jpg"};
+Overlay_Data parking= {PACKAGE_DATA_DIR"/images/parking.png"};
+Overlay_Data icon_data = {PACKAGE_DATA_DIR"/images/icon_14.png"};
+
+static Elm_Map_Overlay *route_start, *route_end, *route_clas;
+static Elm_Map_Overlay *bubble_img;
+static Elm_Map_Overlay *bubble_parking;
+static Elm_Map_Overlay *route_ovl;
+static Elm_Map_Overlay *line_start, *line_end, *line;
+static Elm_Map_Overlay *poly;
+static Elm_Map_Overlay *circle;
+static Elm_Map_Overlay *scale;
+static Eina_List *poly_points;
+
+static Evas_Object *menu, *fs_win;
 static Elm_Map_Route *route;
 static Elm_Map_Name *name;
-static const char **source_names = NULL;
-static Evas_Coord old_x, old_y;
-static Evas_Coord old_d;
-static Map_Source ms[SOURCE_MAX];
+static Evas_Object *track;
+static Evas_Coord down_x, down_y;
+static Evas_Coord old_x, old_y, old_d;
+static Map_Source ts[SOURCE_MAX];
+static Map_Source rs[SOURCE_MAX];
+static Map_Source ns[SOURCE_MAX];
+
+static void
+#ifdef ELM_EMAP
+my_map_gpx_fileselector_done(void *data, Evas_Object *obj __UNUSED__, void *event_info)
+#else
+my_map_gpx_fileselector_done(void *data __UNUSED__, Evas_Object *obj __UNUSED__, void *event_info)
+#endif
+{
+   const char *selected = event_info;
+
+   if (selected)
+     {
+        printf("Selected file: %s\n", selected);
+#ifdef ELM_EMAP
+        EMap_Route *emap = emap_route_gpx_new(selected);
+        track = elm_map_track_add(data, emap);
+#else
+        printf("libEMap is required !\n");
+#endif
+     }
+   evas_object_del(fs_win);
+}
+
+static Evas_Object *
+_route_icon_get(Evas_Object *obj)
+{
+   Evas_Object *icon = elm_icon_add(obj);
+   elm_icon_file_set(icon, PACKAGE_DATA_DIR"/images/bubble.png", NULL);
+   evas_object_show(icon);
+
+   return icon;
+}
+
+static Evas_Object *
+_box_get(Evas_Object *obj, Overlay_Data *data, Elm_Map_Overlay *ovl)
+{
+   Evas_Object *bx, *img, *label;
+   double lon, lat;
+   char buf[256];
+   bx = elm_box_add(obj);
+   evas_object_show(bx);
+
+   img = evas_object_image_add(evas_object_evas_get(obj));
+   evas_object_image_file_set(img, data->file, NULL);
+   evas_object_image_filled_set(img, EINA_TRUE);
+   evas_object_size_hint_min_set(img, 64, 64);
+   evas_object_show(img);
+   elm_box_pack_end(bx, img);
+
+   label = elm_label_add(bx);
+   elm_map_overlay_region_get(ovl, &lon, &lat);
+   snprintf(buf, sizeof(buf), "%0.4lf %0.4lf", lon, lat);
+   elm_object_text_set(label, buf);
+   evas_object_show(label);
+   elm_box_pack_end(bx, label);
+   return bx;
+}
+
+static Evas_Object *
+_label_get(Evas_Object *obj)
+{
+   Evas_Object *label;
+   label = elm_label_add(obj);
+   elm_object_text_set(label, "Here is a parking lot.");
+   return label;
+}
 
-Marker_Data data1 = {PACKAGE_DATA_DIR"/images/logo.png"};
-Marker_Data data2 = {PACKAGE_DATA_DIR"/images/logo_small.png"};
-Marker_Data data3 = {PACKAGE_DATA_DIR"/images/panel_01.jpg"};
-Marker_Data data4 = {PACKAGE_DATA_DIR"/images/plant_01.jpg"};
-Marker_Data data5 = {PACKAGE_DATA_DIR"/images/rock_01.jpg"};
-Marker_Data data6 = {PACKAGE_DATA_DIR"/images/rock_02.jpg"};
-Marker_Data data7 = {PACKAGE_DATA_DIR"/images/sky_01.jpg"};
-Marker_Data data8 = {PACKAGE_DATA_DIR"/images/sky_02.jpg"};
-Marker_Data data9 = {PACKAGE_DATA_DIR"/images/sky_03.jpg"};
-Marker_Data data10 = {PACKAGE_DATA_DIR"/images/sky_03.jpg"};
-Marker_Data data11= {PACKAGE_DATA_DIR"/images/wood_01.jpg"};
+static Evas_Object *
+_icon_get(Evas_Object *obj, Overlay_Data *data)
+{
+   Evas_Object *icon = elm_icon_add(obj);
+   elm_icon_file_set(icon, data->file, NULL);
+   evas_object_show(icon);
 
-Marker_Data data_parking= {PACKAGE_DATA_DIR"/images/parking.png"};
+   return icon;
+}
 
-static Evas_Object * _marker_get(Evas_Object *obj, Elm_Map_Marker *marker __UNUSED__, void *data);
-static Evas_Object * _group_icon_get(Evas_Object *obj, void *data);
+static void
+_overlay_hide(void *data, Evas_Object *obj __UNUSED__, void *ev __UNUSED__)
+{
+   elm_map_overlay_hide_set(data, EINA_TRUE);
+}
 
 static void
-my_map_clicked(void *data __UNUSED__, Evas_Object *obj __UNUSED__, void *event_info __UNUSED__)
+_overlay_pause(void *data, Evas_Object *obj __UNUSED__, void *ev __UNUSED__)
 {
-   printf("clicked\n");
+   elm_map_overlay_paused_set(data, EINA_TRUE);
 }
 
 static void
-my_map_press(void *data __UNUSED__, Evas_Object *obj __UNUSED__, void *event_info __UNUSED__)
+_overlay_unpause(void *data, Evas_Object *obj __UNUSED__, void *ev __UNUSED__)
 {
-   printf("press\n");
+   elm_map_overlay_paused_set(data, EINA_FALSE);
 }
 
 static void
-my_map_longpressed(void *data, Evas_Object *obj __UNUSED__, void *event_info)
+_overlay_show(void *data, Evas_Object *obj __UNUSED__, void *ev __UNUSED__)
 {
-   double lon, lat;
-   Evas_Coord ox, oy, x, y, w, h;
-   int zoom;
-   Evas_Event_Mouse_Down *down = (Evas_Event_Mouse_Down *)event_info;
-   if (!down) return;
+   elm_map_overlay_show(data);
+}
+
+static Evas_Object *
+_btn_box_get(Evas_Object *obj, Elm_Map_Overlay *ovl)
+{
+   Evas_Object *bx, *btn, *btn2, *btn3, *btn4;
+   bx = elm_box_add(obj);
+   elm_box_horizontal_set(bx, EINA_TRUE);
+   evas_object_show(bx);
 
-   evas_object_geometry_get(data, &ox, &oy, &w, &h);
-   zoom = elm_map_zoom_get(data);
-   elm_map_geo_region_get(obj, &lon, &lat);
-   elm_map_utils_convert_geo_into_coord(obj, lon, lat, pow(2.0, zoom) * 256, &x, &y);
-   x += down->output.x - (w / 2) - ox;
-   y += down->output.y - (h / 2) - oy;
-   elm_map_utils_convert_coord_into_geo(obj, x, y, pow(2.0, zoom) * 256, &lon, &lat);
+   btn = elm_button_add(bx);
+   elm_object_text_set(btn, "Hide");
+   evas_object_smart_callback_add(btn, "clicked", _overlay_hide, ovl);
+   evas_object_show(btn);
+   elm_box_pack_end(bx, btn);
+
+   btn2 = elm_button_add(bx);
+   elm_object_text_set(btn2, "Pause");
+   evas_object_smart_callback_add(btn2, "clicked", _overlay_pause, ovl);
+   evas_object_show(btn2);
+   elm_box_pack_end(bx, btn2);
+
+   btn3 = elm_button_add(bx);
+   elm_object_text_set(btn3, "Unpause");
+   evas_object_smart_callback_add(btn3, "clicked", _overlay_unpause, ovl);
+   evas_object_show(btn3);
+   elm_box_pack_end(bx, btn3);
+
+   btn4 = elm_button_add(bx);
+   elm_object_text_set(btn4, "Show");
+   evas_object_smart_callback_add(btn4, "clicked", _overlay_show, ovl);
+   evas_object_show(btn4);
+   elm_box_pack_end(bx, btn4);
 
-   name = elm_map_utils_convert_coord_into_name(data, lon, lat);
+   return bx;
 }
 
 static void
-my_map_clicked_double(void *data, Evas_Object *obj, void *event_info)
+_bubble_parking_follow(Evas_Object *map)
 {
    double lon, lat;
-   double flon, flat, tlon, tlat;
-   Evas_Coord ox, oy, x, y, w, h, rx, ry, tx, ty;
-   double d;
-   int zoom;
-   Evas_Coord size;
-   Evas_Event_Mouse_Down *down = (Evas_Event_Mouse_Down *)event_info;
-   if (!down) return;
+   Evas_Coord x, y;
 
-   evas_object_geometry_get(data, &ox, &oy, &w, &h);
-   zoom = elm_map_zoom_get(data);
-   if (zoom < 5) return;
-   size = pow(2.0, zoom) * 256;
-   elm_map_geo_region_get(obj, &lon, &lat);
-   elm_map_utils_convert_geo_into_coord(obj, lon, lat, size, &x, &y);
-
-   rx = x;
-   ry = y;
-   x += down->output.x - ((float)w * 0.5) - ox;
-   y += down->output.y - ((float)h * 0.5) - oy;
-   elm_map_rotate_get(data, &d, NULL, NULL);
-   elm_map_utils_rotate_coord(data, x, y, rx, ry, -d, &tx, &ty);
-   elm_map_utils_convert_coord_into_geo(obj, tx, ty, size, &lon, &lat);
+   if (bubble_parking)
+     {
+        Elm_Map_Overlay *ovl = elm_map_overlay_data_get(bubble_parking);
+        elm_map_overlay_region_get(ovl, &lon, &lat);
+        elm_map_region_to_canvas_convert(map, lon, lat, &x, &y);
+        elm_map_canvas_to_region_convert(map, x+40, y+50, &lon, &lat);
+        elm_map_overlay_region_set(bubble_parking, lon, lat);
+     }
+}
+
+static void
+_map_clicked(void *data __UNUSED__, Evas_Object *obj __UNUSED__, void *event_info __UNUSED__)
+{
+   printf("clicked\n");
+}
 
-   itc1 = elm_map_marker_class_new(data);
+static void
+_map_clicked_double(void *data __UNUSED__, Evas_Object *obj, void *event_info)
+{
+   printf("clicked,double\n");
+   double lon, lat;
+   Evas_Event_Mouse_Down *down = event_info;
+   if (!down) return;
+   if (elm_map_zoom_get(obj) < 5) return;
 
-   elm_map_marker_class_del_cb_set(itc1, NULL);
+   elm_map_canvas_to_region_convert(obj, down->canvas.x, down->canvas.y, &lon, &lat);
+   printf("x:%d, y:%d, lon:%lf, lat:%lf\n", down->canvas.x, down->canvas.y, lon, lat);
 
-   itc_group1 = elm_map_group_class_new(data);
-   elm_map_group_class_icon_cb_set(itc_group1, _group_icon_get);
-   elm_map_group_class_data_set(itc_group1, (void *)PACKAGE_DATA_DIR"/images/bubble.png");
-   elm_map_group_class_style_set(itc_group1, "empty");
-   elm_map_group_class_zoom_displayed_set(itc_group1, 5);
+   if (!route_clas)
+     {
+        route_clas = elm_map_overlay_class_add(obj);
+        elm_map_overlay_icon_set(route_clas, _route_icon_get(obj));
+        elm_map_overlay_displayed_zoom_min_set(route_clas, 5);
+     }
 
-   if (route_from && route_to)
+   if (route_start && route_end)
      {
-        elm_map_marker_remove(route_from);
-        route_from = NULL;
-        elm_map_marker_remove(route_to);
-        route_to = NULL;
-        elm_map_route_remove(route);
+        elm_map_overlay_del(route_start);
+        elm_map_overlay_del(route_end);
+        elm_map_route_del(route);
+        route_start = NULL;
+        route_end = NULL;
+        route = NULL;
      }
 
-   if (!route_from) route_from = elm_map_marker_add(data, lon, lat, itc1, itc_group1, NULL);
-   else route_to = elm_map_marker_add(data, lon, lat, itc1, itc_group1, NULL);
+   if (!route_start) route_start = elm_map_overlay_add(obj, lon, lat);
+   else route_end = elm_map_overlay_add(obj, lon, lat);
 
-   if (route_from && route_to)
+   if (route_start && route_end)
      {
-        elm_map_marker_region_get(route_from, &flon, &flat);
-        elm_map_marker_region_get(route_to, &tlon, &tlat);
-        route = elm_map_route_add(data, ELM_MAP_ROUTE_TYPE_MOTOCAR, ELM_MAP_ROUTE_METHOD_FASTEST, flon, flat, tlon, tlat);
-        elm_map_route_color_set(route, 255, 0, 0, 255);
+        double start_lon, start_lat, end_lon, end_lat;
+        elm_map_overlay_class_append(route_clas, route_start);
+        elm_map_overlay_class_append(route_clas, route_end);
+        elm_map_overlay_region_get(route_start, &start_lon, &start_lat);
+        elm_map_overlay_region_get(route_end, &end_lon, &end_lat);
+        route = elm_map_route_add(obj, ELM_MAP_ROUTE_TYPE_MOTOCAR,
+                                     ELM_MAP_ROUTE_METHOD_FASTEST,
+                                     start_lon, start_lat, end_lon, end_lat,
+                                     NULL, NULL);
      }
 }
 
 static void
-my_map_load_detail(void *data __UNUSED__, Evas_Object *obj __UNUSED__, void *event_info __UNUSED__)
+_map_press(void *data __UNUSED__, Evas_Object *obj __UNUSED__, void *event_info __UNUSED__)
 {
-   printf("load,detail\n");
+   printf("press\n");
 }
 
 static void
-my_map_loaded_detail(void *data __UNUSED__, Evas_Object *obj __UNUSED__, void *event_info __UNUSED__)
+_map_longpressed(void *data __UNUSED__, Evas_Object *obj, void *event_info)
 {
-   printf("loaded,detail\n");
+   if (!event_info) return;
+   double lon, lat;
+   Evas_Event_Mouse_Down *down = (Evas_Event_Mouse_Down *)event_info;
+   elm_map_canvas_to_region_convert(obj, down->canvas.x, down->canvas.y, &lon, &lat);
+   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;
+   if (name) elm_map_name_del(name);
+   name = elm_map_name_add(obj, NULL, lon, lat, NULL, NULL);
 }
 
 static void
-my_map_zoom_start(void *data __UNUSED__, Evas_Object *obj __UNUSED__, void *event_info __UNUSED__)
+_map_scroll(void *data __UNUSED__, Evas_Object *obj, void *event_info __UNUSED__)
 {
-   printf("zoom,start\n");
+   double lon, lat;
+   elm_map_region_get(obj, &lon, &lat);
+   printf("scroll, longitude: %f latitude: %f\n", lon, lat);
+   _bubble_parking_follow(obj);
 }
 
 static void
-my_map_zoom_stop(void *data __UNUSED__, Evas_Object *obj __UNUSED__, void *event_info __UNUSED__)
+_map_drag_start(void *data, Evas_Object *obj __UNUSED__, void *event_info __UNUSED__)
 {
-   printf("zoom,stop\n");
+   printf("scroll,drag,start\n");
+   evas_object_smart_callback_del(data, "longpressed", _map_longpressed);
 }
 
 static void
-my_map_zoom_change(void *data __UNUSED__, Evas_Object *obj __UNUSED__, void *event_info __UNUSED__)
+_map_drag_stop(void *data, Evas_Object *obj __UNUSED__, void *event_info __UNUSED__)
 {
-   printf("zoom,change\n");
+   printf("scroll,drag,stop\n");
+   evas_object_smart_callback_add(data, "longpressed", _map_longpressed, data);
 }
 
 static void
-my_map_anim_start(void *data __UNUSED__, Evas_Object *obj __UNUSED__, void *event_info __UNUSED__)
+_map_anim_start(void *data __UNUSED__, Evas_Object *obj __UNUSED__, void *event_info __UNUSED__)
 {
-   printf("anim,start\n");
+   printf("scroll,anim,start\n");
 }
 
 static void
-my_map_anim_stop(void *data __UNUSED__, Evas_Object *obj __UNUSED__, void *event_info __UNUSED__)
+_map_anim_stop(void *data __UNUSED__, Evas_Object *obj __UNUSED__, void *event_info __UNUSED__)
 {
-   printf("anim,stop\n");
+   printf("scroll,anim,stop\n");
 }
 
 static void
-my_map_drag_start(void *data, Evas_Object *obj __UNUSED__, void *event_info __UNUSED__)
+_map_zoom_start(void *data __UNUSED__, Evas_Object *obj __UNUSED__, void *event_info __UNUSED__)
 {
-   evas_object_smart_callback_del(data, "longpressed", my_map_longpressed);
+   printf("zoom,start\n");
 }
 
 static void
-my_map_drag_stop(void *data, Evas_Object *obj __UNUSED__, void *event_info __UNUSED__)
+_map_zoom_stop(void *data __UNUSED__, Evas_Object *obj __UNUSED__, void *event_info __UNUSED__)
 {
-   evas_object_smart_callback_add(data, "longpressed", my_map_longpressed, data);
+   printf("zoom,stop\n");
+   _bubble_parking_follow(obj);
 }
 
 static void
-my_map_scroll(void *data __UNUSED__, Evas_Object *obj, void *event_info __UNUSED__)
+_map_zoom_change(void *data __UNUSED__, Evas_Object *obj __UNUSED__, void *event_info __UNUSED__)
 {
-   double lon, lat;
-   elm_map_geo_region_get(obj, &lon, &lat);
-   printf("scroll longitude : %f latitude : %f\n", lon, lat);
+   printf("zoom,change\n");
 }
 
 static void
-my_map_downloaded(void *data, Evas_Object *obj __UNUSED__, void *event_info __UNUSED__)
+_map_tile_load(void *data __UNUSED__, Evas_Object *obj __UNUSED__, void *event_info __UNUSED__)
+{
+   printf("tile,load\n");
+}
+
+static void
+_map_tile_loaded(void *data, Evas_Object *obj __UNUSED__, void *event_info __UNUSED__)
+{
+   int try_num, finish_num;
+   elm_map_tile_load_status_get(data, &try_num, &finish_num);
+   printf("tile,loaded: %d / %d\n", finish_num, try_num);
+}
+
+static void
+_map_tile_loaded_fail(void *data, Evas_Object *obj __UNUSED__, void *event_info __UNUSED__)
 {
    int try_num, finish_num;
-   elm_map_utils_downloading_status_get(data, &try_num, &finish_num);
-   printf("downloaded : %d / %d\n", finish_num, try_num);
+   elm_map_tile_load_status_get(data, &try_num, &finish_num);
+   printf("tile,loaded,fail: %d / %d\n", finish_num, try_num);
 }
 
 static void
-my_map_route_load(void *data __UNUSED__, Evas_Object *obj __UNUSED__, void *event_info __UNUSED__)
+_map_route_load(void *data __UNUSED__, Evas_Object *obj __UNUSED__, void *event_info __UNUSED__)
 {
-   printf("route_load\n");
+   printf("route,load\n");
 }
 
 static void
-my_map_route_loaded(void *data __UNUSED__, Evas_Object *obj __UNUSED__, void *event_info __UNUSED__)
+_map_route_loaded(void *data __UNUSED__, Evas_Object *obj, void *event_info __UNUSED__)
 {
+   printf("route,loaded\n");
    double d;
    const char *w, *n;
+
    d = elm_map_route_distance_get(route);
    printf("route distance = %lf km\n", d);
 
@@ -229,17 +374,27 @@ my_map_route_loaded(void *data __UNUSED__, Evas_Object *obj __UNUSED__, void *ev
 
    n = elm_map_route_node_get(route);
    if (n) printf("[nodes]\n%s\n", n);
+
+   if (route_ovl) elm_map_overlay_del(route_ovl);
+   route_ovl = elm_map_overlay_route_add(obj, route);
+}
+
+static void
+_map_route_loaded_fail(void *data __UNUSED__, Evas_Object *obj __UNUSED__, void *event_info __UNUSED__)
+{
+   printf("route,loaded,fail\n");
 }
 
 static void
-my_map_name_load(void *data __UNUSED__, Evas_Object *obj __UNUSED__, void *event_info __UNUSED__)
+_map_name_load(void *data __UNUSED__, Evas_Object *obj __UNUSED__, void *event_info __UNUSED__)
 {
-   printf("name_load\n");
+   printf("name,load\n");
 }
 
 static void
-my_map_name_loaded(void *data, Evas_Object *obj __UNUSED__, void *event_info __UNUSED__)
+_map_name_loaded(void *data, Evas_Object *obj __UNUSED__, void *event_info __UNUSED__)
 {
+   printf("name,loaded\n");
    if (!name) return;
    double lon, lat;
    const char *addr = elm_map_name_address_get(name);
@@ -252,45 +407,61 @@ my_map_name_loaded(void *data, Evas_Object *obj __UNUSED__, void *event_info __U
              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_geo_region_show(data, lon, lat);
-             elm_map_zoom_set(data, 18);
+             elm_map_zoom_set(data, elm_map_zoom_max_get(data));
+             elm_map_region_show(data, lon, lat);
              elm_map_paused_set(data, b);
           }
      }
-   elm_map_name_remove(name);
+
+   elm_map_name_del(name);
+   name = NULL;
 }
 
 static void
-map_show_seoul(void *data, Evas_Object *obj __UNUSED__, void *event_info __UNUSED__)
+_map_name_loaded_fail(void *data __UNUSED__, Evas_Object *obj __UNUSED__, void *event_info __UNUSED__)
+{
+   printf("name,loaded,fail\n");
+}
+
+static void
+_src_set(void *data, Evas_Object *obj __UNUSED__, void *event_info __UNUSED__)
+{
+   Map_Source *s = data;
+
+   if (!s) return;
+   elm_map_source_set(s->map, s->type, s->source_name);
+}
+
+static void
+_show_urmatt(void *data, Evas_Object *obj __UNUSED__, void *event_info __UNUSED__)
 {
-   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_geo_region_show(data, 126.977969, 37.566535);
-   elm_map_zoom_set(data, 18);
-   elm_map_paused_set(data, b);
+   if (elm_map_zoom_get(data) < 12) elm_map_zoom_set(data, 12);
+   elm_map_region_show(data,7.325201, 48.526813);
 }
 
 static void
-map_bring_seoul(void *data, Evas_Object *obj __UNUSED__, void *event_info __UNUSED__)
+_bring_seoul(void *data, Evas_Object *obj __UNUSED__, void *event_info __UNUSED__)
 {
-   elm_map_geo_region_bring_in(data, 126.977969, 37.566535);
+   elm_map_zoom_mode_set(data, ELM_MAP_ZOOM_MODE_MANUAL);
+   if (elm_map_zoom_get(data) < 12) elm_map_zoom_set(data, 12);
+   elm_map_region_bring_in(data, 126.977969, 37.566535);
 }
 
 static void
-map_paused_set(void *data, Evas_Object *obj __UNUSED__, void *event_info __UNUSED__)
+_paused_set(void *data, Evas_Object *obj __UNUSED__, void *event_info __UNUSED__)
 {
    elm_map_paused_set(data, EINA_TRUE);
 }
 
 static void
-map_paused_unset(void *data, Evas_Object *obj __UNUSED__, void *event_info __UNUSED__)
+_paused_unset(void *data, Evas_Object *obj __UNUSED__, void *event_info __UNUSED__)
 {
    elm_map_paused_set(data, EINA_FALSE);
 }
 
 static void
-map_zoom_in(void *data, Evas_Object *obj __UNUSED__, void *event_info __UNUSED__)
+_zoom_in(void *data, Evas_Object *obj __UNUSED__, void *event_info __UNUSED__)
 {
    int zoom;
 
@@ -300,7 +471,7 @@ map_zoom_in(void *data, Evas_Object *obj __UNUSED__, void *event_info __UNUSED__
 }
 
 static void
-map_zoom_out(void *data, Evas_Object *obj __UNUSED__, void *event_info __UNUSED__)
+_zoom_out(void *data, Evas_Object *obj __UNUSED__, void *event_info __UNUSED__)
 {
    int zoom;
 
@@ -310,19 +481,81 @@ map_zoom_out(void *data, Evas_Object *obj __UNUSED__, void *event_info __UNUSED_
 }
 
 static void
-map_zoom_fit(void *data, Evas_Object *obj __UNUSED__, void *event_info __UNUSED__)
+_zoom_fit(void *data, Evas_Object *obj __UNUSED__, void *event_info __UNUSED__)
 {
    elm_map_zoom_mode_set(data, ELM_MAP_ZOOM_MODE_AUTO_FIT);
 }
 
 static void
-map_zoom_fill(void *data, Evas_Object *obj __UNUSED__, void *event_info __UNUSED__)
+_zoom_fill(void *data, Evas_Object *obj __UNUSED__, void *event_info __UNUSED__)
 {
    elm_map_zoom_mode_set(data, ELM_MAP_ZOOM_MODE_AUTO_FILL);
 }
 
 static void
-map_rotate_cw(void *data, Evas_Object *obj __UNUSED__, void *event_info __UNUSED__)
+_zoom_manual(void *data, Evas_Object *obj __UNUSED__, void *event_info __UNUSED__)
+{
+   elm_map_zoom_mode_set(data, ELM_MAP_ZOOM_MODE_MANUAL);
+}
+
+static void
+_track_add(void *data, Evas_Object *obj __UNUSED__, void *event_info __UNUSED__)
+{
+   Evas_Object *fs, *bg, *vbox, *hbox, *sep;
+   char *path = NULL;
+
+   fs_win = elm_win_add(NULL, "fileselector", ELM_WIN_BASIC);
+   elm_win_title_set(fs_win, "File Selector");
+   elm_win_autodel_set(fs_win, 1);
+
+   bg = elm_bg_add(fs_win);
+   elm_win_resize_object_add(fs_win, bg);
+   evas_object_size_hint_weight_set(bg, EVAS_HINT_EXPAND, EVAS_HINT_EXPAND);
+   evas_object_show(bg);
+
+   vbox = elm_box_add(fs_win);
+   elm_win_resize_object_add(fs_win, vbox);
+   evas_object_size_hint_weight_set(vbox, EVAS_HINT_EXPAND, EVAS_HINT_EXPAND);
+   evas_object_show(vbox);
+
+   fs = elm_fileselector_add(fs_win);
+   elm_fileselector_is_save_set(fs, EINA_TRUE);
+   elm_fileselector_expandable_set(fs, EINA_FALSE);
+   path = getenv("HOME");
+   //if "HOME" is not available, set current dir. path
+   if (!path)
+     path = ".";
+   elm_fileselector_path_set(fs, path);
+   evas_object_size_hint_weight_set(fs, EVAS_HINT_EXPAND, EVAS_HINT_EXPAND);
+   evas_object_size_hint_align_set(fs, EVAS_HINT_FILL, EVAS_HINT_FILL);
+   elm_box_pack_end(vbox, fs);
+   evas_object_show(fs);
+
+   evas_object_smart_callback_add(fs, "done", my_map_gpx_fileselector_done, data);
+
+   sep = elm_separator_add(fs_win);
+   elm_separator_horizontal_set(sep, EINA_TRUE);
+   elm_box_pack_end(vbox, sep);
+   evas_object_show(sep);
+
+   hbox = elm_box_add(fs_win);
+   elm_box_horizontal_set(hbox, EINA_TRUE);
+   elm_box_pack_end(vbox, hbox);
+   evas_object_show(hbox);
+
+   evas_object_resize(fs_win, 240, 350);
+   evas_object_show(fs_win);
+}
+
+
+static void
+_track_remove(void *data __UNUSED__, Evas_Object *obj __UNUSED__, void *event_info __UNUSED__)
+{
+   elm_map_track_remove(data, track);
+}
+
+static void
+_rotate_cw(void *data, Evas_Object *obj __UNUSED__, void *event_info __UNUSED__)
 {
    double d;
    Evas_Coord x, y, w, h;
@@ -337,7 +570,7 @@ map_rotate_cw(void *data, Evas_Object *obj __UNUSED__, void *event_info __UNUSED
 }
 
 static void
-map_rotate_ccw(void *data, Evas_Object *obj __UNUSED__, void *event_info __UNUSED__)
+_rotate_ccw(void *data, Evas_Object *obj __UNUSED__, void *event_info __UNUSED__)
 {
    double d;
    Evas_Coord x, y, w, h;
@@ -352,7 +585,7 @@ map_rotate_ccw(void *data, Evas_Object *obj __UNUSED__, void *event_info __UNUSE
 }
 
 static void
-map_rotate_reset(void *data, Evas_Object *obj __UNUSED__, void *event_info __UNUSED__)
+_rotate_reset(void *data, Evas_Object *obj __UNUSED__, void *event_info __UNUSED__)
 {
    Evas_Coord x, y, w, h;
    float half_w, half_h;
@@ -364,206 +597,227 @@ map_rotate_reset(void *data, Evas_Object *obj __UNUSED__, void *event_info __UNU
 }
 
 static void
-map_source(void *data, Evas_Object *obj __UNUSED__, void *event_info __UNUSED__)
+_wheel_disable(void *data, Evas_Object *obj __UNUSED__, void *event_info __UNUSED__)
 {
-   Map_Source *ms = data;
-
-   if (!ms) return;
-   elm_map_source_name_set(ms->map, ms->source_name);
+   elm_map_wheel_disabled_set(data, EINA_TRUE);
 }
 
-/*
 static void
-map_marker_add(void *data)
+_wheel_enable(void *data, Evas_Object *obj __UNUSED__, void *event_info __UNUSED__)
 {
-   int i;
-   Elm_Map_Group_Class *g_clas;
-   Elm_Map_Marker_Class *m_clas;
-   Marker_Data *d = &data7;
-
-   if (*markers) return;
-   for (i =0; i<MARKER_MAX; i++)
-     {
-        d = &data7;
+   elm_map_wheel_disabled_set(data, EINA_FALSE);
+}
 
-        int r1 = rand() % (180*2*100);
-        if (r1<=180) r1 = -r1;
-        else r1 = r1 - 180*100;
+static void
+_zoom_min_set(void *data, Evas_Object *obj __UNUSED__, void *event_info __UNUSED__)
+{
+   elm_map_zoom_min_set(data, 1);
+}
 
-        int r2 = rand() % (85*2*100);
-        if (r2<=85) r2 = -r2;
-        else r2 = r2 - 85*100;
+static void
+_zoom_max_set(void *data, Evas_Object *obj __UNUSED__, void *event_info __UNUSED__)
+{
+   elm_map_zoom_max_set(data, 10);
+}
 
-        int style = rand() % 3;
-        if (!style) m_clas = itc1;
-        else if (style == 1) m_clas = itc2;
-        else
-          {
-             m_clas = itc_parking;
-             d = &data_parking;
-          }
+static void
+_line_add(void *data, Evas_Object *obj __UNUSED__, void *ei __UNUSED__)
+{
+   double lon, lat;
 
-        style = rand() % 2;
-        if (!style) g_clas = itc_group1;
-        else g_clas = itc_group2;
+   elm_map_canvas_to_region_convert(data, down_x, down_y, &lon, &lat);
+   printf("line marker: %d %d %lf %lf\n", down_x, down_y, lon, lat);
+   if (line_start && line_end)
+     {
+        elm_map_overlay_del(line_start);
+        elm_map_overlay_del(line_end);
+        elm_map_overlay_del(line);
+        line_start = NULL;
+        line_end = NULL;
+        line = NULL;
+     }
+   if (!line_start) line_start = elm_map_overlay_add(data, lon, lat);
+   else if (!line_end) line_end = elm_map_overlay_add(data, lon, lat);
 
-        markers[i] = elm_map_marker_add(data, r1/100., r2/100., m_clas, g_clas, d);
+   if (line_start && line_end)
+     {
+        double flon, flat, tlon, tlat;
+        elm_map_overlay_region_get(line_start, &flon, &flat);
+        elm_map_overlay_region_get(line_end, &tlon, &tlat);
+        line = elm_map_overlay_line_add(data, flon, flat, tlon, tlat);
+        printf("line add: (%lf, %lf) --> (%lf, %lf)\n", flon, flat, tlon, tlat);
      }
-   nb_elts += 1000;
-   printf("nb elements: %d\n", nb_elts);
 }
 
 static void
-map_marker_remove(void *data __UNUSED__)
+_poly_add(void *data, Evas_Object *obj __UNUSED__, void *ei __UNUSED__)
 {
-   int i;
+   double lon, lat;
 
-   for (i = 0; i<MARKER_MAX; i++)
-     {
-        if (markers[i])
-          {
-             elm_map_marker_remove(markers[i]);
-             markers[i] = NULL;
-          }
-     }
+   elm_map_canvas_to_region_convert(data, down_x, down_y, &lon, &lat);
+   printf("%d %d %lf %lf\n", down_x, down_y, lon, lat);
+
+   if (!poly) poly = elm_map_overlay_polygon_add(data);
+   poly_points = eina_list_append(poly_points,
+                                  elm_map_overlay_add(data, lon, lat));
+   elm_map_overlay_polygon_region_add(poly, lon, lat);
 }
 
 static void
-my_map_entry_focused(void *data __UNUSED__, Evas_Object *obj, void *event_info __UNUSED__)
+_poly_clear(void *data __UNUSED__, Evas_Object *obj __UNUSED__, void *ei __UNUSED__)
 {
-   const char *s = elm_scrolled_entry_entry_get(obj);
-   if (!strcmp(s, NAME_ENTRY_TEXT)) elm_scrolled_entry_entry_set(obj, "");
+   Elm_Map_Overlay *ovl;
+   if (poly) elm_map_overlay_del(poly);
+   EINA_LIST_FREE(poly_points, ovl) elm_map_overlay_del(ovl);
+   poly = NULL;
+   poly_points = NULL;
 }
 
 static void
-my_map_entry_activated(void *data, Evas_Object *obj, void *event_info __UNUSED__)
+_circle_add(void *data, Evas_Object *obj __UNUSED__, void *ei __UNUSED__)
 {
-   const char *s = elm_scrolled_entry_entry_get(obj);
-   char *addr = strdup(s);
-   name = elm_map_utils_convert_name_into_coord(data, addr);
-   if (addr) free (addr);
+   double radius = 100;
+   double lon, lat;
+
+   if (circle) elm_map_overlay_del(circle);
+   elm_map_canvas_to_region_convert(data, down_x, down_y, &lon, &lat);
+   circle = elm_map_overlay_circle_add(data, lon, lat, radius);
 }
-*/
 
-static Evas_Object *
-_marker_get(Evas_Object *obj, Elm_Map_Marker *marker __UNUSED__, void *data)
+static void
+_scale_add(void *data, Evas_Object *obj __UNUSED__, void *ei __UNUSED__)
 {
-   Marker_Data *d = data;
+   if (scale) elm_map_overlay_del(scale);
+   scale = elm_map_overlay_scale_add(data, down_x, down_y);
+}
 
-   Evas_Object *bx = elm_box_add(obj);
-   evas_object_show(bx);
+static void
+_submenu_src_add(void *data, Elm_Object_Item *parent)
+{
+   int idx;
+   const char **tile_srcs;
+   const char **route_srcs;
+   const char **name_srcs;
 
-   if (d == &data3)
+   if ((!data) || (!parent)) return;
+
+   tile_srcs = elm_map_sources_get(data, ELM_MAP_SOURCE_TYPE_TILE);
+   route_srcs = elm_map_sources_get(data, ELM_MAP_SOURCE_TYPE_ROUTE);
+   name_srcs = elm_map_sources_get(data, ELM_MAP_SOURCE_TYPE_NAME);
+
+   for (idx = 0; tile_srcs[idx]; idx++)
+     {
+        if (idx >= SOURCE_MAX) break;
+        ts[idx].map = data;
+        ts[idx].type = ELM_MAP_SOURCE_TYPE_TILE;
+        ts[idx].source_name = strdup(tile_srcs[idx]);
+        elm_menu_item_add(menu, parent, "", tile_srcs[idx], _src_set, &ts[idx]);
+     }
+   for (idx = 0; route_srcs[idx]; idx++)
      {
-        Evas_Object *icon = elm_icon_add(obj);
-        elm_icon_file_set(icon, d->file, NULL);
-        evas_object_show(icon);
-
-        Evas_Object *o = elm_button_add(obj);
-        elm_button_icon_set(o, icon);
-        evas_object_show(o);
-        elm_box_pack_end(bx, o);
+        if (idx >= SOURCE_MAX) break;
+        rs[idx].map = data;
+        rs[idx].type = ELM_MAP_SOURCE_TYPE_ROUTE;
+        rs[idx].source_name = strdup(route_srcs[idx]);
+        elm_menu_item_add(menu, parent, "", route_srcs[idx], _src_set, &rs[idx]);
      }
-   else
+   for (idx = 0; name_srcs[idx]; idx++)
      {
-        Evas_Object *o = evas_object_image_add(evas_object_evas_get(obj));
-        evas_object_image_file_set(o, d->file, NULL);
-        evas_object_image_filled_set(o, EINA_TRUE);
-        evas_object_size_hint_min_set(o, 64, 64);
-        evas_object_show(o);
-        elm_box_pack_end(bx, o);
-
-        Evas_Object *lbl = elm_label_add(obj);
-        elm_label_label_set(lbl, "Wolves Go !");
-        evas_object_show(lbl);
-        elm_box_pack_end(bx, lbl);
+        if (idx >= SOURCE_MAX) break;
+        ns[idx].map = data;
+        ns[idx].type = ELM_MAP_SOURCE_TYPE_NAME;
+        ns[idx].source_name = strdup(name_srcs[idx]);
+        elm_menu_item_add(menu, parent, "", name_srcs[idx], _src_set, &ns[idx]);
      }
-
-   return bx;
 }
 
-static Evas_Object *
-_icon_get(Evas_Object *obj, Elm_Map_Marker *marker __UNUSED__, void *data)
+static void
+_submenu_move_add(void *data, Elm_Object_Item *parent)
 {
-   Marker_Data *d = data;
-
-   Evas_Object *icon = elm_icon_add(obj);
-   elm_icon_file_set(icon, d->file, NULL);
-   evas_object_show(icon);
+   if ((!data) || (!parent)) return;
+   elm_menu_item_add(menu, parent, NULL, "Show Urmatt", _show_urmatt, data);
+   elm_menu_item_add(menu, parent, NULL, "Bring Seoul", _bring_seoul, data);
 
-   return icon;
 }
 
-static Evas_Object *
-_group_icon_get(Evas_Object *obj, void *data)
+static void
+_submenu_zoom_add(void *data, Elm_Object_Item *parent)
 {
-   char *file = data;
-
-   Evas_Object *icon = elm_icon_add(obj);
-   elm_icon_file_set(icon, file, NULL);
-   evas_object_show(icon);
-
-   return icon;
+   if ((!data) || (!parent)) return;
+   elm_menu_item_add(menu, parent, NULL, "Zoom +", _zoom_in, data);
+   elm_menu_item_add(menu, parent, NULL, "Zoom -", _zoom_out, data);
+   elm_menu_item_add(menu, parent, NULL, "Zoom Fit", _zoom_fit, data);
+   elm_menu_item_add(menu, parent, NULL, "Zoom Fill", _zoom_fill, data);
+   elm_menu_item_add(menu, parent, NULL, "Zoom Manual", _zoom_manual, data);
+   elm_menu_item_add(menu, parent, NULL, "Zoom Min to 1", _zoom_min_set, data);
+   elm_menu_item_add(menu, parent, NULL, "Zoom Max to 10", _zoom_max_set, data);
 }
 
 static void
-_map_move_resize_cb(void *data, Evas *e __UNUSED__, Evas_Object *obj __UNUSED__, void *event_info __UNUSED__)
+_submenu_prop_add(void *data, Elm_Object_Item *parent)
 {
-   int x,y,w,h;
-
-   evas_object_geometry_get(data,&x,&y,&w,&h);
-   evas_object_resize(rect,w,h);
-   evas_object_move(rect,x,y);
+   if ((!data) || (!parent)) return;
+   elm_menu_item_add(menu, parent, NULL, "Paused Set", _paused_set, data);
+   elm_menu_item_add(menu, parent, NULL, "Paused Unset", _paused_unset, data);
+   elm_menu_item_add(menu, parent, NULL, "Rotate CW", _rotate_cw, data);
+   elm_menu_item_add(menu, parent, NULL, "Rotate CCW", _rotate_ccw, data);
+   elm_menu_item_add(menu, parent, NULL, "Reset Rotate", _rotate_reset, data);
+   elm_menu_item_add(menu, parent, NULL, "Disable Wheel", _wheel_disable, data);
+   elm_menu_item_add(menu, parent, NULL, "Enable Wheel", _wheel_enable, data);
 }
 
 static void
-_populate(void *data, Elm_Menu_Item *item)
+_submenu_track_add(void *data, Elm_Object_Item *parent)
 {
-   int idx;
+   if ((!data) || (!parent)) return;
+   elm_menu_item_add(menu, parent, NULL, "Add Track", _track_add, data);
+   elm_menu_item_add(menu, parent, NULL, "Remove Track", _track_remove, data);
+}
 
-   if ((!data) || (!item) || (!source_names)) return;
-   for (idx = 0; source_names[idx]; idx++)
-     {
-        if (idx >= SOURCE_MAX) break;
-        ms[idx].map = data;
-        ms[idx].source_name = strdup(source_names[idx]);
-        elm_menu_item_add(menu, item, "", source_names[idx], map_source, &ms[idx]);
-     }
+static void
+_submenu_ovl_add(void *data, Elm_Object_Item *parent)
+{
+   if ((!data) || (!parent)) return;
+   elm_menu_item_add(menu, parent, NULL, "Add line", _line_add, data);
+   elm_menu_item_add(menu, parent, NULL, "Add polygon", _poly_add, data);
+   elm_menu_item_add(menu, parent, NULL, "Clear polygon", _poly_clear, data);
+   elm_menu_item_add(menu, parent, NULL, "Add circle", _circle_add, data);
+   elm_menu_item_add(menu, parent, NULL, "Add scale", _scale_add, data);
 }
 
 static void
 _map_mouse_down(void *data, Evas *evas __UNUSED__, Evas_Object *obj, void *event_info)
 {
    Evas_Event_Mouse_Down *down = event_info;
-   Elm_Menu_Item *item;
+   Elm_Object_Item *menu_it;
    if (!down) return;
 
    if (down->button == 2)
      {
-        old_x = down->output.x;
-        old_y = down->output.y;
+        old_x = down->canvas.x;
+        old_y = down->canvas.y;
         old_d = 0.0;
      }
    else if (down->button == 3)
      {
+        down_x = down->canvas.x;
+        down_y = down->canvas.y;
         menu = elm_menu_add(obj);
-        item = elm_menu_item_add(menu, NULL, NULL, "Source", NULL, NULL);
-        _populate(data, item);
-        elm_menu_item_add(menu, NULL, NULL, "Show Seoul", map_show_seoul, data);
-        elm_menu_item_add(menu, NULL, NULL, "Bring Seoul", map_bring_seoul, data);
-        elm_menu_item_add(menu, NULL, NULL, "Paused Set", map_paused_set, data);
-        elm_menu_item_add(menu, NULL, NULL, "Paused Unset", map_paused_unset, data);
-        elm_menu_item_add(menu, NULL, NULL, "Zoom +", map_zoom_in, data);
-        elm_menu_item_add(menu, NULL, NULL, "Zoom -", map_zoom_out, data);
-        elm_menu_item_add(menu, NULL, NULL, "Zoom Fit", map_zoom_fit, data);
-        elm_menu_item_add(menu, NULL, NULL, "Zoom Fill", map_zoom_fill, data);
-        elm_menu_item_add(menu, NULL, NULL, "Add Marker", NULL, NULL);
-        elm_menu_item_add(menu, NULL, NULL, "Rotate CW", map_rotate_cw, data);
-        elm_menu_item_add(menu, NULL, NULL, "Rotate CCW", map_rotate_ccw, data);
-        elm_menu_item_add(menu, NULL, NULL, "Reset Rotate", map_rotate_reset, data);
-
-        elm_menu_move(menu, down->canvas.x, down->canvas.y);
-        evas_object_show(menu);
+        menu_it = elm_menu_item_add(menu, NULL, "", "Source", NULL, NULL);
+        _submenu_src_add(data, menu_it);
+        menu_it = elm_menu_item_add(menu, NULL, "", "Move", NULL, NULL);
+        _submenu_move_add(data, menu_it);
+        menu_it = elm_menu_item_add(menu, NULL, "", "Zoom", NULL, NULL);
+        _submenu_zoom_add(data, menu_it);
+        menu_it = elm_menu_item_add(menu, NULL, "", "Prop", NULL, NULL);
+        _submenu_prop_add(data, menu_it);
+        menu_it = elm_menu_item_add(menu, NULL, "", "Track", NULL, NULL);
+        _submenu_track_add(data, menu_it);
+        menu_it = elm_menu_item_add(menu, NULL, "", "Overlay", NULL, NULL);
+        _submenu_ovl_add(data, menu_it);
+
+         elm_menu_move(menu, down->canvas.x, down->canvas.y);
+         evas_object_show(menu);
      }
 }
 
@@ -584,7 +838,7 @@ _map_mouse_move(void *data, Evas *evas __UNUSED__, Evas_Object *obj __UNUSED__,
         half_h = (float)h * 0.5;
         elm_map_rotate_get(data, &cur_d, NULL, NULL);
 
-        d = move->cur.output.x - old_x;
+        d = move->cur.canvas.x - old_x;
         if (!old_d) old_d = d;
         else
           {
@@ -618,15 +872,113 @@ _map_mouse_up(void *data __UNUSED__, Evas *evas __UNUSED__, Evas_Object *obj __U
      }
 }
 
+static void
+_overlay_cb(void *data __UNUSED__, Evas_Object *map, void *ev)
+{
+   printf("Overlay clicked: ");
+   Elm_Map_Overlay *overlay = ev;
+   Overlay_Data *od;
+   Elm_Map_Overlay_Type type = elm_map_overlay_type_get(overlay);
+
+   if (type != ELM_MAP_OVERLAY_TYPE_GROUP &&
+       type != ELM_MAP_OVERLAY_TYPE_DEFAULT) return;
+
+   if (!bubble_img)  bubble_img = elm_map_overlay_bubble_add(map);
+   elm_map_overlay_bubble_follow(bubble_img, overlay);
+   elm_map_overlay_bubble_content_clear(bubble_img);
+
+   if (type == ELM_MAP_OVERLAY_TYPE_GROUP)
+     {
+        Eina_List *l;
+        Elm_Map_Overlay *memb;
+        Eina_List *members = elm_map_overlay_group_members_get(overlay);
+        printf("Group Members Num: %d\n", eina_list_count(members));
+        EINA_LIST_FOREACH(members, l, memb)
+          {
+             od = elm_map_overlay_data_get(memb);
+             if (od)
+                elm_map_overlay_bubble_content_append(bubble_img,
+                                                      _box_get(map, od, memb));
+          }
+      }
+     else
+     {
+        od = elm_map_overlay_data_get(overlay);
+        if (od)
+           elm_map_overlay_bubble_content_append(bubble_img,
+                                                 _box_get(map, od, overlay));
+        elm_map_overlay_bubble_content_append(bubble_img,
+                                              _btn_box_get(map, overlay));
+     }
+}
+
+static void
+_parking_cb(void *data __UNUSED__, Evas_Object *map, Elm_Map_Overlay *ovl)
+{
+   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);
+
+   elm_map_canvas_to_region_convert(map, x+40, y+50, &lon, &lat);
+   if (!bubble_parking)
+     {
+        Evas_Object *bubble, *label;
+        bubble = elm_bubble_add(map);
+        elm_bubble_pos_set(bubble, ELM_BUBBLE_POS_TOP_LEFT);
+        elm_object_text_set(bubble, "Overlay object");
+        elm_object_part_text_set(bubble, "info", "Bubble is overlayed");
+
+        label = elm_label_add(bubble);
+        elm_object_text_set(label, "Parking Here !!");
+        evas_object_show(label);
+        elm_object_content_set(bubble, label);
+
+        evas_object_resize(bubble, 125, 50);
+        evas_object_show(bubble);
+
+        bubble_parking = elm_map_overlay_add(map, lon, lat);
+        elm_map_overlay_content_set(bubble_parking, bubble);
+     }
+   else elm_map_overlay_region_set(bubble_parking, lon, lat);
+   elm_map_overlay_data_set(bubble_parking, ovl);
+}
+
+static void
+_del_map(void *data __UNUSED__, Evas *e __UNUSED__, Evas_Object *obj __UNUSED__, void *ei __UNUSED__)
+{
+   if (route_start)    elm_map_overlay_del(route_start);
+   if (route_end)      elm_map_overlay_del(route_end);
+   if (route_clas)     elm_map_overlay_del(route_clas);
+   if (bubble_img)     elm_map_overlay_del(bubble_img);
+   if (bubble_parking) elm_map_overlay_del(bubble_parking);
+   if (route_ovl)      elm_map_overlay_del(route_ovl);
+   route_start = NULL;
+   route_end = NULL;
+   route_clas = NULL;
+   bubble_img = NULL;
+   bubble_parking = NULL;
+   route_ovl = NULL;
+
+   if (route) elm_map_route_del(route);
+   if (name) elm_map_name_del(name);
+   route = NULL;
+   name = NULL;
+}
+
 void
 test_map(void *data __UNUSED__, Evas_Object *obj __UNUSED__, void *event_info __UNUSED__)
 {
    Evas_Object *win, *bg, *map;
    int idx = 0;
+   const char **tile_srcs;
+   const char **route_srcs;
+   const char **name_srcs;
 
    win = elm_win_add(NULL, "map", ELM_WIN_BASIC);
    elm_win_title_set(win, "Map");
-   elm_win_autodel_set(win, 1);
+   elm_win_autodel_set(win, EINA_TRUE);
 
    bg = elm_bg_add(win);
    evas_object_size_hint_weight_set(bg, EVAS_HINT_EXPAND, EVAS_HINT_EXPAND);
@@ -636,61 +988,36 @@ test_map(void *data __UNUSED__, Evas_Object *obj __UNUSED__, void *event_info __
    map = elm_map_add(win);
    if (map)
      {
+        Elm_Map_Overlay *ovl_1, *ovl_2, *ovl_3, *ovl_4, *ovl_5, *ovl_6;
+        Elm_Map_Overlay *ovl_7, *ovl_8, *ovl_9, *ovl_10, *ovl_11;
+        Elm_Map_Overlay *parking1, *parking2, *parking3, *parking4, *parking5;
+        Elm_Map_Overlay *grp1, *grp2, *grp_parking;
+
+        evas_object_event_callback_add(map, EVAS_CALLBACK_DEL, _del_map, NULL);
+
         srand(time(NULL));
 
-        source_names = elm_map_source_names_get(map);
+        tile_srcs = elm_map_sources_get(map, ELM_MAP_SOURCE_TYPE_TILE);
+        route_srcs = elm_map_sources_get(map, ELM_MAP_SOURCE_TYPE_ROUTE);
+        name_srcs = elm_map_sources_get(map, ELM_MAP_SOURCE_TYPE_NAME);
 
-        if (!source_names) return;
-        printf("map sources [ ");
-        for (idx = 0; source_names[idx] ; idx++) printf("%s ", source_names[idx]);
+        if (!tile_srcs) return;
+        printf("Tile sources [ ");
+        for (idx = 0; tile_srcs[idx] ; idx++) printf("%s, ", tile_srcs[idx]);
+        printf("]\n");
+        if (!route_srcs) return;
+        printf("Route sources [ ");
+        for (idx = 0; route_srcs[idx] ; idx++) printf("%s, ", route_srcs[idx]);
+        printf("]\n");
+        if (!name_srcs) return;
+        printf("Name sources [ ");
+        for (idx = 0; name_srcs[idx] ; idx++) printf("%s, ", name_srcs[idx]);
         printf("]\n");
 
         evas_object_size_hint_weight_set(map, EVAS_HINT_EXPAND, EVAS_HINT_EXPAND);
         elm_win_resize_object_add(win, map);
         evas_object_data_set(map, "window", win);
 
-        //
-        itc1 = elm_map_marker_class_new(map);
-        elm_map_marker_class_get_cb_set(itc1, _marker_get);
-        elm_map_marker_class_del_cb_set(itc1, NULL);
-
-        itc2 = elm_map_marker_class_new(map);
-        elm_map_marker_class_get_cb_set(itc2, _marker_get);
-        elm_map_marker_class_del_cb_set(itc2, NULL);
-        elm_map_marker_class_style_set(itc2, "radio2");
-
-        itc_parking = elm_map_marker_class_new(map);
-        elm_map_marker_class_get_cb_set(itc_parking, _marker_get);
-        elm_map_marker_class_del_cb_set(itc_parking, NULL);
-        elm_map_marker_class_icon_cb_set(itc_parking, _icon_get);
-        elm_map_marker_class_style_set(itc_parking, "empty");
-        //
-
-        //
-        itc_group1 = elm_map_group_class_new(map);
-        elm_map_group_class_data_set(itc_group1, (void *)PACKAGE_DATA_DIR"/images/plant_01.jpg");
-
-        itc_group2 = elm_map_group_class_new(map);
-        elm_map_group_class_style_set(itc_group2, "radio2");
-        elm_map_group_class_zoom_displayed_set(itc_group1, 3);
-
-        itc_group_parking = elm_map_group_class_new(map);
-        elm_map_group_class_icon_cb_set(itc_group_parking, _group_icon_get);
-        elm_map_group_class_data_set(itc_group_parking, (void *)PACKAGE_DATA_DIR"/images/parking.png");
-        elm_map_group_class_style_set(itc_group_parking, "empty");
-        elm_map_group_class_zoom_displayed_set(itc_group_parking, 5);
-        //
-
-        rect = evas_object_rectangle_add(evas_object_evas_get(win));
-        evas_object_color_set(rect, 0, 0, 0, 0);
-        evas_object_repeat_events_set(rect,1);
-        evas_object_show(rect);
-        evas_object_raise(rect);
-
-        evas_object_event_callback_add(map, EVAS_CALLBACK_RESIZE,
-                                       _map_move_resize_cb, map);
-        evas_object_event_callback_add(map, EVAS_CALLBACK_MOVE,
-                                       _map_move_resize_cb, map);
         evas_object_event_callback_add(map, EVAS_CALLBACK_MOUSE_DOWN,
                                        _map_mouse_down, map);
         evas_object_event_callback_add(map, EVAS_CALLBACK_MOUSE_MOVE,
@@ -698,42 +1025,100 @@ test_map(void *data __UNUSED__, Evas_Object *obj __UNUSED__, void *event_info __
         evas_object_event_callback_add(map, EVAS_CALLBACK_MOUSE_UP,
                                        _map_mouse_up, map);
 
-        elm_map_marker_add(map, 2.352, 48.857, itc1, itc_group1, &data1);
-        elm_map_marker_add(map, 2.355, 48.857, itc1, itc_group1, &data3);
-        elm_map_marker_add(map, 3, 48.857, itc2, itc_group1, &data2);
-        elm_map_marker_add(map, 2.352, 49, itc2, itc_group1, &data1);
-
-        elm_map_marker_add(map, 7.31451, 48.857127, itc1, itc_group1, &data10);
-        elm_map_marker_add(map, 7.314704, 48.857119, itc1, itc_group1, &data4);
-        elm_map_marker_add(map, 7.314704, 48.857119, itc2, itc_group1, &data5);
-        elm_map_marker_add(map, 7.31432, 48.856785, itc2, itc_group1, &data6);
-        elm_map_marker_add(map, 7.3148, 48.85725, itc1, itc_group2, &data7);
-        elm_map_marker_add(map, 7.316445, 48.8572210000694, itc1, itc_group1, &data8);
-        elm_map_marker_add(map, 7.316527000125, 48.85609, itc2, itc_group2, &data9);
-        elm_map_marker_add(map, 7.3165409990833, 48.856078, itc2, itc_group1, &data11);
-        elm_map_marker_add(map, 7.319812, 48.856561, itc2, itc_group2, &data10);
-
-        nb_elts = 13;
-
-        evas_object_smart_callback_add(map, "clicked", my_map_clicked, win);
-        evas_object_smart_callback_add(map, "press", my_map_press, win);
-        evas_object_smart_callback_add(map, "longpressed", my_map_longpressed, map);
-        evas_object_smart_callback_add(map, "clicked,double", my_map_clicked_double, map);
-        evas_object_smart_callback_add(map, "load,detail", my_map_load_detail, win);
-        evas_object_smart_callback_add(map, "loaded,detail", my_map_loaded_detail, win);
-        evas_object_smart_callback_add(map, "zoom,start", my_map_zoom_start, win);
-        evas_object_smart_callback_add(map, "zoom,stop", my_map_zoom_stop, win);
-        evas_object_smart_callback_add(map, "zoom,change", my_map_zoom_change, win);
-        evas_object_smart_callback_add(map, "scroll,anim,start", my_map_anim_start, win);
-        evas_object_smart_callback_add(map, "scroll,anim,stop", my_map_anim_stop, win);
-        evas_object_smart_callback_add(map, "scroll,drag,start", my_map_drag_start, map);
-        evas_object_smart_callback_add(map, "scroll,drag,stop", my_map_drag_stop, map);
-        evas_object_smart_callback_add(map, "scroll", my_map_scroll, win);
-        evas_object_smart_callback_add(map, "downloaded", my_map_downloaded, map);
-        evas_object_smart_callback_add(map, "route,load", my_map_route_load, map);
-        evas_object_smart_callback_add(map, "route,loaded", my_map_route_loaded, map);
-        evas_object_smart_callback_add(map, "name,load", my_map_name_load, map);
-        evas_object_smart_callback_add(map, "name,loaded", my_map_name_loaded, map);
+        evas_object_smart_callback_add(map, "clicked", _map_clicked, map);
+        evas_object_smart_callback_add(map, "clicked,double", _map_clicked_double, map);
+        evas_object_smart_callback_add(map, "press", _map_press, map);
+        evas_object_smart_callback_add(map, "longpressed", _map_longpressed, map);
+        evas_object_smart_callback_add(map, "scroll", _map_scroll, map);
+        evas_object_smart_callback_add(map, "scroll,drag,start", _map_drag_start, map);
+        evas_object_smart_callback_add(map, "scroll,drag,stop", _map_drag_stop, map);
+        evas_object_smart_callback_add(map, "scroll,anim,start", _map_anim_start, map);
+        evas_object_smart_callback_add(map, "scroll,anim,stop", _map_anim_stop, map);
+        evas_object_smart_callback_add(map, "zoom,start", _map_zoom_start, map);
+        evas_object_smart_callback_add(map, "zoom,stop", _map_zoom_stop, map);
+        evas_object_smart_callback_add(map, "zoom,change", _map_zoom_change, map);
+        evas_object_smart_callback_add(map, "tile,load", _map_tile_load, map);
+        evas_object_smart_callback_add(map, "tile,loaded", _map_tile_loaded, map);
+        evas_object_smart_callback_add(map, "tile,loaded,fail", _map_tile_loaded_fail, map);
+        evas_object_smart_callback_add(map, "route,load", _map_route_load, map);
+        evas_object_smart_callback_add(map, "route,loaded", _map_route_loaded, map);
+        evas_object_smart_callback_add(map, "route,loaded,fail", _map_route_loaded_fail, map);
+        evas_object_smart_callback_add(map, "name,load", _map_name_load, map);
+        evas_object_smart_callback_add(map, "name,loaded", _map_name_loaded, map);
+        evas_object_smart_callback_add(map, "name,loaded,fail", _map_name_loaded_fail, map);
+        evas_object_smart_callback_add(map, "overlay,clicked", _overlay_cb, map);
+
+        // Create Overlays
+        ovl_1 = elm_map_overlay_add(map, 2.352, 48.857);
+        elm_map_overlay_color_set(ovl_1, 0x00, 0xfa, 0x9a, 0xff);
+        elm_map_overlay_displayed_zoom_min_set(ovl_1, 5);
+        ovl_2 = elm_map_overlay_add(map, 3, 48.857);
+        elm_map_overlay_color_set(ovl_2, 0xff, 0xd7, 0x00, 0xff);
+        elm_map_overlay_displayed_zoom_min_set(ovl_2, 4);
+        ovl_3 = elm_map_overlay_add(map, 2.352, 49);
+        elm_map_overlay_displayed_zoom_min_set(ovl_3, 3);
+        ovl_4 = elm_map_overlay_add(map, 7.31451, 48.857127);
+        ovl_5 = elm_map_overlay_add(map, 7.314704, 48.857119);
+        ovl_6 = elm_map_overlay_add(map, 7.31432, 48.856785);
+        ovl_7 = elm_map_overlay_add(map, 7.3148, 48.85725);
+        ovl_8 = elm_map_overlay_add(map, 7.316445, 48.8572210000694);
+        ovl_9 = elm_map_overlay_add(map, 7.316527000125, 48.85609);
+        ovl_10 = elm_map_overlay_add(map, 7.3165409990833, 48.856078);
+        ovl_11 = elm_map_overlay_add(map, 7.319812, 48.856561);
+        elm_map_overlay_data_set(ovl_1, &data1);
+        elm_map_overlay_data_set(ovl_2, &data2);
+        elm_map_overlay_data_set(ovl_3, &data3);
+        elm_map_overlay_data_set(ovl_4, &data4);
+        elm_map_overlay_data_set(ovl_5, &data5);
+        elm_map_overlay_data_set(ovl_6, &data6);
+        elm_map_overlay_data_set(ovl_7, &data7);
+        elm_map_overlay_data_set(ovl_8, &data8);
+        elm_map_overlay_data_set(ovl_9, &data9);
+        elm_map_overlay_data_set(ovl_10, &data10);
+        elm_map_overlay_data_set(ovl_11, &data11);
+
+        // Append overlays to groups
+        grp1 = elm_map_overlay_class_add(map);
+        elm_map_overlay_class_zoom_max_set(grp1, 6);
+        elm_map_overlay_class_append(grp1, ovl_1);
+        elm_map_overlay_class_append(grp1, ovl_2);
+        elm_map_overlay_class_append(grp1, ovl_3);
+        elm_map_overlay_class_append(grp1, ovl_4);
+        elm_map_overlay_class_append(grp1, ovl_5);
+        elm_map_overlay_class_append(grp1, ovl_6);
+
+        // Append overlays to groups
+        grp2 = elm_map_overlay_class_add(map);
+        elm_map_overlay_displayed_zoom_min_set(grp2, 9);
+        elm_map_overlay_class_append(grp2, ovl_7);
+        elm_map_overlay_class_append(grp2, ovl_8);
+        elm_map_overlay_class_append(grp2, ovl_9);
+        elm_map_overlay_class_append(grp2, ovl_10);
+        elm_map_overlay_class_append(grp2, ovl_11);
+
+        // Create overlays
+        parking1 = elm_map_overlay_add(map, 127.04871, 37.25730);
+        parking2 = elm_map_overlay_add(map, 127.05578, 37.25545);
+        parking3 = elm_map_overlay_add(map, 127.05515, 37.25439);
+        parking4 = elm_map_overlay_add(map, 127.05328, 37.25721);
+        elm_map_overlay_icon_set(parking4, _icon_get(map, &icon_data));
+        parking5 = elm_map_overlay_add(map, 127.05431, 37.25873);
+        elm_map_overlay_content_set(parking5, _label_get(map));
+        elm_map_overlay_get_cb_set(parking1, _parking_cb, NULL);
+        elm_map_overlay_get_cb_set(parking2, _parking_cb, NULL);
+        elm_map_overlay_get_cb_set(parking3, _parking_cb, NULL);
+        elm_map_overlay_get_cb_set(parking4, _parking_cb, NULL);
+        elm_map_overlay_get_cb_set(parking5, _parking_cb, NULL);
+
+        // Append overlays to groups
+        grp_parking = elm_map_overlay_class_add(map);
+        elm_map_overlay_icon_set(grp_parking, _icon_get(map, &parking));
+        elm_map_overlay_get_cb_set(grp_parking, _parking_cb, NULL);
+        elm_map_overlay_class_append(grp_parking, parking1);
+        elm_map_overlay_class_append(grp_parking, parking2);
+        elm_map_overlay_class_append(grp_parking, parking3);
+        elm_map_overlay_class_append(grp_parking, parking4);
+        elm_map_overlay_class_append(grp_parking, parking5);
 
         evas_object_show(map);
      }