X-Git-Url: http://review.tizen.org/git/?a=blobdiff_plain;f=src%2Fbin%2Ftest_map.c;h=bf1b0d2fed931e93f280132556d35c0681bd79fc;hb=69349483956f9222d3e68ffc4c514f792f43b3c8;hp=8704ed1a69a6f2ed37b498bc874d981919135ee0;hpb=fc0a140c5dd2366d1a01f21f9810fba126de3cbc;p=framework%2Fuifw%2Felementary.git diff --git a/src/bin/test_map.c b/src/bin/test_map.c index 8704ed1..bf1b0d2 100644 --- a/src/bin/test_map.c +++ b/src/bin/test_map.c @@ -8,219 +8,364 @@ #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 (%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= 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); }