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:
cnook 2012-03-07 13:50:37 +00:00 committed by Carsten Haitzler
parent 2df31b2926
commit 6477874b2f
5 changed files with 442 additions and 243 deletions

View File

@ -131,6 +131,7 @@ void test_flip3(void *data, Evas_Object *obj, void *event_info);
void test_flip4(void *data, Evas_Object *obj, void *event_info);
void test_flip_page(void *data, Evas_Object *obj, void *event_info);
void test_label(void *data, Evas_Object *obj, void *event_info);
void test_label2(void *data, Evas_Object *obj, void *event_info);
void test_conformant(void *data, Evas_Object *obj, void *event_info);
void test_conformant2(void *data, Evas_Object *obj, void *event_info);
void test_multi(void *data, Evas_Object *obj, void *event_info);
@ -523,6 +524,7 @@ add_tests:
//------------------------------//
ADD_TEST(NULL, "Text", "Label", test_label);
ADD_TEST(NULL, "Text", "Label2", test_label2);
//------------------------------//
ADD_TEST(NULL, "Stored Surface Buffer", "Launcher", test_launcher);

View File

@ -4,6 +4,14 @@
#endif
#ifndef ELM_LIB_QUICKLAUNCH
enum _slide_style
{
SLIDE_SHORT,
SLIDE_LONG,
SLIDE_BOUNCE,
SLIDE_STYLE_LAST
};
void
test_label(void *data __UNUSED__, Evas_Object *obj __UNUSED__, void *event_info __UNUSED__)
{
@ -68,10 +76,149 @@ test_label(void *data __UNUSED__, Evas_Object *obj __UNUSED__, void *event_info
elm_box_pack_end(bx, lb);
evas_object_show(lb);
evas_object_resize(win, 320, 300);
evas_object_show(bx);
evas_object_show(win);
elm_win_resize_object_add(win, bx);
}
static void
_cb_size_radio_changed(void *data, Evas_Object *obj, void *event __UNUSED__)
{
Evas_Object *lb = (Evas_Object *)data;
int style = elm_radio_value_get((Evas_Object *)obj);
switch (style)
{
case SLIDE_SHORT:
elm_object_style_set(lb, "slide_short");
break;
case SLIDE_LONG:
elm_object_style_set(lb, "slide_long");
break;
case SLIDE_BOUNCE:
elm_object_style_set(lb, "slide_bounce");
break;
default:
return;
}
}
static void
_change_cb(void *data, Evas_Object *obj, void *event_info __UNUSED__)
{
Evas_Object *lb = (Evas_Object *)data;
double val = elm_slider_value_get(obj);
elm_label_slide_set(lb, EINA_FALSE);
elm_label_slide_duration_set(lb, val);
elm_label_slide_set(lb, EINA_TRUE);
}
void
test_label2(void *data __UNUSED__, Evas_Object *obj __UNUSED__, void *event_info __UNUSED__)
{
Evas_Object *win, *gd, *rect, *lb, *rd, *rdg, *sl;
win = elm_win_util_standard_add("label2", "Label 2");
elm_win_autodel_set(win, EINA_TRUE);
gd = elm_grid_add(win);
elm_grid_size_set(gd, 100, 100);
evas_object_size_hint_weight_set(gd, EVAS_HINT_EXPAND, EVAS_HINT_EXPAND);
elm_win_resize_object_add(win, gd);
evas_object_show(gd);
/* Test Label Ellipsis */
lb = elm_label_add(win);
elm_object_text_set(lb, "Test Label Ellipsis:");
elm_label_slide_set(lb, EINA_TRUE);
elm_grid_pack(gd, lb, 5, 5, 90, 10);
evas_object_show(lb);
rect = evas_object_rectangle_add(evas_object_evas_get(win));
elm_grid_pack(gd, rect, 5, 15, 90, 10);
evas_object_color_set(rect, 255, 125, 125, 255);
evas_object_show(rect);
lb = elm_label_add(win);
elm_object_text_set(lb,
"This is a label set to ellipsis. "
"If set ellipsis to true and the text doesn't fit "
"in the label an ellipsis(\"...\") will be shown "
"at the end of the widget."
);
elm_label_ellipsis_set(lb, EINA_TRUE);
elm_grid_pack(gd, lb, 5, 15, 90, 10);
evas_object_show(lb);
/* Test Label Slide */
lb = elm_label_add(win);
elm_object_text_set(lb, "Test Label Slide:");
elm_label_slide_set(lb, EINA_TRUE);
elm_grid_pack(gd, lb, 5, 30, 90, 10);
evas_object_show(lb);
rect = evas_object_rectangle_add(evas_object_evas_get(win));
elm_grid_pack(gd, rect, 5, 40, 90, 10);
evas_object_color_set(rect, 255, 125, 125, 255);
evas_object_show(rect);
lb = elm_label_add(win);
elm_object_style_set(lb, "slide_short");
elm_object_text_set(lb,
"This is a label set to slide. "
"If set slide to true the text of the label "
"will slide/scroll through the length of label."
"This only works with the themes \"slide_short\", "
"\"slide_long\" and \"slide_bounce\"."
);
elm_label_slide_set(lb, EINA_TRUE);
elm_grid_pack(gd, lb, 5, 40, 90, 10);
evas_object_show(lb);
rd = elm_radio_add(win);
elm_radio_state_value_set(rd, SLIDE_SHORT);
elm_object_text_set(rd, "slide_short");
evas_object_size_hint_weight_set(rd, EVAS_HINT_EXPAND, EVAS_HINT_FILL);
evas_object_smart_callback_add(rd, "changed", _cb_size_radio_changed, lb);
elm_grid_pack(gd, rd, 5, 50, 30, 10);
evas_object_show(rd);
rdg = rd;
rd = elm_radio_add(win);
elm_radio_state_value_set(rd, SLIDE_LONG);
elm_radio_group_add(rd, rdg);
elm_object_text_set(rd, "slide_long");
evas_object_size_hint_weight_set(rd, EVAS_HINT_EXPAND, EVAS_HINT_FILL);
evas_object_smart_callback_add(rd, "changed", _cb_size_radio_changed, lb);
elm_grid_pack(gd, rd, 35, 50, 30, 10);
evas_object_show(rd);
rd = elm_radio_add(win);
elm_radio_state_value_set(rd, SLIDE_BOUNCE);
elm_radio_group_add(rd, rdg);
elm_object_text_set(rd, "slide_bounce");
evas_object_size_hint_weight_set(rd, EVAS_HINT_EXPAND, EVAS_HINT_FILL);
evas_object_smart_callback_add(rd, "changed", _cb_size_radio_changed, lb);
elm_grid_pack(gd, rd, 65, 50, 30, 10);
evas_object_show(rd);
sl = elm_slider_add(win);
elm_object_text_set(sl, "Slide Duration");
elm_slider_unit_format_set(sl, "%1.1f units");
elm_slider_min_max_set(sl, 1, 20);
elm_slider_value_set(sl, 10);
evas_object_size_hint_align_set(sl, EVAS_HINT_FILL, 0.5);
evas_object_size_hint_weight_set(sl, EVAS_HINT_EXPAND, EVAS_HINT_EXPAND);
evas_object_smart_callback_add(sl, "changed", _change_cb, lb);
elm_grid_pack(gd, sl, 5, 60, 90, 10);
evas_object_show(sl);
evas_object_resize(win, 320, 320);
evas_object_show(win);
}
#endif

View File

@ -108,8 +108,6 @@ _map_clicked_double(void *data __UNUSED__, Evas_Object *obj, void *event_info)
{
elm_map_overlay_del(route_start);
elm_map_overlay_del(route_end);
// FIXME: deprecated
// elm_map_route_remove(route);
route_start = NULL;
route_end = NULL;
route = NULL;
@ -148,8 +146,7 @@ _map_longpressed(void *data __UNUSED__, Evas_Object *obj, void *event_info)
printf("longpressed, x:%d, y:%d, lon:%lf, lat:%lf\n", down->canvas.x, down->canvas.y, lon, lat);
if (elm_map_zoom_get(obj) < 8) return;
// FIXME: deprecated
// if (name) elm_map_name_remove(name);
if (name) elm_map_name_del(name);
name = elm_map_name_add(obj, NULL, lon, lat, NULL, NULL);
}
@ -282,13 +279,13 @@ _map_name_loaded(void *data, Evas_Object *obj __UNUSED__, void *event_info __UNU
Eina_Bool b = elm_map_paused_get(data);
elm_map_paused_set(data, EINA_TRUE);
elm_map_zoom_mode_set(data, ELM_MAP_ZOOM_MODE_MANUAL);
elm_map_region_show(data, lon, lat);
elm_map_zoom_set(data, elm_map_zoom_max_get(data));
elm_map_region_show(data, lon, lat);
elm_map_paused_set(data, b);
}
}
// FIXME: deprecated
// elm_map_name_remove(name);
elm_map_name_del(name);
name = NULL;
}
@ -718,11 +715,14 @@ _overlay_cb(void *data __UNUSED__, Evas_Object *map, void *ev)
static void
_parking_cb(void *data __UNUSED__, Evas_Object *map, const Elm_Map_Overlay *ovl)
{
printf("Parking clicked\n");
if (elm_map_overlay_type_get(ovl) != ELM_MAP_OVERLAY_TYPE_DEFAULT) return;
double lon, lat;
Evas_Coord x, y;
elm_map_overlay_region_get(ovl, &lon, &lat);
elm_map_region_to_canvas_convert(map, lon, lat, &x, &y);
printf("Parking clicked: %lf %lf %d %d\n", lon, lat, x, y);
if (!bubble_parking)
{
Evas_Object *bubble, *label;
@ -761,10 +761,8 @@ _del_map(void *data __UNUSED__, Evas *e __UNUSED__, Evas_Object *obj __UNUSED__,
bubble_parking = NULL;
route_ovl = NULL;
// FIXME: deprecated
// if (route) elm_map_route_remove(route);
// FIXME: deprecated
// if (name) elm_map_name_remove(name);
if (route) elm_map_route_del(route);
if (name) elm_map_name_del(name);
route = NULL;
name = NULL;
}

View File

@ -29,6 +29,15 @@ typedef struct _Source_Tile Source_Tile;
typedef struct _Source_Route Source_Route;
typedef struct _Source_Name Source_Name;
typedef char *(*Elm_Map_Module_Source_Name_Func)(void);
typedef int (*Elm_Map_Module_Tile_Zoom_Min_Func)(void);
typedef int (*Elm_Map_Module_Tile_Zoom_Max_Func)(void);
typedef char *(*Elm_Map_Module_Tile_Url_Func)(Evas_Object *obj, int x, int y, int zoom);
typedef Eina_Bool (*Elm_Map_Module_Tile_Geo_to_Coord_Func)(const Evas_Object *obj, int zoom, double lon, double lat, int size, int *x, int *y);
typedef Eina_Bool (*Elm_Map_Module_Tile_Coord_to_Geo_Func)(const Evas_Object *obj, int zoom, int x, int y, int size, double *lon, double *lat);
typedef char *(*Elm_Map_Module_Route_Url_Func)(Evas_Object *obj, const char *type_name, int method, double flon, double flat, double tlon, double tlat);
typedef char *(*Elm_Map_Module_Name_Url_Func)(Evas_Object *obj, int method, const char *name, double lon, double lat);
#define ROUND(z) (((z) < 0) ? (int)ceil((z) - 0.005) : (int)floor((z) + 0.005))
#define EVAS_MAP_POINT 4
#define DEFAULT_TILE_SIZE 256
@ -398,14 +407,17 @@ struct _Widget_Data
Evas_Object *sep_maps_markers; // Tiles are below this and overlays are on top
Evas_Map *map;
Eina_Array *src_tile_mods;
Source_Tile *src_tile;
Eina_List *src_tiles;
const char **src_tile_names;
Eina_Array *src_route_mods;
Source_Route *src_route;
Eina_List *src_routes;
const char **src_route_names;
Eina_Array *src_name_mods;
Source_Name *src_name;
Eina_List *src_names;
const char **src_name_names;
@ -649,7 +661,7 @@ _coord_to_region_convert(Widget_Data *wd, Evas_Coord x, Evas_Coord y, Evas_Coord
}
static void
_geo_to_coord_convert(Widget_Data *wd, double lon, double lat, Evas_Coord size, Evas_Coord *x, Evas_Coord *y)
_region_to_coord_convert(Widget_Data *wd, double lon, double lat, Evas_Coord size, Evas_Coord *x, Evas_Coord *y)
{
EINA_SAFETY_ON_NULL_RETURN(wd);
@ -665,7 +677,6 @@ _geo_to_coord_convert(Widget_Data *wd, double lon, double lat, Evas_Coord size,
/ ELM_PI) / 2.0 * size);
}
static void
_viewport_size_get(Widget_Data *wd, Evas_Coord *vw, Evas_Coord *vh)
{
@ -702,7 +713,7 @@ _region_show(void *data)
Delayed_Data *dd = data;
int x, y, w, h;
_geo_to_coord_convert(dd->wd, dd->lon, dd->lat, dd->wd->size.w, &x, &y);
_region_to_coord_convert(dd->wd, dd->lon, dd->lat, dd->wd->size.w, &x, &y);
_viewport_size_get(dd->wd, &w, &h);
x = x - (w / 2);
y = y - (h / 2);
@ -1020,7 +1031,7 @@ _marker_update(Elm_Map_Marker *marker)
icon = clas->func.icon_get(marker->wd->obj, marker, marker->data);
elm_object_part_content_set(marker->obj, "elm.icon", icon);
}
_geo_to_coord_convert(marker->wd, marker->longitude, marker->latitude,
_region_to_coord_convert(marker->wd, marker->longitude, marker->latitude,
marker->wd->size.w, &(marker->x), &(marker->y));
if (marker->bubble)
@ -1521,8 +1532,8 @@ _track_place(Widget_Data *wd)
double lat_min, lat_max;
elm_route_longitude_min_max_get(route, &lon_min, &lon_max);
elm_route_latitude_min_max_get(route, &lat_min, &lat_max);
_geo_to_coord_convert(wd, lon_min, lat_max, size, &xmin, &ymin);
_geo_to_coord_convert(wd, lon_max, lat_min, size, &xmax, &ymax);
_region_to_coord_convert(wd, lon_min, lat_max, size, &xmin, &ymin);
_region_to_coord_convert(wd, lon_max, lat_min, size, &xmax, &ymax);
if( !(xmin < px && xmax < px) && !(xmin > px+ow && xmax > px+ow))
{
@ -1855,7 +1866,7 @@ _icon_dup(Evas_Object *icon, Evas_Object *parent)
const char *file = NULL, *group = NULL;
Eina_Bool size_up, size_down;
Evas_Object *dupp;
dupp = elm_icon_add(parent);
elm_icon_file_get(icon, &file, &group);
elm_icon_file_set(dupp, file, group);
@ -1976,7 +1987,7 @@ _overlay_default_update(Widget_Data *wd, Overlay_Default *ovl, Evas_Object *obj,
EINA_SAFETY_ON_NULL_RETURN(wd);
EINA_SAFETY_ON_NULL_RETURN(ovl);
_geo_to_coord_convert(wd, ovl->lon, ovl->lat, wd->size.w, &ovl->x, &ovl->y);
_region_to_coord_convert(wd, ovl->lon, ovl->lat, wd->size.w, &ovl->x, &ovl->y);
if (obj)
{
@ -2203,7 +2214,7 @@ _overlay_bubble_update(Overlay_Bubble *bubble)
EINA_SAFETY_ON_NULL_RETURN(bubble);
if ((!bubble->pobj) && (bubble->lon >= 0) && (bubble->lat >= 0))
{
_geo_to_coord_convert(bubble->wd, bubble->lon, bubble->lat,
_region_to_coord_convert(bubble->wd, bubble->lon, bubble->lat,
bubble->wd->size.w, &bubble->x, &bubble->y);
}
}
@ -2361,7 +2372,7 @@ _overlay_route_show(Overlay_Route *r)
((n->idx % (int)ceil((double)cnt/(double)size*100.0))))) continue;
if (r->inbound)
{
_geo_to_coord_convert(wd, n->pos.lon, n->pos.lat, size,
_region_to_coord_convert(wd, n->pos.lon, n->pos.lat, size,
&x, &y);
if ((x >= px - ow) && (x <= (px + ow*2)) &&
(y >= py - oh) && (y <= (py + oh*2)))
@ -2399,7 +2410,7 @@ _overlay_route_show(Overlay_Route *r)
}
else
{
_geo_to_coord_convert(wd, n->pos.lon, n->pos.lat, size,
_region_to_coord_convert(wd, n->pos.lon, n->pos.lat, size,
&x, &y);
if ((x >= px - ow) && (x <= (px + ow*2)) &&
(y >= py - oh) && (y <= (py + oh*2)))
@ -2638,8 +2649,8 @@ _overlays_show(void *data)
{
Evas_Coord size, max_x, max_y, min_x, min_y;
size = pow(2.0, zoom) * dd->wd->tsize;
_geo_to_coord_convert(dd->wd, min_lon, max_lat, size, &min_x, &max_y);
_geo_to_coord_convert(dd->wd, max_lon, min_lat, size, &max_x, &min_y);
_region_to_coord_convert(dd->wd, min_lon, max_lat, size, &min_x, &max_y);
_region_to_coord_convert(dd->wd, max_lon, min_lat, size, &max_x, &min_y);
if ((max_x - min_x) > vw || (max_y - min_y) > vh) break;
zoom++;
}
@ -2810,196 +2821,6 @@ _elm_map_marker_remove(Elm_Map_Marker *marker)
#endif
}
static void
_on_focus_hook(void *data __UNUSED__, Evas_Object *obj)
{
ELM_CHECK_WIDTYPE(obj, widtype);
Widget_Data *wd = elm_widget_data_get(obj);
EINA_SAFETY_ON_NULL_RETURN(wd);
if (elm_widget_focus_get(obj))
{
edje_object_signal_emit(elm_smart_scroller_edje_object_get(wd->scr), "elm,action,focus", "elm");
evas_object_focus_set(wd->obj, EINA_TRUE);
}
else
{
edje_object_signal_emit(elm_smart_scroller_edje_object_get(wd->scr), "elm,action,unfocus", "elm");
evas_object_focus_set(wd->obj, EINA_FALSE);
}
}
static void
_del_hook(Evas_Object *obj)
{
ELM_CHECK_WIDTYPE(obj, widtype);
Widget_Data *wd = elm_widget_data_get(obj);
EINA_SAFETY_ON_NULL_RETURN(wd);
if (wd->map) evas_map_free(wd->map);
free(wd);
}
static void
_del_pre_hook(Evas_Object *obj)
{
ELM_CHECK_WIDTYPE(obj, widtype);
Widget_Data *wd = elm_widget_data_get(obj);
EINA_SAFETY_ON_NULL_RETURN(wd);
Eina_List *l, *ll;
Elm_Map_Route *r;
Elm_Map_Name *na;
Evas_Object *track;
Elm_Map_Marker *marker;
Elm_Map_Group_Class *group_clas;
Elm_Map_Marker_Class *clas;
Elm_Map_Overlay *overlay;
Delayed_Data *dd;
int idx = 0;
Source_Tile *ts;
Source_Route *rs;
Source_Name *ns;
EINA_LIST_FOREACH_SAFE(wd->routes, l, ll, r) elm_map_route_del(r);
eina_list_free(wd->routes);
EINA_LIST_FOREACH_SAFE(wd->names, l, ll, na) elm_map_name_del(na);
eina_list_free(wd->names);
EINA_LIST_FOREACH_SAFE(wd->overlays, l, ll, overlay)
elm_map_overlay_del(overlay);
eina_list_free(wd->overlays);
EINA_LIST_FREE(wd->track, track) evas_object_del(track);
EINA_LIST_FOREACH_SAFE(wd->markers, l, ll, marker)
_elm_map_marker_remove(marker);
eina_list_free(wd->markers);
EINA_LIST_FREE(wd->group_classes, group_clas)
{
eina_list_free(group_clas->markers);
if (group_clas->style) eina_stringshare_del(group_clas->style);
free(group_clas);
}
EINA_LIST_FREE(wd->marker_classes, clas)
{
if (clas->style) eina_stringshare_del(clas->style);
free(clas);
}
if (wd->scr_timer) ecore_timer_del(wd->scr_timer);
if (wd->long_timer) ecore_timer_del(wd->long_timer);
if (wd->delayed_jobs) EINA_LIST_FREE(wd->delayed_jobs, dd) free(dd);
if (wd->user_agent) eina_stringshare_del(wd->user_agent);
if (wd->ua) eina_hash_free(wd->ua);
if (wd->zoom_timer) ecore_timer_del(wd->zoom_timer);
if (wd->zoom_animator) ecore_animator_del(wd->zoom_animator);
_grid_all_clear(wd);
// Removal of download list should be after grid clear.
if (wd->download_idler) ecore_idler_del(wd->download_idler);
eina_list_free(wd->download_list);
for (idx = 0; wd->src_tile_names[idx]; idx++)
eina_stringshare_del(wd->src_tile_names[idx]);
EINA_LIST_FREE(wd->src_tiles, ts) free(ts);
for (idx = 0; wd->src_route_names[idx]; idx++)
eina_stringshare_del(wd->src_route_names[idx]);
EINA_LIST_FREE(wd->src_routes, rs) free(rs);
for (idx = 0; wd->src_name_names[idx]; idx++)
eina_stringshare_del(wd->src_name_names[idx]);
EINA_LIST_FREE(wd->src_names, ns) free(ns);
if (!ecore_file_recursive_rm(CACHE_ROOT))
ERR("Deletion of %s failed", CACHE_ROOT);
}
static void
_theme_hook(Evas_Object *obj)
{
ELM_CHECK_WIDTYPE(obj, widtype);
Widget_Data *wd = elm_widget_data_get(obj);
EINA_SAFETY_ON_NULL_RETURN(wd);
elm_smart_scroller_object_theme_set(obj, wd->scr, "map", "base", elm_widget_style_get(obj));
_sizing_eval(wd);
}
static Eina_Bool
_event_hook(Evas_Object *obj, Evas_Object *src __UNUSED__, Evas_Callback_Type type, void *event_info)
{
ELM_CHECK_WIDTYPE(obj, widtype) EINA_FALSE;
Widget_Data *wd = elm_widget_data_get(obj);
EINA_SAFETY_ON_NULL_RETURN_VAL(wd, EINA_FALSE);
Evas_Coord x, y;
Evas_Coord vh;
Evas_Coord step_x, step_y, page_x, page_y;
if (type != EVAS_CALLBACK_KEY_DOWN) return EINA_FALSE;
Evas_Event_Key_Down *ev = event_info;
if (ev->event_flags & EVAS_EVENT_FLAG_ON_HOLD) return EINA_FALSE;
elm_smart_scroller_child_pos_get(wd->scr, &x, &y);
elm_smart_scroller_step_size_get(wd->scr, &step_x, &step_y);
elm_smart_scroller_page_size_get(wd->scr, &page_x, &page_y);
_viewport_size_get(wd, NULL, &vh);
if ((!strcmp(ev->keyname, "Left")) || (!strcmp(ev->keyname, "KP_Left")))
{
x -= step_x;
}
else if ((!strcmp(ev->keyname, "Right")) || (!strcmp(ev->keyname, "KP_Right")))
{
x += step_x;
}
else if ((!strcmp(ev->keyname, "Up")) || (!strcmp(ev->keyname, "KP_Up")))
{
y -= step_y;
}
else if ((!strcmp(ev->keyname, "Down")) || (!strcmp(ev->keyname, "KP_Down")))
{
y += step_y;
}
else if ((!strcmp(ev->keyname, "Prior")) || (!strcmp(ev->keyname, "KP_Prior")))
{
if (page_y < 0)
y -= -(page_y * vh) / 100;
else
y -= page_y;
}
else if ((!strcmp(ev->keyname, "Next")) || (!strcmp(ev->keyname, "KP_Next")))
{
if (page_y < 0)
y += -(page_y * vh) / 100;
else
y += page_y;
}
else if (!strcmp(ev->keyname, "KP_Add"))
{
zoom_with_animation(wd, wd->zoom + 1, 10);
return EINA_TRUE;
}
else if (!strcmp(ev->keyname, "KP_Subtract"))
{
zoom_with_animation(wd, wd->zoom - 1, 10);
return EINA_TRUE;
}
else return EINA_FALSE;
ev->event_flags |= EVAS_EVENT_FLAG_ON_HOLD;
elm_smart_scroller_child_pos_set(wd->scr, x, y);
return EINA_TRUE;
}
static Eina_Bool
cb_dump_name_attrs(void *data, const char *key, const char *value)
{
@ -3462,7 +3283,6 @@ _source_tile_mod_cb(Eina_Module *m, void *data)
s->coord_to_geo = coord_to_geo;
wd->src_tiles = eina_list_append(wd->src_tiles, s);
eina_module_unload(m);
return EINA_TRUE;
}
@ -3472,7 +3292,6 @@ _source_tile_load(Widget_Data *wd)
unsigned int idx;
Eina_List *l;
Source_Tile *s;
Eina_Array *modules = NULL;
// Load from hard coded data
for (idx = 0; idx < (sizeof(src_tiles) / sizeof(Source_Tile)); idx++)
@ -3488,8 +3307,8 @@ _source_tile_load(Widget_Data *wd)
}
// Load from modules
modules = eina_module_list_get(modules, MODULES_PATH, 1, &_source_tile_mod_cb, wd);
eina_array_free(modules);
wd->src_tile_mods = eina_module_list_get(wd->src_tile_mods, MODULES_PATH, 1,
&_source_tile_mod_cb, wd);
// Set default source
wd->src_tile = eina_list_nth(wd->src_tiles, 0);
@ -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;

View File

@ -185,15 +185,6 @@ typedef void (*Elm_Map_Overlay_Get_Cb)(void *data, Evas_Ob
typedef void (*Elm_Map_Name_Cb)(void *data, Evas_Object *map, const Elm_Map_Name *name); /**< Async-callback function for the name request. */
typedef void (*Elm_Map_Route_Cb)(void *data, Evas_Object *map, const Elm_Map_Route *route); /**< Async-callback function for the route request. */
typedef char *(*Elm_Map_Module_Source_Name_Func)(void);
typedef int (*Elm_Map_Module_Tile_Zoom_Min_Func)(void);
typedef int (*Elm_Map_Module_Tile_Zoom_Max_Func)(void);
typedef char *(*Elm_Map_Module_Tile_Url_Func)(Evas_Object *obj, int x, int y, int zoom);
typedef Eina_Bool (*Elm_Map_Module_Tile_Geo_to_Coord_Func)(const Evas_Object *obj, int zoom, double lon, double lat, int size, int *x, int *y);
typedef Eina_Bool (*Elm_Map_Module_Tile_Coord_to_Geo_Func)(const Evas_Object *obj, int zoom, int x, int y, int size, double *lon, double *lat);
typedef char *(*Elm_Map_Module_Route_Url_Func)(Evas_Object *obj, const char *type_name, int method, double flon, double flat, double tlon, double tlat);
typedef char *(*Elm_Map_Module_Name_Url_Func)(Evas_Object *obj, int method, const char *name, double lon, double lat);
/**
* Add a new map widget to the given parent Elementary (container) object.
*
@ -394,7 +385,7 @@ EAPI void elm_map_region_bring_in(Evas_Object *obj, double lon,
EAPI void elm_map_region_show(Evas_Object *obj, double lon, double lat);
/**
* Convert canvas coordinates into a geographic coordinate
* Convert canvas coordinates into geographic coordinates
* (longitude, latitude).
*
* @param obj The map object.
@ -406,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);