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