EINA_LIST_FOREACH(ee->sub_ecore_evas, ll, ee2)
{
- if (ee2->func.fn_pre_render) ee2->func.fn_pre_render(ee2);
- _ecore_evas_buffer_render(ee2);
- if (ee2->func.fn_post_render) ee2->func.fn_post_render(ee2);
+ if (ee2->func.fn_pre_render) ee2->func.fn_pre_render(ee2);
+ _ecore_evas_buffer_render(ee2);
+ if (ee2->func.fn_post_render) ee2->func.fn_post_render(ee2);
}
#endif
if (ee->func.fn_pre_render) ee->func.fn_pre_render(ee);
if (!ecore_evases) return 1;
if (_ecore_evas_fps_debug)
{
- t1 = ecore_time_get();
+ t1 = ecore_time_get();
}
for (l = (Ecore_List2 *)ecore_evases; l; l = l->next)
{
- Ecore_Evas *ee;
+ Ecore_Evas *ee;
- ee = (Ecore_Evas *)l;
- _ecore_evas_win32_render(ee);
+ ee = (Ecore_Evas *)l;
+ _ecore_evas_win32_render(ee);
}
/* ecore_x_flush(); */
if (_ecore_evas_fps_debug)
{
- t2 = ecore_time_get();
-/* _ecore_evas_fps_debug_rendertime_add(t2 - t1); */
+ t2 = ecore_time_get();
+/* _ecore_evas_fps_debug_rendertime_add(t2 - t1); */
}
return 1;
}
_ecore_evas_init_count--;
if (_ecore_evas_init_count == 0)
{
- int i;
-
- while (ecore_evases) _ecore_evas_free(ecore_evases);
- for (i = 0; i < ECORE_EVAS_EVENT_COUNT; i++)
- ecore_event_handler_del(ecore_evas_event_handlers[i]);
- ecore_idle_enterer_del(ecore_evas_idle_enterer);
- ecore_evas_idle_enterer = NULL;
- ecore_event_evas_shutdown();
+ int i;
+
+ while (ecore_evases) _ecore_evas_free(ecore_evases);
+ for (i = 0; i < ECORE_EVAS_EVENT_COUNT; i++)
+ ecore_event_handler_del(ecore_evas_event_handlers[i]);
+ ecore_idle_enterer_del(ecore_evas_idle_enterer);
+ ecore_evas_idle_enterer = NULL;
+ ecore_event_evas_shutdown();
}
if (_ecore_evas_init_count < 0) _ecore_evas_init_count = 0;
ecore_evas_avoid_damage_set(ee, 1);
}
/* FIXME: to do... */
-/* if (ee->shaped) */
-/* _ecore_evas_x_resize_shape(ee); */
+/* if (ee->shaped) */
+/* _ecore_evas_x_resize_shape(ee); */
if ((ee->expecting_resize.w > 0) &&
(ee->expecting_resize.h > 0))
{
if ((ee->expecting_resize.w == ee->w) &&
(ee->expecting_resize.h == ee->h))
_ecore_evas_mouse_move_process(ee, ee->mouse.x, ee->mouse.y,
- ecore_win32_current_time_get());
+ ecore_win32_current_time_get());
ee->expecting_resize.w = 0;
ee->expecting_resize.h = 0;
}
if (!strcmp(ee->driver, "software_ddraw"))
{
#ifdef BUILD_ECORE_EVAS_SOFTWARE_DDRAW
- Evas_Engine_Info_Software_DDraw *einfo;
-
- einfo = (Evas_Engine_Info_Software_DDraw *)evas_engine_info_get(ee->evas);
- if (!einfo) return;
- if (rot_dif != 180)
- {
- int minw, minh, maxw, maxh, basew, baseh, stepw, steph;
-
- einfo->info.rotation = rotation;
- evas_engine_info_set(ee->evas, (Evas_Engine_Info *)einfo);
- if (!ee->prop.fullscreen)
- {
- ecore_win32_window_resize(ee->prop.window, ee->h, ee->w);
- ee->expecting_resize.w = ee->h;
- ee->expecting_resize.h = ee->w;
- }
- else
- {
- int w, h;
-
- ecore_win32_window_size_get(ee->prop.window, &w, &h);
- ecore_win32_window_resize(ee->prop.window, h, w);
- if ((rotation == 0) || (rotation == 180))
- {
- evas_output_size_set(ee->evas, ee->w, ee->h);
- evas_output_viewport_set(ee->evas, 0, 0, ee->w, ee->h);
- }
- else
- {
- evas_output_size_set(ee->evas, ee->h, ee->w);
- evas_output_viewport_set(ee->evas, 0, 0, ee->h, ee->w);
- }
- if (ee->func.fn_resize) ee->func.fn_resize(ee);
- }
- ecore_evas_size_min_get(ee, &minw, &minh);
- ecore_evas_size_max_get(ee, &maxw, &maxh);
- ecore_evas_size_base_get(ee, &basew, &baseh);
- ecore_evas_size_step_get(ee, &stepw, &steph);
- ee->rotation = rotation;
- ecore_evas_size_min_set(ee, minh, minw);
- ecore_evas_size_max_set(ee, maxh, maxw);
- ecore_evas_size_base_set(ee, baseh, basew);
- ecore_evas_size_step_set(ee, steph, stepw);
- _ecore_evas_mouse_move_process(ee, ee->mouse.x, ee->mouse.y,
- ecore_win32_current_time_get());
- }
- else
- {
- einfo->info.rotation = rotation;
- evas_engine_info_set(ee->evas, (Evas_Engine_Info *)einfo);
- ee->rotation = rotation;
- _ecore_evas_mouse_move_process(ee, ee->mouse.x, ee->mouse.y,
+ Evas_Engine_Info_Software_DDraw *einfo;
+
+ einfo = (Evas_Engine_Info_Software_DDraw *)evas_engine_info_get(ee->evas);
+ if (!einfo) return;
+ if (rot_dif != 180)
+ {
+ int minw, minh, maxw, maxh, basew, baseh, stepw, steph;
+
+ einfo->info.rotation = rotation;
+ evas_engine_info_set(ee->evas, (Evas_Engine_Info *)einfo);
+ if (!ee->prop.fullscreen)
+ {
+ ecore_win32_window_resize(ee->prop.window, ee->h, ee->w);
+ ee->expecting_resize.w = ee->h;
+ ee->expecting_resize.h = ee->w;
+ }
+ else
+ {
+ int w, h;
+
+ ecore_win32_window_size_get(ee->prop.window, &w, &h);
+ ecore_win32_window_resize(ee->prop.window, h, w);
+ if ((rotation == 0) || (rotation == 180))
+ {
+ evas_output_size_set(ee->evas, ee->w, ee->h);
+ evas_output_viewport_set(ee->evas, 0, 0, ee->w, ee->h);
+ }
+ else
+ {
+ evas_output_size_set(ee->evas, ee->h, ee->w);
+ evas_output_viewport_set(ee->evas, 0, 0, ee->h, ee->w);
+ }
+ if (ee->func.fn_resize) ee->func.fn_resize(ee);
+ }
+ ecore_evas_size_min_get(ee, &minw, &minh);
+ ecore_evas_size_max_get(ee, &maxw, &maxh);
+ ecore_evas_size_base_get(ee, &basew, &baseh);
+ ecore_evas_size_step_get(ee, &stepw, &steph);
+ ee->rotation = rotation;
+ ecore_evas_size_min_set(ee, minh, minw);
+ ecore_evas_size_max_set(ee, maxh, maxw);
+ ecore_evas_size_base_set(ee, baseh, basew);
+ ecore_evas_size_step_set(ee, steph, stepw);
+ _ecore_evas_mouse_move_process(ee, ee->mouse.x, ee->mouse.y,
+ ecore_win32_current_time_get());
+ }
+ else
+ {
+ einfo->info.rotation = rotation;
+ evas_engine_info_set(ee->evas, (Evas_Engine_Info *)einfo);
+ ee->rotation = rotation;
+ _ecore_evas_mouse_move_process(ee, ee->mouse.x, ee->mouse.y,
ecore_win32_current_time_get());
- if (ee->func.fn_resize) ee->func.fn_resize(ee);
- }
- if ((ee->rotation == 90) || (ee->rotation == 270))
- evas_damage_rectangle_add(ee->evas, 0, 0, ee->h, ee->w);
- else
- evas_damage_rectangle_add(ee->evas, 0, 0, ee->w, ee->h);
+ if (ee->func.fn_resize) ee->func.fn_resize(ee);
+ }
+ if ((ee->rotation == 90) || (ee->rotation == 270))
+ evas_damage_rectangle_add(ee->evas, 0, 0, ee->h, ee->w);
+ else
+ evas_damage_rectangle_add(ee->evas, 0, 0, ee->w, ee->h);
#endif /* BUILD_ECORE_EVAS_SOFTWARE_DDRAW */
}
}
if (obj == NULL)
{
- ee->prop.cursor.object = NULL;
- ee->prop.cursor.layer = 0;
- ee->prop.cursor.hot.x = 0;
- ee->prop.cursor.hot.y = 0;
- ecore_win32_window_cursor_show(ee->prop.window, 1);
- return;
+ ee->prop.cursor.object = NULL;
+ ee->prop.cursor.layer = 0;
+ ee->prop.cursor.hot.x = 0;
+ ee->prop.cursor.hot.y = 0;
+ ecore_win32_window_cursor_show(ee->prop.window, 1);
+ return;
}
ee->prop.cursor.object = obj;
evas_pointer_output_xy_get(ee->evas, &x, &y);
evas_object_layer_set(ee->prop.cursor.object, ee->prop.cursor.layer);
evas_object_move(ee->prop.cursor.object,
- x - ee->prop.cursor.hot.x,
- y - ee->prop.cursor.hot.y);
+ x - ee->prop.cursor.hot.x,
+ y - ee->prop.cursor.hot.y);
evas_object_pass_events_set(ee->prop.cursor.object, 1);
if (evas_pointer_inside_get(ee->evas))
evas_object_show(ee->prop.cursor.object);
/* API */
+#ifdef BUILD_ECORE_EVAS_SOFTWARE_GDI
+static int
+_ecore_evas_engine_software_gdi_init(Ecore_Evas *ee)
+{
+ Evas_Engine_Info_Software_Gdi *einfo;
+ const char *driver;
+ int rmethod;
+
+ driver = "software_gdi";
+
+ rmethod = evas_render_method_lookup(driver);
+ if (!rmethod)
+ return 0;
+
+ ee->driver = driver;
+ evas_output_method_set(ee->evas, rmethod);
+
+ einfo = (Evas_Engine_Info_Software_Gdi *)evas_engine_info_get(ee->evas);
+ if (einfo)
+ {
+ /* FIXME: REDRAW_DEBUG missing for now */
+ einfo->info.window = ((struct _Ecore_Win32_Window *)ee->prop.window)->window;
+ einfo->info.mask = NULL;
+ einfo->info.depth = ecore_win32_screen_depth_get();
+ einfo->info.rotation = 0;
+ einfo->info.fullscreen = 0;
+ evas_engine_info_set(ee->evas, (Evas_Engine_Info *)einfo);
+ }
+
+ return 1;
+}
+#endif /* BUILD_ECORE_EVAS_SOFTWARE_GDI */
+
#ifdef BUILD_ECORE_EVAS_SOFTWARE_DDRAW
static int
_ecore_evas_engine_software_ddraw_init(Ecore_Evas *ee)
einfo->info.window = ((struct _Ecore_Win32_Window *)ee->prop.window)->window;
einfo->info.depth = ecore_win32_screen_depth_get();
einfo->info.rotation = 0;
- evas_engine_info_set(ee->evas, (Evas_Engine_Info *)einfo);
+ evas_engine_info_set(ee->evas, (Evas_Engine_Info *)einfo);
}
return 1;
einfo->info.window = ((struct _Ecore_Win32_Window *)ee->prop.window)->window;
einfo->info.depth = ecore_win32_screen_depth_get();
einfo->info.rotation = 0;
- evas_engine_info_set(ee->evas, (Evas_Engine_Info *)einfo);
+ evas_engine_info_set(ee->evas, (Evas_Engine_Info *)einfo);
}
return 1;
/* FIXME: REDRAW_DEBUG missing for now */
einfo->info.window = ((struct _Ecore_Win32_Window *)ee->prop.window)->window;
einfo->info.depth = ecore_win32_screen_depth_get();
- evas_engine_info_set(ee->evas, (Evas_Engine_Info *)einfo);
+ evas_engine_info_set(ee->evas, (Evas_Engine_Info *)einfo);
}
return 1;
einfo->info.window = ((struct _Ecore_Win32_Window *)ee->prop.window)->window;
einfo->info.depth = ecore_win32_screen_depth_get();
einfo->info.rotation = 0;
- evas_engine_info_set(ee->evas, (Evas_Engine_Info *)einfo);
+ evas_engine_info_set(ee->evas, (Evas_Engine_Info *)einfo);
}
return 1;
#endif /* BUILD_ECORE_EVAS_WIN32 */
+#ifdef BUILD_ECORE_EVAS_SOFTWARE_GDI
+
+EAPI Ecore_Evas *
+ecore_evas_software_gdi_new(Ecore_Win32_Window *parent,
+ int x,
+ int y,
+ int width,
+ int height)
+{
+ return _ecore_evas_win32_new_internal(_ecore_evas_engine_software_gdi_init,
+ parent,
+ x,
+ y,
+ width,
+ height);
+}
+
+#else
+
+EAPI Ecore_Evas *
+ecore_evas_software_gdi_new(Ecore_Win32_Window *parent __UNUSED__,
+ int x __UNUSED__,
+ int y __UNUSED__,
+ int width __UNUSED__,
+ int height __UNUSED__)
+{
+ return NULL;
+}
+
+#endif /* ! BUILD_ECORE_EVAS_SOFTWARE_GDI */
+
#ifdef BUILD_ECORE_EVAS_SOFTWARE_DDRAW
EAPI Ecore_Evas *
#ifdef BUILD_ECORE_EVAS_SOFTWARE_16_WINCE
-#define ECORE_EVAS_EVENT_COUNT 12
+#define ECORE_EVAS_EVENT_COUNT 7
static int _ecore_evas_init_count = 0;
static int _ecore_evas_fps_debug = 0;
static Ecore_Evas *ecore_evases = NULL;
static Eina_Hash *ecore_evases_hash = NULL;
-static int _ecore_evas_wince_event_key_down(void *data __UNUSED__, int type __UNUSED__, void *event);
-
-static int _ecore_evas_wince_event_key_up(void *data __UNUSED__, int type __UNUSED__, void *event);
-
-static int _ecore_evas_wince_event_mouse_button_down(void *data __UNUSED__, int type __UNUSED__, void *event);
-
-static int _ecore_evas_wince_event_mouse_button_up(void *data __UNUSED__, int type __UNUSED__, void *event);
-
-static int _ecore_evas_wince_event_mouse_move(void *data __UNUSED__, int type __UNUSED__, void *event);
-
static int _ecore_evas_wince_event_mouse_in(void *data __UNUSED__, int type __UNUSED__, void *event);
static int _ecore_evas_wince_event_mouse_out(void *data __UNUSED__, int type __UNUSED__, void *event);
ecore_evas_idle_enterer = ecore_idle_enterer_add(_ecore_evas_wince_idle_enter, NULL);
- ecore_evas_event_handlers[0] = ecore_event_handler_add(ECORE_WINCE_EVENT_KEY_DOWN, _ecore_evas_wince_event_key_down, NULL);
- ecore_evas_event_handlers[1] = ecore_event_handler_add(ECORE_WINCE_EVENT_KEY_UP, _ecore_evas_wince_event_key_up, NULL);
- ecore_evas_event_handlers[2] = ecore_event_handler_add(ECORE_WINCE_EVENT_MOUSE_BUTTON_DOWN, _ecore_evas_wince_event_mouse_button_down, NULL);
- ecore_evas_event_handlers[3] = ecore_event_handler_add(ECORE_WINCE_EVENT_MOUSE_BUTTON_UP, _ecore_evas_wince_event_mouse_button_up, NULL);
- ecore_evas_event_handlers[4] = ecore_event_handler_add(ECORE_WINCE_EVENT_MOUSE_MOVE, _ecore_evas_wince_event_mouse_move, NULL);
- ecore_evas_event_handlers[5] = ecore_event_handler_add(ECORE_WINCE_EVENT_MOUSE_IN, _ecore_evas_wince_event_mouse_in, NULL);
- ecore_evas_event_handlers[6] = ecore_event_handler_add(ECORE_WINCE_EVENT_MOUSE_OUT, _ecore_evas_wince_event_mouse_out, NULL);
- ecore_evas_event_handlers[7] = ecore_event_handler_add(ECORE_WINCE_EVENT_WINDOW_DAMAGE, _ecore_evas_wince_event_window_damage, NULL);
- ecore_evas_event_handlers[8] = ecore_event_handler_add(ECORE_WINCE_EVENT_WINDOW_DESTROY, _ecore_evas_wince_event_window_destroy, NULL);
- ecore_evas_event_handlers[9] = ecore_event_handler_add(ECORE_WINCE_EVENT_WINDOW_SHOW, _ecore_evas_wince_event_window_show, NULL);
- ecore_evas_event_handlers[10] = ecore_event_handler_add(ECORE_WINCE_EVENT_WINDOW_HIDE, _ecore_evas_wince_event_window_hide, NULL);
- ecore_evas_event_handlers[11] = ecore_event_handler_add(ECORE_WINCE_EVENT_WINDOW_DELETE_REQUEST, _ecore_evas_wince_event_window_delete_request, NULL);
+ ecore_evas_event_handlers[0] = ecore_event_handler_add(ECORE_WINCE_EVENT_MOUSE_OUT, _ecore_evas_wince_event_mouse_out, NULL);
+ ecore_evas_event_handlers[2] = ecore_event_handler_add(ECORE_WINCE_EVENT_WINDOW_DAMAGE, _ecore_evas_wince_event_window_damage, NULL);
+ ecore_evas_event_handlers[3] = ecore_event_handler_add(ECORE_WINCE_EVENT_WINDOW_DESTROY, _ecore_evas_wince_event_window_destroy, NULL);
+ ecore_evas_event_handlers[4] = ecore_event_handler_add(ECORE_WINCE_EVENT_WINDOW_SHOW, _ecore_evas_wince_event_window_show, NULL);
+ ecore_evas_event_handlers[5] = ecore_event_handler_add(ECORE_WINCE_EVENT_WINDOW_HIDE, _ecore_evas_wince_event_window_hide, NULL);
+ ecore_evas_event_handlers[6] = ecore_event_handler_add(ECORE_WINCE_EVENT_WINDOW_DELETE_REQUEST, _ecore_evas_wince_event_window_delete_request, NULL);
if (_ecore_evas_fps_debug) _ecore_evas_fps_debug_init();
+ ecore_event_evas_init();
return _ecore_evas_init_count;
}
ecore_idle_enterer_del(ecore_evas_idle_enterer);
ecore_evas_idle_enterer = NULL;
if (_ecore_evas_fps_debug) _ecore_evas_fps_debug_shutdown();
+ ecore_event_evas_shutdown();
}
if (_ecore_evas_init_count < 0) _ecore_evas_init_count = 0;
return _ecore_evas_init_count;
}
-static char *
-_ecore_evas_wince_winid_str_get(Ecore_WinCE_Window *window)
-{
- static char id[9];
- const char *vals = "qWeRtYuIoP5-$&<~";
- unsigned int val;
-
- val = (unsigned int)window;
- id[0] = vals[(val >> 28) & 0xf];
- id[1] = vals[(val >> 24) & 0xf];
- id[2] = vals[(val >> 20) & 0xf];
- id[3] = vals[(val >> 16) & 0xf];
- id[4] = vals[(val >> 12) & 0xf];
- id[5] = vals[(val >> 8) & 0xf];
- id[6] = vals[(val >> 4) & 0xf];
- id[7] = vals[(val ) & 0xf];
- id[8] = 0;
-
- return id;
-}
-
-static Ecore_Evas *
-_ecore_evas_wince_match(Ecore_WinCE_Window *window)
-{
- Ecore_Evas *ee;
-
- ee = eina_hash_find(ecore_evases_hash, _ecore_evas_wince_winid_str_get(window));
-
- return ee;
-}
-
-static int
-_ecore_evas_wince_event_key_down(void *data __UNUSED__, int type __UNUSED__, void *event)
-{
- Ecore_Evas *ee;
- Ecore_WinCE_Event_Key_Down *e;
-
- e = event;
-
- EINA_ERROR_PINFO("key down (%f %s %s %s)\n", e->time, e->keyname, e->keysymbol, e->keycompose);
-
- ee = _ecore_evas_wince_match(e->window);
- if ((!ee) || (ee->ignore_events)) return 1; /* pass on event */
- /* FIXME to do */
-/* _ecore_evas_x_modifier_locks_update(ee, e->modifiers); */
- evas_event_feed_key_down(ee->evas, e->keyname, e->keysymbol, e->keycompose, NULL, e->time, NULL);
-
- return 1;
-}
-
-static int
-_ecore_evas_wince_event_key_up(void *data __UNUSED__, int type __UNUSED__, void *event)
-{
- Ecore_Evas *ee;
- Ecore_WinCE_Event_Key_Up *e;
-
- e = event;
-
- EINA_ERROR_PINFO("key up (%f %s %s %s)\n", e->time, e->keyname, e->keysymbol, e->keycompose);
-
- ee = _ecore_evas_wince_match(e->window);
- if ((!ee) || (ee->ignore_events)) return 1; /* pass on event */
- /* FIXME to do */
-/* _ecore_evas_x_modifier_locks_update(ee, e->modifiers); */
- evas_event_feed_key_up(ee->evas, e->keyname, e->keysymbol, e->keycompose, NULL, e->time, NULL);
-
- return 1;
-}
-
-static int
-_ecore_evas_wince_event_mouse_button_down(void *data __UNUSED__, int type __UNUSED__, void *event)
-{
- Ecore_Evas *ee;
- Ecore_WinCE_Event_Mouse_Button_Down *e;
- Evas_Button_Flags flags = EVAS_BUTTON_NONE;
-
- e = event;
-
- EINA_ERROR_PINFO("mouse button down (%f %dx%d)\n", e->time, e->x, e->y);
-
- ee = _ecore_evas_wince_match(e->window);
- if ((!ee) || (ee->ignore_events)) return 1; /* pass on event */
- if (e->window != ee->engine.wince.window) return 1;
- /* FIXME to do */
-/* _ecore_evas_x_modifier_locks_update(ee, e->modifiers); */
- if (e->double_click) flags |= EVAS_BUTTON_DOUBLE_CLICK;
- if (e->triple_click) flags |= EVAS_BUTTON_TRIPLE_CLICK;
- evas_event_feed_mouse_down(ee->evas, e->button, flags, e->time, NULL);
-
- return 1;
-}
-
-static int
-_ecore_evas_wince_event_mouse_button_up(void *data __UNUSED__, int type __UNUSED__, void *event)
-{
- Ecore_Evas *ee;
- Ecore_WinCE_Event_Mouse_Button_Up *e;
- Evas_Button_Flags flags = EVAS_BUTTON_NONE;
-
- e = event;
-
- EINA_ERROR_PINFO("mouse button up (%f %dx%d)\n", e->time, e->x, e->y);
-
- ee = _ecore_evas_wince_match(e->window);
- if ((!ee) || (ee->ignore_events)) return 1; /* pass on event */
- if (e->window != ee->engine.wince.window) return 1;
- /* FIXME to do */
-/* _ecore_evas_x_modifier_locks_update(ee, e->modifiers); */
- if (e->double_click) flags |= EVAS_BUTTON_DOUBLE_CLICK;
- if (e->triple_click) flags |= EVAS_BUTTON_TRIPLE_CLICK;
- evas_event_feed_mouse_up(ee->evas, e->button, flags, e->time, NULL);
-
- return 1;
-}
-
-static int
-_ecore_evas_wince_event_mouse_move(void *data __UNUSED__, int type __UNUSED__, void *event)
-{
- Ecore_Evas *ee;
- Ecore_WinCE_Event_Mouse_Move *e;
-
- EINA_ERROR_PINFO("mouse move\n");
-
- e = event;
- ee = _ecore_evas_wince_match(e->window);
- if ((!ee) || (ee->ignore_events)) return 1; /* pass on event */
- if (e->window != ee->engine.wince.window) return 1;
- /* FIXME to do */
-/* _ecore_evas_x_modifier_locks_update(ee, e->modifiers); */
- _ecore_evas_mouse_move_process(ee, e->x, e->y, e->time);
-
- return 1;
-}
-
static int
_ecore_evas_wince_event_mouse_in(void *data __UNUSED__, int type __UNUSED__, void *event)
{
EINA_ERROR_PINFO("mouse in\n");
e = event;
- ee = _ecore_evas_wince_match(e->window);
+ ee = ecore_event_window_match(e->window);
if ((!ee) || (ee->ignore_events)) return 1; /* pass on event */
- if (e->window != ee->engine.wince.window) return 1;
+ if (e->window != ee->prop.window) return 1;
if (ee->func.fn_mouse_in) ee->func.fn_mouse_in(ee);
/* FIXME to do */
EINA_ERROR_PINFO("mouse out\n");
e = event;
- ee = _ecore_evas_wince_match(e->window);
+ ee = ecore_event_window_match(e->window);
if ((!ee) || (ee->ignore_events)) return 1; /* pass on event */
- if (e->window != ee->engine.wince.window) return 1;
+ if (e->window != ee->prop.window) return 1;
/* FIXME to do */
/* _ecore_evas_x_modifier_locks_update(ee, e->modifiers); */
EINA_ERROR_PINFO("window damage\n");
e = event;
- ee = _ecore_evas_wince_match(e->window);
+ ee = ecore_event_window_match(e->window);
if (!ee) return 1; /* pass on event */
- if (e->window != ee->engine.wince.window) return 1;
+ if (e->window != ee->prop.window) return 1;
if (ee->prop.avoid_damage)
{
EINA_ERROR_PINFO("window destroy\n");
e = event;
- ee = _ecore_evas_wince_match(e->window);
+ ee = ecore_event_window_match(e->window);
if (!ee) return 1; /* pass on event */
- if (e->window != ee->engine.wince.window) return 1;
+ if (e->window != ee->prop.window) return 1;
if (ee->func.fn_destroy) ee->func.fn_destroy(ee);
ecore_evas_free(ee);
EINA_ERROR_PINFO("window show\n");
e = event;
- ee = _ecore_evas_wince_match(e->window);
+ ee = ecore_event_window_match(e->window);
if (!ee) return 1; /* pass on event */
- if (e->window != ee->engine.wince.window) return 1;
+ if (e->window != ee->prop.window) return 1;
if (ee->visible) return 0; /* dont pass it on */
ee->visible = 1;
if (ee->func.fn_show) ee->func.fn_show(ee);
EINA_ERROR_PINFO("window hide\n");
e = event;
- ee = _ecore_evas_wince_match(e->window);
+ ee = ecore_event_window_match(e->window);
if (!ee) return 1; /* pass on event */
- if (e->window != ee->engine.wince.window) return 1;
+ if (e->window != ee->prop.window) return 1;
if (!ee->visible) return 0; /* dont pass it on */
ee->visible = 0;
if (ee->func.fn_hide) ee->func.fn_hide(ee);
EINA_ERROR_PINFO("window delete request\n");
e = event;
- ee = _ecore_evas_wince_match(e->window);
+ ee = ecore_event_window_match(e->window);
if (!ee) return 1; /* pass on event */
- if (e->window != ee->engine.wince.window) return 1;
+ if (e->window != ee->prop.window) return 1;
if (ee->func.fn_delete_request) ee->func.fn_delete_request(ee);
return 1;
{
EINA_ERROR_PINFO("ecore evas free\n");
- ecore_wince_window_free(ee->engine.wince.window);
- eina_hash_del(ecore_evases_hash, _ecore_evas_wince_winid_str_get(ee->engine.wince.window), ee);
+ ecore_wince_window_free(ee->prop.window);
+ ecore_event_window_unregister(ee->prop.window);
ecore_evases = _ecore_list2_remove(ecore_evases, ee);
_ecore_evas_wince_shutdown();
ecore_wince_shutdown();
{
ee->x = x;
ee->y = y;
- ecore_wince_window_move(ee->engine.wince.window, x, y);
+ ecore_wince_window_move(ee->prop.window, x, y);
if (ee->func.fn_move) ee->func.fn_move(ee);
}
}
{
ee->w = width;
ee->h = height;
- ecore_wince_window_resize(ee->engine.wince.window, width, height);
+ ecore_wince_window_resize(ee->prop.window, width, height);
if ((ee->rotation == 90) || (ee->rotation == 270))
{
evas_output_size_set(ee->evas, ee->h, ee->w);
ee->y = y;
ee->w = width;
ee->h = height;
- ecore_wince_window_move_resize(ee->engine.wince.window, x, y, width, height);
+ ecore_wince_window_move_resize(ee->prop.window, x, y, width, height);
if ((ee->rotation == 90) || (ee->rotation == 270))
{
evas_output_size_set(ee->evas, ee->h, ee->w);
/* evas_engine_info_set(ee->evas, (Evas_Engine_Info *)einfo); */
/* if (!ee->prop.fullscreen) */
/* { */
-/* ecore_wince_window_resize(ee->engine.wince.window, ee->h, ee->w); */
+/* ecore_wince_window_resize(ee->prop.window, ee->h, ee->w); */
/* ee->expecting_resize.w = ee->h; */
/* ee->expecting_resize.h = ee->w; */
/* } */
/* { */
/* int w, h; */
-/* ecore_wince_window_size_get(ee->engine.wince.window, &w, &h); */
-/* ecore_wince_window_resize(ee->engine.wince.window, h, w); */
+/* ecore_wince_window_size_get(ee->prop.window, &w, &h); */
+/* ecore_wince_window_resize(ee->prop.window, h, w); */
/* if ((rotation == 0) || (rotation == 180)) */
/* { */
/* evas_output_size_set(ee->evas, ee->w, ee->h); */
ee->should_be_visible = 1;
if (ee->prop.avoid_damage)
_ecore_evas_wince_render(ee);
- ecore_wince_window_show(ee->engine.wince.window);
+ ecore_wince_window_show(ee->prop.window);
/* if (ee->prop.fullscreen) */
-/* ecore_wince_window_focus(ee->engine.wince.window); */
+/* ecore_wince_window_focus(ee->prop.window); */
}
static void
{
EINA_ERROR_PINFO("ecore evas hide\n");
- ecore_wince_window_hide(ee->engine.wince.window);
+ ecore_wince_window_hide(ee->prop.window);
ee->should_be_visible = 0;
}
/* _ecore_evas_wince_raise(Ecore_Evas *ee) */
/* { */
/* if (!ee->prop.fullscreen) */
-/* ecore_wince_window_raise(ee->engine.wince.window); */
+/* ecore_wince_window_raise(ee->prop.window); */
/* else */
-/* ecore_wince_window_raise(ee->engine.wince.window); */
+/* ecore_wince_window_raise(ee->prop.window); */
/* } */
/* static void */
/* _ecore_evas_wince_lower(Ecore_Evas *ee) */
/* { */
/* if (!ee->prop.fullscreen) */
-/* ecore_wince_window_lower(ee->engine.wince.window); */
+/* ecore_wince_window_lower(ee->prop.window); */
/* else */
-/* ecore_wince_window_lower(ee->engine.wince.window); */
+/* ecore_wince_window_lower(ee->prop.window); */
/* } */
static void
if (ee->prop.title) free(ee->prop.title);
ee->prop.title = NULL;
if (title) ee->prop.title = strdup(title);
- ecore_wince_window_title_set(ee->engine.wince.window, ee->prop.title);
+ ecore_wince_window_title_set(ee->prop.window, ee->prop.title);
}
/* static void */
/* if ((ee->prop.min.w == width) && (ee->prop.min.h == height)) return; */
/* ee->prop.min.w = width; */
/* ee->prop.min.h = height; */
-/* ecore_wince_window_size_min_set(ee->engine.wince.window, width, height); */
+/* ecore_wince_window_size_min_set(ee->prop.window, width, height); */
/* } */
/* static void */
/* if ((ee->prop.max.w == width) && (ee->prop.max.h == height)) return; */
/* ee->prop.max.w = width; */
/* ee->prop.max.h = height; */
-/* ecore_wince_window_size_max_set(ee->engine.wince.window, width, height); */
+/* ecore_wince_window_size_max_set(ee->prop.window, width, height); */
/* } */
/* static void */
/* if ((ee->prop.base.w == width) && (ee->prop.base.h == height)) return; */
/* ee->prop.base.w = width; */
/* ee->prop.base.h = height; */
-/* ecore_wince_window_size_base_set(ee->engine.wince.window, width, height); */
+/* ecore_wince_window_size_base_set(ee->prop.window, width, height); */
/* } */
/* static void */
/* if ((ee->prop.step.w == width) && (ee->prop.step.h == height)) return; */
/* ee->prop.step.w = width; */
/* ee->prop.step.h = height; */
-/* ecore_wince_window_size_step_set(ee->engine.wince.window, width, height); */
+/* ecore_wince_window_size_step_set(ee->prop.window, width, height); */
/* } */
static void
ee->prop.cursor.layer = 0;
ee->prop.cursor.hot.x = 0;
ee->prop.cursor.hot.y = 0;
- ecore_wince_window_cursor_show(ee->engine.wince.window, 1);
+ ecore_wince_window_cursor_show(ee->prop.window, 1);
return;
}
ee->prop.cursor.hot.x = hot_x;
ee->prop.cursor.hot.y = hot_y;
- ecore_wince_window_cursor_show(ee->engine.wince.window, 0);
+ ecore_wince_window_cursor_show(ee->prop.window, 0);
evas_pointer_output_xy_get(ee->evas, &x, &y);
evas_object_layer_set(ee->prop.cursor.object, ee->prop.cursor.layer);
/* static void */
/* _ecore_evas_wince_focus_set(Ecore_Evas *ee, int on __UNUSED__) */
/* { */
-/* ecore_wince_window_focus_set(ee->engine.wince.window); */
+/* ecore_wince_window_focus_set(ee->prop.window); */
/* } */
/* static void */
/* /\* if (((ee->prop.borderless) && (on)) || *\/ */
/* /\* ((!ee->prop.borderless) && (!on))) return; *\/ */
/* ee->prop.iconified = on; */
-/* ecore_wince_window_iconified_set(ee->engine.wince.window, ee->prop.iconified); */
+/* ecore_wince_window_iconified_set(ee->prop.window, ee->prop.iconified); */
/* } */
/* static void */
/* if (((ee->prop.borderless) && (on)) || */
/* ((!ee->prop.borderless) && (!on))) return; */
/* ee->prop.borderless = on; */
-/* ecore_wince_window_borderless_set(ee->engine.wince.window, ee->prop.borderless); */
+/* ecore_wince_window_borderless_set(ee->prop.window, ee->prop.borderless); */
/* } */
static void
ee->engine.wince.state.fullscreen = on;
ee->prop.fullscreen = on;
- window = (struct _Ecore_WinCE_Window *)ee->engine.wince.window;
+ window = (struct _Ecore_WinCE_Window *)ee->prop.window;
if (on != 0)
{
/* ecore_win32_window_shape_set(ee->engine.win32.window, 0, 0, NULL); */
- ecore_wince_window_fullscreen_set(ee->engine.wince.window, on);
+ ecore_wince_window_fullscreen_set(ee->prop.window, on);
ee->w = GetSystemMetrics(SM_CXSCREEN);
ee->h = GetSystemMetrics(SM_CYSCREEN);
evas_output_size_set(ee->evas, ee->w, ee->h);
int w;
int h;
- ecore_wince_window_fullscreen_set(ee->engine.wince.window, on);
- ecore_wince_window_size_get(ee->engine.wince.window, &w, &h);
+ ecore_wince_window_fullscreen_set(ee->prop.window, on);
+ ecore_wince_window_size_get(ee->prop.window, &w, &h);
ee->w = w;
ee->h = h;
evas_output_size_set(ee->evas, ee->w, ee->h);
}
}
-static void *
-_ecore_evas_wince_window_get(const Ecore_Evas *ee)
-{
- EINA_ERROR_PINFO("ecore evas window get\n");
-
- return ee->engine.wince.window;
-}
-
static const Ecore_Evas_Engine_Func _ecore_wince_engine_func =
{
_ecore_evas_wince_free,
NULL, /* _ecore_evas_x_withdrawn_set */
NULL, /* _ecore_evas_x_sticky_set */
NULL, /* _ecore_evas_x_ignore_events_set */
- NULL, /* _ecore_evas_x_alpha_set */
- _ecore_evas_wince_window_get
+ NULL /* _ecore_evas_x_alpha_set */
};
/* API */
ee->prop.sticky = 0;
/* FIXME: sticky to add */
- ee->engine.wince.window = ecore_wince_window_new(parent, x, y, width, height);
- if (!ee->engine.wince.window)
+ ee->prop.window = ecore_wince_window_new(parent, x, y, width, height);
+ if (!ee->prop.window)
{
_ecore_evas_wince_shutdown();
free(ee);
return NULL;
}
- ecore_wince_window_fullscreen_set(ee->engine.wince.window, fullscreen);
+ ecore_wince_window_fullscreen_set(ee->prop.window, fullscreen);
/* init evas here */
ee->evas = evas_new();
if (einfo)
{
/* FIXME: REDRAW_DEBUG missing for now */
- einfo->info.window = ((struct _Ecore_WinCE_Window *)ee->engine.wince.window)->window;
+ einfo->info.window = ((struct _Ecore_WinCE_Window *)ee->prop.window)->window;
einfo->info.width = width;
einfo->info.height = height;
einfo->info.backend = backend;
einfo->info.fullscreen = fullscreen;
evas_engine_info_set(ee->evas, (Evas_Engine_Info *)einfo);
- ecore_wince_window_backend_set(ee->engine.wince.window, backend);
- ecore_wince_window_suspend_set(ee->engine.wince.window, einfo->func.suspend);
- ecore_wince_window_resume_set(ee->engine.wince.window, einfo->func.resume);
+ ecore_wince_window_backend_set(ee->prop.window, backend);
+ ecore_wince_window_suspend_set(ee->prop.window, einfo->func.suspend);
+ ecore_wince_window_resume_set(ee->prop.window, einfo->func.resume);
}
- evas_key_modifier_add(ee->evas, "Shift");
- evas_key_modifier_add(ee->evas, "Control");
- evas_key_modifier_add(ee->evas, "Alt");
- evas_key_modifier_add(ee->evas, "Meta");
- evas_key_modifier_add(ee->evas, "Hyper");
- evas_key_modifier_add(ee->evas, "Super");
- evas_key_lock_add(ee->evas, "Caps_Lock");
- evas_key_lock_add(ee->evas, "Num_Lock");
- evas_key_lock_add(ee->evas, "Scroll_Lock");
-
ecore_evases = _ecore_list2_prepend(ecore_evases, ee);
- if (!ecore_evases_hash)
- ecore_evases_hash = eina_hash_string_superfast_new(NULL);
- eina_hash_add(ecore_evases_hash, _ecore_evas_wince_winid_str_get(ee->engine.wince.window), ee);
+ ecore_event_window_register(ee->prop.window, ee, ee->evas, _ecore_evas_mouse_move_process);
return ee;
}
EAPI Ecore_WinCE_Window *
ecore_evas_software_wince_window_get(const Ecore_Evas *ee)
{
- return (Ecore_WinCE_Window *) _ecore_evas_wince_window_get(ee);
+ return (Ecore_WinCE_Window *) ecore_evas_window_get(ee);
}
#else