From: Enlightenment C. <no...@cv...> - 2007-09-23 11:57:36
|
Enlightenment CVS committal Author : doursse Project : e17 Module : libs/ecore Dir : e17/libs/ecore/src/lib/ecore_evas Modified Files: Ecore_Evas.h ecore_evas_private.h ecore_evas_win32.c Log Message: Win32 port: * add _window_get() functions * add minimal fullscreen support (not completely finished yet, but should work) * remove CR character in ecore_evas_win32.c =================================================================== RCS file: /cvs/e/e17/libs/ecore/src/lib/ecore_evas/Ecore_Evas.h,v retrieving revision 1.30 retrieving revision 1.31 diff -u -3 -r1.30 -r1.31 --- Ecore_Evas.h 26 Aug 2007 11:17:21 -0000 1.30 +++ Ecore_Evas.h 23 Sep 2007 11:57:34 -0000 1.31 @@ -140,11 +140,15 @@ int width, int height); +EAPI Ecore_Win32_Window *ecore_evas_software_ddraw_window_get(Ecore_Evas *ee); + EAPI Ecore_Evas *ecore_evas_direct3d_new(Ecore_Win32_Window *parent, int x, int y, int width, int height); + +EAPI Ecore_Win32_Window *ecore_evas_direct3d_window_get(Ecore_Evas *ee); EAPI Ecore_Evas *ecore_evas_sdl_new(const char* name, int w, int h, int fullscreen, int hwsurface, int noframe, int alpha); =================================================================== RCS file: /cvs/e/e17/libs/ecore/src/lib/ecore_evas/ecore_evas_private.h,v retrieving revision 1.30 retrieving revision 1.31 diff -u -3 -r1.30 -r1.31 --- ecore_evas_private.h 26 Aug 2007 11:17:21 -0000 1.30 +++ ecore_evas_private.h 23 Sep 2007 11:57:34 -0000 1.31 @@ -182,6 +182,9 @@ struct { Ecore_Win32_Window *parent; Ecore_Win32_Window *window; + struct { + unsigned char fullscreen : 1; + } state; } win32; #endif =================================================================== RCS file: /cvs/e/e17/libs/ecore/src/lib/ecore_evas/ecore_evas_win32.c,v retrieving revision 1.1 retrieving revision 1.2 diff -u -3 -r1.1 -r1.2 --- ecore_evas_win32.c 26 Aug 2007 11:17:21 -0000 1.1 +++ ecore_evas_win32.c 23 Sep 2007 11:57:34 -0000 1.2 @@ -1,1040 +1,1162 @@ -/* - * vim:ts=8:sw=3:sts=8:noexpandtab:cino=>5n-3f0^-2{2 - */ - -#include <stdlib.h> /* for NULL */ - -#include "config.h" -#include "Ecore.h" -#include "ecore_private.h" -#include "ecore_evas_private.h" -#include "Ecore_Evas.h" -#ifdef BUILD_ECORE_WIN32 -#include "Ecore_Win32.h" -#include "ecore_win32_private.h" -#endif - - -#ifdef BUILD_ECORE_WIN32 - -#define ECORE_EVAS_EVENT_COUNT 12 - -static int _ecore_evas_init_count = 0; -static int _ecore_evas_fps_debug = 0; - -static Ecore_Event_Handler *ecore_evas_event_handlers[ECORE_EVAS_EVENT_COUNT]; -static Ecore_Idle_Enterer *ecore_evas_idle_enterer = NULL; -static Ecore_Evas *ecore_evases = NULL; -static Evas_Hash *ecore_evases_hash = NULL; - -static int _ecore_evas_win32_event_key_down(void *data __UNUSED__, int type __UNUSED__, void *event); - -static int _ecore_evas_win32_event_key_up(void *data __UNUSED__, int type __UNUSED__, void *event); - -static int _ecore_evas_win32_event_mouse_button_down(void *data __UNUSED__, int type __UNUSED__, void *event); - -static int _ecore_evas_win32_event_mouse_button_up(void *data __UNUSED__, int type __UNUSED__, void *event); - -static int _ecore_evas_win32_event_mouse_move(void *data __UNUSED__, int type __UNUSED__, void *event); - -static int _ecore_evas_win32_event_mouse_in(void *data __UNUSED__, int type __UNUSED__, void *event); - -static int _ecore_evas_win32_event_mouse_out(void *data __UNUSED__, int type __UNUSED__, void *event); - -static int _ecore_evas_win32_event_window_damage(void *data __UNUSED__, int type __UNUSED__, void *event); - -static int _ecore_evas_win32_event_window_destroy(void *data __UNUSED__, int type __UNUSED__, void *event); - -static int _ecore_evas_win32_event_window_show(void *data __UNUSED__, int type __UNUSED__, void *event); - -static int _ecore_evas_win32_event_window_hide(void *data __UNUSED__, int type __UNUSED__, void *event); - -static int _ecore_evas_win32_event_window_delete(void *data __UNUSED__, int type __UNUSED__, void *event); - -/* Private functions */ - -static void -_ecore_evas_win32_render(Ecore_Evas *ee) -{ -#ifdef BUILD_ECORE_EVAS_BUFFER - Evas_List *ll; -#endif - -#ifdef BUILD_ECORE_EVAS_BUFFER - for (ll = ee->sub_ecore_evas; ll; ll = ll->next) - { - Ecore_Evas *ee2; - - ee2 = ll->data; - 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 (ee->prop.avoid_damage) - { - Evas_List *updates; - - updates = evas_render_updates(ee->evas); - if (updates) evas_render_updates_free(updates); - } - else if ((ee->visible) || - ((ee->should_be_visible) && (ee->prop.fullscreen)) || - ((ee->should_be_visible) && (ee->prop.override))) - { - if (ee->shaped) - { - Evas_List *updates; - - updates = evas_render_updates(ee->evas); - if (updates) evas_render_updates_free(updates); - } - else - { - Evas_List *updates; - - updates = evas_render_updates(ee->evas); - if (updates) evas_render_updates_free(updates); - } - } - else - evas_norender(ee->evas); - if (ee->func.fn_post_render) ee->func.fn_post_render(ee); -} - -static int -_ecore_evas_win32_idle_enter(void *data __UNUSED__) -{ - Ecore_List2 *l; - double t1 = 0.0; - double t2 = 0.0; - - if (_ecore_evas_fps_debug) - { - t1 = ecore_time_get(); - } - for (l = (Ecore_List2 *)ecore_evases; l; l = l->next) - { - Ecore_Evas *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); */ - } - return 1; -} - -static int -_ecore_evas_win32_init(void) -{ - _ecore_evas_init_count++; - if (_ecore_evas_init_count > 1) - return _ecore_evas_init_count; - - if (getenv("ECORE_EVAS_FPS_DEBUG")) - _ecore_evas_fps_debug = 1; - - ecore_evas_idle_enterer = ecore_idle_enterer_add(_ecore_evas_win32_idle_enter, NULL); - - ecore_evas_event_handlers[0] = ecore_event_handler_add(ECORE_WIN32_EVENT_KEY_DOWN, _ecore_evas_win32_event_key_down, NULL); - ecore_evas_event_handlers[1] = ecore_event_handler_add(ECORE_WIN32_EVENT_KEY_UP, _ecore_evas_win32_event_key_up, NULL); - ecore_evas_event_handlers[2] = ecore_event_handler_add(ECORE_WIN32_EVENT_MOUSE_BUTTON_DOWN, _ecore_evas_win32_event_mouse_button_down, NULL); - ecore_evas_event_handlers[3] = ecore_event_handler_add(ECORE_WIN32_EVENT_MOUSE_BUTTON_UP, _ecore_evas_win32_event_mouse_button_up, NULL); - ecore_evas_event_handlers[4] = ecore_event_handler_add(ECORE_WIN32_EVENT_MOUSE_MOVE, _ecore_evas_win32_event_mouse_move, NULL); - ecore_evas_event_handlers[5] = ecore_event_handler_add(ECORE_WIN32_EVENT_MOUSE_IN, _ecore_evas_win32_event_mouse_in, NULL); - ecore_evas_event_handlers[6] = ecore_event_handler_add(ECORE_WIN32_EVENT_MOUSE_OUT, _ecore_evas_win32_event_mouse_out, NULL); - ecore_evas_event_handlers[7] = ecore_event_handler_add(ECORE_WIN32_EVENT_WINDOW_DAMAGE, _ecore_evas_win32_event_window_damage, NULL); - ecore_evas_event_handlers[8] = ecore_event_handler_add(ECORE_WIN32_EVENT_WINDOW_DESTROY, _ecore_evas_win32_event_window_destroy, NULL); - ecore_evas_event_handlers[9] = ecore_event_handler_add(ECORE_WIN32_EVENT_WINDOW_SHOW, _ecore_evas_win32_event_window_show, NULL); - ecore_evas_event_handlers[10] = ecore_event_handler_add(ECORE_WIN32_EVENT_WINDOW_HIDE, _ecore_evas_win32_event_window_hide, NULL); - ecore_evas_event_handlers[11] = ecore_event_handler_add(ECORE_WIN32_EVENT_WINDOW_DELETE, _ecore_evas_win32_event_window_delete, NULL); - - return _ecore_evas_init_count; -} - -int -_ecore_evas_win32_shutdown(void) -{ - _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; - } - - if (_ecore_evas_init_count < 0) _ecore_evas_init_count = 0; - - return _ecore_evas_init_count; -} - -static char * -_ecore_evas_win32_winid_str_get(Ecore_Win32_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_win32_match(Ecore_Win32_Window *window) -{ - Ecore_Evas *ee; - - ee = evas_hash_find(ecore_evases_hash, _ecore_evas_win32_winid_str_get(window)); - - return ee; -} - -static int -_ecore_evas_win32_event_key_down(void *data __UNUSED__, int type __UNUSED__, void *event) -{ - Ecore_Evas *ee; - Ecore_Win32_Event_Key_Down *e; - - e = event; - ee = _ecore_evas_win32_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_win32_event_key_up(void *data __UNUSED__, int type __UNUSED__, void *event) -{ - Ecore_Evas *ee; - Ecore_Win32_Event_Key_Up *e; - - e = event; - ee = _ecore_evas_win32_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_win32_event_mouse_button_down(void *data __UNUSED__, int type __UNUSED__, void *event) -{ - Ecore_Evas *ee; - Ecore_Win32_Event_Mouse_Button_Down *e; - Evas_Button_Flags flags = EVAS_BUTTON_NONE; - - e = event; - ee = _ecore_evas_win32_match(e->window); - if ((!ee) || (ee->ignore_events)) return 1; /* pass on event */ - if (e->window != ee->engine.win32.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); - - printf (" * ee event button down %f\n", e->time); - - return 1; -} - -static int -_ecore_evas_win32_event_mouse_button_up(void *data __UNUSED__, int type __UNUSED__, void *event) -{ - Ecore_Evas *ee; - Ecore_Win32_Event_Mouse_Button_Up *e; - Evas_Button_Flags flags = EVAS_BUTTON_NONE; - - e = event; - ee = _ecore_evas_win32_match(e->window); - if ((!ee) || (ee->ignore_events)) return 1; /* pass on event */ - if (e->window != ee->engine.win32.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); - - printf (" * ee event button up\n"); - - return 1; -} - -static void -_ecore_evas_win32_mouse_move_process(Ecore_Evas *ee, int x, int y, unsigned int timestamp) -{ - ee->mouse.x = x; - ee->mouse.y = y; - if (ee->prop.cursor.object) - { - evas_object_show(ee->prop.cursor.object); - if (ee->rotation == 0) - evas_object_move(ee->prop.cursor.object, - x - ee->prop.cursor.hot.x, - y - ee->prop.cursor.hot.y); - else if (ee->rotation == 90) - evas_object_move(ee->prop.cursor.object, - ee->h - y - 1 - ee->prop.cursor.hot.x, - x - ee->prop.cursor.hot.y); - else if (ee->rotation == 180) - evas_object_move(ee->prop.cursor.object, - ee->w - x - 1 - ee->prop.cursor.hot.x, - ee->h - y - 1 - ee->prop.cursor.hot.y); - else if (ee->rotation == 270) - evas_object_move(ee->prop.cursor.object, - y - ee->prop.cursor.hot.x, - ee->w - x - 1 - ee->prop.cursor.hot.y); - } - if (ee->rotation == 0) - evas_event_feed_mouse_move(ee->evas, x, y, timestamp, NULL); - else if (ee->rotation == 90) - evas_event_feed_mouse_move(ee->evas, ee->h - y - 1, x, timestamp, NULL); - else if (ee->rotation == 180) - evas_event_feed_mouse_move(ee->evas, ee->w - x - 1, ee->h - y - 1, timestamp, NULL); - else if (ee->rotation == 270) - evas_event_feed_mouse_move(ee->evas, y, ee->w - x - 1, timestamp, NULL); -} - -static int -_ecore_evas_win32_event_mouse_move(void *data __UNUSED__, int type __UNUSED__, void *event) -{ - Ecore_Evas *ee; - Ecore_Win32_Event_Mouse_Move *e; - - e = event; - ee = _ecore_evas_win32_match(e->window); - if ((!ee) || (ee->ignore_events)) return 1; /* pass on event */ - if (e->window != ee->engine.win32.window) return 1; - /* FIXME to do */ -/* _ecore_evas_x_modifier_locks_update(ee, e->modifiers); */ - _ecore_evas_win32_mouse_move_process(ee, e->x, e->y, e->time); - - return 1; -} - -static int -_ecore_evas_win32_event_mouse_in(void *data __UNUSED__, int type __UNUSED__, void *event) -{ - Ecore_Evas *ee; - Ecore_Win32_Event_Mouse_In *e; - - e = event; - ee = _ecore_evas_win32_match(e->window); - if ((!ee) || (ee->ignore_events)) return 1; /* pass on event */ - if (e->window != ee->engine.win32.window) return 1; - - if (ee->func.fn_mouse_in) ee->func.fn_mouse_in(ee); - /* FIXME to do */ -/* _ecore_evas_x_modifier_locks_update(ee, e->modifiers); */ - evas_event_feed_mouse_in(ee->evas, e->time, NULL); - _ecore_evas_win32_mouse_move_process(ee, e->x, e->y, e->time); - - return 1; -} - -static int -_ecore_evas_win32_event_mouse_out(void *data __UNUSED__, int type __UNUSED__, void *event) -{ - Ecore_Evas *ee; - Ecore_Win32_Event_Mouse_Out *e; - - e = event; - ee = _ecore_evas_win32_match(e->window); - if ((!ee) || (ee->ignore_events)) return 1; /* pass on event */ - if (e->window != ee->engine.win32.window) return 1; - - /* FIXME to do */ -/* _ecore_evas_x_modifier_locks_update(ee, e->modifiers); */ - _ecore_evas_win32_mouse_move_process(ee, e->x, e->y, e->time); - - evas_event_feed_mouse_out(ee->evas, e->time, NULL); - if (ee->func.fn_mouse_out) ee->func.fn_mouse_out(ee); - if (ee->prop.cursor.object) evas_object_hide(ee->prop.cursor.object); - - return 1; -} - -static int -_ecore_evas_win32_event_window_damage(void *data __UNUSED__, int type __UNUSED__, void *event) -{ - Ecore_Evas *ee; - Ecore_Win32_Event_Window_Damage *e; - - e = event; - ee = _ecore_evas_win32_match(e->window); - if (!ee) return 1; /* pass on event */ - if (e->window != ee->engine.win32.window) return 1; - - if (ee->prop.avoid_damage) - { -#warning [ECORE] [WIN32] No Region code - } - else - { - if (ee->rotation == 0) - evas_damage_rectangle_add(ee->evas, - e->x, - e->y, - e->width, - e->height); - else if (ee->rotation == 90) - evas_damage_rectangle_add(ee->evas, - ee->h - e->y - e->height, - e->x, - e->height, - e->width); - else if (ee->rotation == 180) - evas_damage_rectangle_add(ee->evas, - ee->w - e->x - e->width, - ee->h - e->y - e->height, - e->width, - e->height); - else if (ee->rotation == 270) - evas_damage_rectangle_add(ee->evas, - e->y, - ee->w - e->x - e->width, - e->height, - e->width); - } - - return 1; -} - -static int -_ecore_evas_win32_event_window_destroy(void *data __UNUSED__, int type __UNUSED__, void *event) -{ - Ecore_Evas *ee; - Ecore_Win32_Event_Window_Destroy *e; - - e = event; - ee = _ecore_evas_win32_match(e->window); - if (!ee) return 1; /* pass on event */ - if (e->window != ee->engine.win32.window) return 1; - if (ee->func.fn_destroy) ee->func.fn_destroy(ee); - ecore_evas_free(ee); - - printf (" * ee event destroy\n"); - return 1; -} - -static int -_ecore_evas_win32_event_window_show(void *data __UNUSED__, int type __UNUSED__, void *event) -{ - Ecore_Evas *ee; - Ecore_Win32_Event_Window_Show *e; - - printf (" * ee window event show\n"); - e = event; - ee = _ecore_evas_win32_match(e->window); - if (!ee) return 1; /* pass on event */ - if (e->window != ee->engine.win32.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); - - return 1; -} - -static int -_ecore_evas_win32_event_window_hide(void *data __UNUSED__, int type __UNUSED__, void *event) -{ - Ecore_Evas *ee; - Ecore_Win32_Event_Window_Hide *e; - - e = event; - ee = _ecore_evas_win32_match(e->window); - if (!ee) return 1; /* pass on event */ - if (e->window != ee->engine.win32.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); - - return 1; -} - -static int -_ecore_evas_win32_event_window_delete(void *data __UNUSED__, int type __UNUSED__, void *event) -{ - Ecore_Evas *ee; - Ecore_Win32_Event_Window_Delete *e; - - e = event; - ee = _ecore_evas_win32_match(e->window); - if (!ee) return 1; /* pass on event */ - if (e->window != ee->engine.win32.window) return 1; - if (ee->func.fn_delete_request) ee->func.fn_delete_request(ee); - - printf (" * ee event delete\n"); - return 1; -} - - -/* Ecore_Evas interface */ - -static void -_ecore_evas_win32_free(Ecore_Evas *ee) -{ - ecore_win32_window_del(ee->engine.win32.window); - ecore_evases_hash = evas_hash_del(ecore_evases_hash, _ecore_evas_win32_winid_str_get(ee->engine.win32.window), ee); - ecore_evases = _ecore_list2_remove(ecore_evases, ee); - _ecore_evas_win32_shutdown(); - ecore_win32_shutdown(); -} - -static void -_ecore_evas_win32_callback_delete_request_set(Ecore_Evas *ee, - void (*func) (Ecore_Evas *ee)) -{ - ee->func.fn_delete_request = func; -} - -static void -_ecore_evas_win32_move(Ecore_Evas *ee, int x, int y) -{ - if ((x != ee->x) || (y != ee->y)) - { - ee->x = x; - ee->y = y; - ecore_win32_window_move(ee->engine.win32.window, x, y); - if (ee->func.fn_move) ee->func.fn_move(ee); - } -} - -static void -_ecore_evas_win32_resize(Ecore_Evas *ee, int width, int height) -{ - if ((ee->w != width) || (ee->h != height)) - { - ee->w = width; - ee->h = height; - ecore_win32_window_resize(ee->engine.win32.window, width, height); - if ((ee->rotation == 90) || (ee->rotation == 270)) - { - evas_output_size_set(ee->evas, ee->h, ee->w); - evas_output_viewport_set(ee->evas, 0, 0, ee->h, ee->w); - } - else - { - evas_output_size_set(ee->evas, ee->w, ee->h); - evas_output_viewport_set(ee->evas, 0, 0, ee->w, ee->h); - } - /* FIXME: damage and shape */ - - if (ee->func.fn_resize) ee->func.fn_resize(ee); - } -} - -static void -_ecore_evas_win32_move_resize(Ecore_Evas *ee, int x, int y, int width, int height) -{ - if ((ee->w != width) || (ee->h != height) || (x != ee->x) || (y != ee->y)) - { - int change_size = 0; - int change_pos = 0; - - if ((ee->w != width) || (ee->h != height)) change_size = 1; - if ((x != ee->x) || (y != ee->y)) change_pos = 1; - - ee->x = x; - ee->y = y; - ee->w = width; - ee->h = height; - ecore_win32_window_move_resize(ee->engine.win32.window, x, y, width, height); - if ((ee->rotation == 90) || (ee->rotation == 270)) - { - evas_output_size_set(ee->evas, ee->h, ee->w); - evas_output_viewport_set(ee->evas, 0, 0, ee->h, ee->w); - } - else - { - evas_output_size_set(ee->evas, ee->w, ee->h); - evas_output_viewport_set(ee->evas, 0, 0, ee->w, ee->h); - } - /* FIXME: damage and shape */ - if (change_pos) - { - if (ee->func.fn_move) ee->func.fn_move(ee); - } - if (change_size) - { - if (ee->func.fn_resize) ee->func.fn_resize(ee); - } - } -} - -static void -_ecore_evas_win32_rotation_set(Ecore_Evas *ee, int rotation) -{ - int rot_dif; - - if (ee->rotation == rotation) return; - rot_dif = ee->rotation - rotation; - if (rot_dif < 0) rot_dif = -rot_dif; - if (!strcmp(ee->driver, "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->engine.win32.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->engine.win32.window, &w, &h); - ecore_win32_window_resize(ee->engine.win32.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_win32_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_win32_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); - } -} - -static void -_ecore_evas_win32_show(Ecore_Evas *ee) -{ - printf (" * ee window show\n"); - ee->should_be_visible = 1; - if (ee->prop.avoid_damage) - _ecore_evas_win32_render(ee); - ecore_win32_window_show(ee->engine.win32.window); -/* if (ee->prop.fullscreen) */ -/* ecore_win32_window_focus(ee->engine.win32.window); */ -} - -static void -_ecore_evas_win32_hide(Ecore_Evas *ee) -{ - ecore_win32_window_hide(ee->engine.win32.window); - ee->should_be_visible = 0; -} - -static void -_ecore_evas_win32_raise(Ecore_Evas *ee) -{ - if (!ee->prop.fullscreen) - ecore_win32_window_raise(ee->engine.win32.window); - else - ecore_win32_window_raise(ee->engine.win32.window); -} - -static void -_ecore_evas_win32_lower(Ecore_Evas *ee) -{ - if (!ee->prop.fullscreen) - ecore_win32_window_lower(ee->engine.win32.window); - else - ecore_win32_window_lower(ee->engine.win32.window); -} - -static void -_ecore_evas_win32_title_set(Ecore_Evas *ee, const char *title) -{ - if (ee->prop.title) free(ee->prop.title); - ee->prop.title = NULL; - if (title) ee->prop.title = strdup(title); - ecore_win32_window_title_set(ee->engine.win32.window, ee->prop.title); -} - -static void -_ecore_evas_win32_size_min_set(Ecore_Evas *ee, int width, int height) -{ - if (width < 0) width = 0; - if (height < 0) height = 0; - if ((ee->prop.min.w == width) && (ee->prop.min.h == height)) return; - ee->prop.min.w = width; - ee->prop.min.h = height; - ecore_win32_window_size_min_set(ee->engine.win32.window, width, height); -} - -static void -_ecore_evas_win32_size_max_set(Ecore_Evas *ee, int width, int height) -{ - if (width < 0) width = 0; - if (height < 0) height = 0; - if ((ee->prop.max.w == width) && (ee->prop.max.h == height)) return; - ee->prop.max.w = width; - ee->prop.max.h = height; - ecore_win32_window_size_max_set(ee->engine.win32.window, width, height); -} - -static void -_ecore_evas_win32_size_base_set(Ecore_Evas *ee, int width, int height) -{ - if (width < 0) width = 0; - if (height < 0) height = 0; - if ((ee->prop.base.w == width) && (ee->prop.base.h == height)) return; - ee->prop.base.w = width; - ee->prop.base.h = height; - ecore_win32_window_size_base_set(ee->engine.win32.window, width, height); -} - -static void -_ecore_evas_win32_size_step_set(Ecore_Evas *ee, int width, int height) -{ - if (width < 1) width = 1; - if (height < 1) height = 1; - if ((ee->prop.step.w == width) && (ee->prop.step.h == height)) return; - ee->prop.step.w = width; - ee->prop.step.h = height; - ecore_win32_window_size_step_set(ee->engine.win32.window, width, height); -} - -static void -_ecore_evas_win32_focus_set(Ecore_Evas *ee, int on __UNUSED__) -{ - ecore_win32_window_focus_set(ee->engine.win32.window); -} - -static void -_ecore_evas_win32_iconified_set(Ecore_Evas *ee, int on) -{ -/* if (((ee->prop.borderless) && (on)) || */ -/* ((!ee->prop.borderless) && (!on))) return; */ - ee->prop.iconified = on; - ecore_win32_window_iconified_set(ee->engine.win32.window, ee->prop.iconified); -} - -static void -_ecore_evas_win32_borderless_set(Ecore_Evas *ee, int on) -{ - if (((ee->prop.borderless) && (on)) || - ((!ee->prop.borderless) && (!on))) return; - ee->prop.borderless = on; - ecore_win32_window_borderless_set(ee->engine.win32.window, ee->prop.borderless); -} - - -static const Ecore_Evas_Engine_Func _ecore_win32_engine_func = -{ - _ecore_evas_win32_free, - NULL, - NULL, - NULL, - NULL, - _ecore_evas_win32_callback_delete_request_set, - NULL, - NULL, - NULL, - NULL, - NULL, - NULL, - NULL, - NULL, - NULL, - _ecore_evas_win32_move, - NULL, - _ecore_evas_win32_resize, - _ecore_evas_win32_move_resize, - _ecore_evas_win32_rotation_set, - NULL, /* _ecore_evas_x_shaped_set */ - _ecore_evas_win32_show, - _ecore_evas_win32_hide, - _ecore_evas_win32_raise, - _ecore_evas_win32_lower, - _ecore_evas_win32_title_set, - NULL, /* _ecore_evas_x_name_class_set */ - _ecore_evas_win32_size_min_set, - _ecore_evas_win32_size_max_set, - _ecore_evas_win32_size_base_set, - _ecore_evas_win32_size_step_set, - NULL, /* _ecore_evas_x_cursor_set */ - NULL, /* _ecore_evas_x_layer_set */ - _ecore_evas_win32_focus_set, - _ecore_evas_win32_iconified_set, - _ecore_evas_win32_borderless_set, - NULL, /* _ecore_evas_x_override_set */ - NULL, - NULL, /* _ecore_evas_x_fullscreen_set */ - NULL, /* _ecore_evas_x_avoid_damage_set */ - 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 */ -}; - -#endif /* BUILD_ECORE_WIN32 */ - -/* API */ - -EAPI Ecore_Evas * -ecore_evas_software_ddraw_new(Ecore_Win32_Window *parent, - int x, - int y, - int width, - int height) -{ -#ifdef BUILD_ECORE_WIN32 - Evas_Engine_Info_Software_DDraw *einfo; - Ecore_Evas *ee; - int rmethod; - - rmethod = evas_render_method_lookup("software_ddraw"); - if (!rmethod) - return NULL; - - if (!ecore_win32_init()) - return NULL; - - ee = calloc(1, sizeof(Ecore_Evas)); - if (!ee) - return NULL; - - ECORE_MAGIC_SET(ee, ECORE_MAGIC_EVAS); - - _ecore_evas_win32_init(); - - ee->engine.func = (Ecore_Evas_Engine_Func *)&_ecore_win32_engine_func; - - ee->driver = "software_ddraw"; - - if (width < 1) width = 1; - if (height < 1) height = 1; - ee->x = x; - ee->y = y; - ee->w = width; - ee->h = height; - - ee->prop.max.w = 32767; - ee->prop.max.h = 32767; - ee->prop.layer = 4; - ee->prop.request_pos = 0; - ee->prop.sticky = 0; - /* FIXME: sticky to add */ - - /* init evas here */ - ee->evas = evas_new(); - evas_data_attach_set(ee->evas, ee); - evas_output_method_set(ee->evas, rmethod); - evas_output_size_set(ee->evas, width, height); - evas_output_viewport_set(ee->evas, 0, 0, width, height); - - ee->engine.win32.parent = parent; - ee->engine.win32.window = ecore_win32_window_new(parent, x, y, width, height); - if (!ee->engine.win32.window) - { - _ecore_evas_win32_shutdown(); - free(ee); - return NULL; - } - - if (!ecore_win32_ddraw_init(ee->engine.win32.window)) - { - ecore_win32_window_del(ee->engine.win32.window); - _ecore_evas_win32_shutdown(); - free(ee); - return NULL; - } - - einfo = (Evas_Engine_Info_Software_DDraw *)evas_engine_info_get(ee->evas); - if (einfo) - { - /* FIXME: REDRAW_DEBUG missing for now */ - einfo->info.window = ((struct _Ecore_Win32_Window *)ee->engine.win32.window)->window; - einfo->info.object = ecore_win32_ddraw_object_get(ee->engine.win32.window); - einfo->info.surface_primary = ecore_win32_ddraw_surface_primary_get(ee->engine.win32.window); - einfo->info.surface_back = ecore_win32_ddraw_surface_back_get(ee->engine.win32.window); - einfo->info.depth = ecore_win32_ddraw_depth_get(ee->engine.win32.window); - einfo->info.rotation = 0; - evas_engine_info_set(ee->evas, (Evas_Engine_Info *)einfo); - } - - 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); - ecore_evases_hash = evas_hash_add(ecore_evases_hash, _ecore_evas_win32_winid_str_get(ee->engine.win32.window), ee); - - return ee; -#else - return NULL; - parent = NULL; - x = 0; - y = 0; - width = 0; - height = 0; -#endif /* BUILD_ECORE_WIN32 */ -} - -EAPI Ecore_Evas * -ecore_evas_direct3d_new(Ecore_Win32_Window *parent, - int x, - int y, - int width, - int height) -{ -#ifdef BUILD_ECORE_WIN32 - Evas_Engine_Info_Direct3D *einfo; - Ecore_Evas *ee; - int rmethod; - - rmethod = evas_render_method_lookup("direct3d"); - if (!rmethod) - return NULL; - - if (!ecore_win32_init()) - return NULL; - - ee = calloc(1, sizeof(Ecore_Evas)); - if (!ee) - return NULL; - - ECORE_MAGIC_SET(ee, ECORE_MAGIC_EVAS); - - _ecore_evas_win32_init(); - - ee->engine.func = (Ecore_Evas_Engine_Func *)&_ecore_win32_engine_func; - - ee->driver = "direct3d"; - - if (width < 1) width = 1; - if (height < 1) height = 1; - ee->x = x; - ee->y = y; - ee->w = width; - ee->h = height; - - ee->prop.max.w = 32767; - ee->prop.max.h = 32767; - ee->prop.layer = 4; - ee->prop.request_pos = 0; - ee->prop.sticky = 0; - /* FIXME: sticky to add */ - - /* init evas here */ - ee->evas = evas_new(); - evas_data_attach_set(ee->evas, ee); - evas_output_method_set(ee->evas, rmethod); - evas_output_size_set(ee->evas, width, height); - evas_output_viewport_set(ee->evas, 0, 0, width, height); - - ee->engine.win32.parent = parent; - ee->engine.win32.window = ecore_win32_window_new(parent, x, y, width, height); - if (!ee->engine.win32.window) - { - _ecore_evas_win32_shutdown(); - free(ee); - return NULL; - } - - if (!ecore_win32_direct3d_init(ee->engine.win32.window)) - { - ecore_win32_window_del(ee->engine.win32.window); - _ecore_evas_win32_shutdown(); - free(ee); - return NULL; - } - - einfo = (Evas_Engine_Info_Direct3D *)evas_engine_info_get(ee->evas); - if (einfo) - { - /* FIXME: REDRAW_DEBUG missing for now */ - einfo->info.window = ((struct _Ecore_Win32_Window *)ee->engine.win32.window)->window; - einfo->info.object = ecore_win32_direct3d_object_get(ee->engine.win32.window); - einfo->info.device = ecore_win32_direct3d_device_get(ee->engine.win32.window); - einfo->info.sprite = ecore_win32_direct3d_sprite_get(ee->engine.win32.window); - einfo->info.texture = ecore_win32_direct3d_texture_get(ee->engine.win32.window); - einfo->info.depth = ecore_win32_direct3d_depth_get(ee->engine.win32.window); - einfo->info.rotation = 0; - evas_engine_info_set(ee->evas, (Evas_Engine_Info *)einfo); - } - - 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); - ecore_evases_hash = evas_hash_add(ecore_evases_hash, _ecore_evas_win32_winid_str_get(ee->engine.win32.window), ee); - - return ee; -#else - return NULL; - parent = NULL; - x = 0; - y = 0; - width = 0; - height = 0; -#endif /* BUILD_ECORE_WIN32 */ -} +/* + * vim:ts=8:sw=3:sts=8:noexpandtab:cino=>5n-3f0^-2{2 + */ + +#include <stdlib.h> /* for NULL */ + +#include "config.h" +#include "Ecore.h" +#include "ecore_private.h" +#include "ecore_evas_private.h" +#include "Ecore_Evas.h" +#ifdef BUILD_ECORE_WIN32 +# include "Ecore_Win32.h" +# include "ecore_win32_private.h" +#endif /* BUILD_ECORE_WIN32 */ + + +#ifdef BUILD_ECORE_WIN32 + +#define ECORE_EVAS_EVENT_COUNT 14 + +static int _ecore_evas_init_count = 0; +static int _ecore_evas_fps_debug = 0; + +static Ecore_Event_Handler *ecore_evas_event_handlers[ECORE_EVAS_EVENT_COUNT]; +static Ecore_Idle_Enterer *ecore_evas_idle_enterer = NULL; +static Ecore_Evas *ecore_evases = NULL; +static Evas_Hash *ecore_evases_hash = NULL; + +static int _ecore_evas_win32_event_key_down(void *data __UNUSED__, int type __UNUSED__, void *event); + +static int _ecore_evas_win32_event_key_up(void *data __UNUSED__, int type __UNUSED__, void *event); + +static int _ecore_evas_win32_event_mouse_button_down(void *data __UNUSED__, int type __UNUSED__, void *event); + +static int _ecore_evas_win32_event_mouse_button_up(void *data __UNUSED__, int type __UNUSED__, void *event); + +static int _ecore_evas_win32_event_mouse_wheel(void *data __UNUSED__, int type __UNUSED__, void *event); + +static int _ecore_evas_win32_event_mouse_move(void *data __UNUSED__, int type __UNUSED__, void *event); + +static int _ecore_evas_win32_event_mouse_in(void *data __UNUSED__, int type __UNUSED__, void *event); + +static int _ecore_evas_win32_event_mouse_out(void *data __UNUSED__, int type __UNUSED__, void *event); + +static int _ecore_evas_win32_event_window_damage(void *data __UNUSED__, int type __UNUSED__, void *event); + +static int _ecore_evas_win32_event_window_destroy(void *data __UNUSED__, int type __UNUSED__, void *event); + +static int _ecore_evas_win32_event_window_show(void *data __UNUSED__, int type __UNUSED__, void *event); + +static int _ecore_evas_win32_event_window_hide(void *data __UNUSED__, int type __UNUSED__, void *event); + +static int _ecore_evas_win32_event_window_configure(void *data __UNUSED__, int type __UNUSED__, void *event); + +static int _ecore_evas_win32_event_window_delete_request(void *data __UNUSED__, int type __UNUSED__, void *event); + +/* Private functions */ + +static void +_ecore_evas_win32_render(Ecore_Evas *ee) +{ +#ifdef BUILD_ECORE_EVAS_BUFFER + Evas_List *ll; +#endif + +#ifdef BUILD_ECORE_EVAS_BUFFER + for (ll = ee->sub_ecore_evas; ll; ll = ll->next) + { + Ecore_Evas *ee2; + + ee2 = ll->data; + 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 (ee->prop.avoid_damage) + { + Evas_List *updates; + + updates = evas_render_updates(ee->evas); + if (updates) evas_render_updates_free(updates); + } + else if ((ee->visible) || + ((ee->should_be_visible) && (ee->prop.fullscreen)) || + ((ee->should_be_visible) && (ee->prop.override))) + { + if (ee->shaped) + { + Evas_List *updates; + + updates = evas_render_updates(ee->evas); + if (updates) evas_render_updates_free(updates); + } + else + { + Evas_List *updates; + + updates = evas_render_updates(ee->evas); + if (updates) evas_render_updates_free(updates); + } + } + else + evas_norender(ee->evas); + if (ee->func.fn_post_render) ee->func.fn_post_render(ee); +} + +static int +_ecore_evas_win32_idle_enter(void *data __UNUSED__) +{ + Ecore_List2 *l; + double t1 = 0.0; + double t2 = 0.0; + + if (_ecore_evas_fps_debug) + { + t1 = ecore_time_get(); + } + for (l = (Ecore_List2 *)ecore_evases; l; l = l->next) + { + Ecore_Evas *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); */ + } + return 1; +} + +static int +_ecore_evas_win32_init(void) +{ + _ecore_evas_init_count++; + if (_ecore_evas_init_count > 1) + return _ecore_evas_init_count; + + if (getenv("ECORE_EVAS_FPS_DEBUG")) + _ecore_evas_fps_debug = 1; + + ecore_evas_idle_enterer = ecore_idle_enterer_add(_ecore_evas_win32_idle_enter, NULL); + + ecore_evas_event_handlers[0] = ecore_event_handler_add(ECORE_WIN32_EVENT_KEY_DOWN, _ecore_evas_win32_event_key_down, NULL); + ecore_evas_event_handlers[1] = ecore_event_handler_add(ECORE_WIN32_EVENT_KEY_UP, _ecore_evas_win32_event_key_up, NULL); + ecore_evas_event_handlers[2] = ecore_event_handler_add(ECORE_WIN32_EVENT_MOUSE_BUTTON_DOWN, _ecore_evas_win32_event_mouse_button_down, NULL); + ecore_evas_event_handlers[3] = ecore_event_handler_add(ECORE_WIN32_EVENT_MOUSE_BUTTON_UP, _ecore_evas_win32_event_mouse_button_up, NULL); + ecore_evas_event_handlers[4] = ecore_event_handler_add(ECORE_WIN32_EVENT_MOUSE_WHEEL, _ecore_evas_win32_event_mouse_wheel, NULL); + ecore_evas_event_handlers[5] = ecore_event_handler_add(ECORE_WIN32_EVENT_MOUSE_MOVE, _ecore_evas_win32_event_mouse_move, NULL); + ecore_evas_event_handlers[6] = ecore_event_handler_add(ECORE_WIN32_EVENT_MOUSE_IN, _ecore_evas_win32_event_mouse_in, NULL); + ecore_evas_event_handlers[7] = ecore_event_handler_add(ECORE_WIN32_EVENT_MOUSE_OUT, _ecore_evas_win32_event_mouse_out, NULL); + ecore_evas_event_handlers[8] = ecore_event_handler_add(ECORE_WIN32_EVENT_WINDOW_DAMAGE, _ecore_evas_win32_event_window_damage, NULL); + ecore_evas_event_handlers[9] = ecore_event_handler_add(ECORE_WIN32_EVENT_WINDOW_DESTROY, _ecore_evas_win32_event_window_destroy, NULL); + ecore_evas_event_handlers[10] = ecore_event_handler_add(ECORE_WIN32_EVENT_WINDOW_SHOW, _ecore_evas_win32_event_window_show, NULL); + ecore_evas_event_handlers[11] = ecore_event_handler_add(ECORE_WIN32_EVENT_WINDOW_HIDE, _ecore_evas_win32_event_window_hide, NULL); + ecore_evas_event_handlers[12] = ecore_event_handler_add(ECORE_WIN32_EVENT_WINDOW_CONFIGURE, _ecore_evas_win32_event_window_configure, NULL); + ecore_evas_event_handlers[13] = ecore_event_handler_add(ECORE_WIN32_EVENT_WINDOW_DELETE_REQUEST, _ecore_evas_win32_event_window_delete_request, NULL); + + return _ecore_evas_init_count; +} + +int +_ecore_evas_win32_shutdown(void) +{ + _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; + } + + if (_ecore_evas_init_count < 0) _ecore_evas_init_count = 0; + + return _ecore_evas_init_count; +} + +static char * +_ecore_evas_win32_winid_str_get(Ecore_Win32_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_win32_match(Ecore_Win32_Window *window) +{ + Ecore_Evas *ee; + + ee = evas_hash_find(ecore_evases_hash, _ecore_evas_win32_winid_str_get(window)); + + return ee; +} + +static int +_ecore_evas_win32_event_key_down(void *data __UNUSED__, int type __UNUSED__, void *event) +{ + Ecore_Evas *ee; + Ecore_Win32_Event_Key_Down *e; + + e = event; + ee = _ecore_evas_win32_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_win32_event_key_up(void *data __UNUSED__, int type __UNUSED__, void *event) +{ + Ecore_Evas *ee; + Ecore_Win32_Event_Key_Up *e; + + e = event; + ee = _ecore_evas_win32_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_win32_event_mouse_button_down(void *data __UNUSED__, int type __UNUSED__, void *event) +{ + Ecore_Evas *ee; + Ecore_Win32_Event_Mouse_Button_Down *e; + Evas_Button_Flags flags = EVAS_BUTTON_NONE; + + e = event; + ee = _ecore_evas_win32_match(e->window); + if ((!ee) || (ee->ignore_events)) return 1; /* pass on event */ + if (e->window != ee->engine.win32.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); + + printf (" * ee event button down %f %d %d\n", e->time, e->x, e->y); + + return 1; +} + +static int +_ecore_evas_win32_event_mouse_button_up(void *data __UNUSED__, int type __UNUSED__, void *event) +{ + Ecore_Evas *ee; + Ecore_Win32_Event_Mouse_Button_Up *e; + Evas_Button_Flags flags = EVAS_BUTTON_NONE; + + e = event; + ee = _ecore_evas_win32_match(e->window); + if ((!ee) || (ee->ignore_events)) return 1; /* pass on event */ + if (e->window != ee->engine.win32.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); + + printf (" * ee event button up\n"); + + return 1; +} + +static int +_ecore_evas_win32_event_mouse_wheel(void *data __UNUSED__, int type __UNUSED__, void *event) +{ + Ecore_Evas *ee; + Ecore_Win32_Event_Mouse_Wheel *e; + + e = event; + ee = _ecore_evas_win32_match(e->window); + if ((!ee) || (ee->ignore_events)) return 1; /* pass on event */ + if (e->window != ee->engine.win32.window) return 1; + /* FIXME to do */ +/* _ecore_evas_x_modifier_locks_update(ee, e->modifiers); */ + evas_event_feed_mouse_wheel(ee->evas, e->direction, e->z, e->time, NULL); + + return 1; +} + +static void +_ecore_evas_win32_mouse_move_process(Ecore_Evas *ee, int x, int y, unsigned int timestamp) +{ + ee->mouse.x = x; + ee->mouse.y = y; + if (ee->prop.cursor.object) + { + evas_object_show(ee->prop.cursor.object); + if (ee->rotation == 0) + evas_object_move(ee->prop.cursor.object, + x - ee->prop.cursor.hot.x, + y - ee->prop.cursor.hot.y); + else if (ee->rotation == 90) + evas_object_move(ee->prop.cursor.object, + ee->h - y - 1 - ee->prop.cursor.hot.x, + x - ee->prop.cursor.hot.y); + else if (ee->rotation == 180) + evas_object_move(ee->prop.cursor.object, + ee->w - x - 1 - ee->prop.cursor.hot.x, + ee->h - y - 1 - ee->prop.cursor.hot.y); + else if (ee->rotation == 270) + evas_object_move(ee->prop.cursor.object, + y - ee->prop.cursor.hot.x, + ee->w - x - 1 - ee->prop.cursor.hot.y); + } + if (ee->rotation == 0) + evas_event_feed_mouse_move(ee->evas, x, y, timestamp, NULL); + else if (ee->rotation == 90) + evas_event_feed_mouse_move(ee->evas, ee->h - y - 1, x, timestamp, NULL); + else if (ee->rotation == 180) + evas_event_feed_mouse_move(ee->evas, ee->w - x - 1, ee->h - y - 1, timestamp, NULL); + else if (ee->rotation == 270) + evas_event_feed_mouse_move(ee->evas, y, ee->w - x - 1, timestamp, NULL); +} + +static int +_ecore_evas_win32_event_mouse_move(void *data __UNUSED__, int type __UNUSED__, void *event) +{ + Ecore_Evas *ee; + Ecore_Win32_Event_Mouse_Move *e; + + e = event; + ee = _ecore_evas_win32_match(e->window); + if ((!ee) || (ee->ignore_events)) return 1; /* pass on event */ + if (e->window != ee->engine.win32.window) return 1; + /* FIXME to do */ +/* _ecore_evas_x_modifier_locks_update(ee, e->modifiers); */ + _ecore_evas_win32_mouse_move_process(ee, e->x, e->y, e->time); + + return 1; +} + +static int +_ecore_evas_win32_event_mouse_in(void *data __UNUSED__, int type __UNUSED__, void *event) +{ + Ecore_Evas *ee; + Ecore_Win32_Event_Mouse_In *e; + + e = event; + ee = _ecore_evas_win32_match(e->window); + if ((!ee) || (ee->ignore_events)) return 1; /* pass on event */ + if (e->window != ee->engine.win32.window) return 1; + + if (ee->func.fn_mouse_in) ee->func.fn_mouse_in(ee); + /* FIXME to do */ +/* _ecore_evas_x_modifier_locks_update(ee, e->modifiers); */ + evas_event_feed_mouse_in(ee->evas, e->time, NULL); + _ecore_evas_win32_mouse_move_process(ee, e->x, e->y, e->time); + + return 1; +} + +static int +_ecore_evas_win32_event_mouse_out(void *data __UNUSED__, int type __UNUSED__, void *event) +{ + Ecore_Evas *ee; + Ecore_Win32_Event_Mouse_Out *e; + + e = event; + ee = _ecore_evas_win32_match(e->window); + if ((!ee) || (ee->ignore_events)) return 1; /* pass on event */ + if (e->window != ee->engine.win32.window) return 1; + + /* FIXME to do */ +/* _ecore_evas_x_modifier_locks_update(ee, e->modifiers); */ + _ecore_evas_win32_mouse_move_process(ee, e->x, e->y, e->time); + + evas_event_feed_mouse_out(ee->evas, e->time, NULL); + if (ee->func.fn_mouse_out) ee->func.fn_mouse_out(ee); + if (ee->prop.cursor.object) evas_object_hide(ee->prop.cursor.object); + + return 1; +} + +static int +_ecore_evas_win32_event_window_damage(void *data __UNUSED__, int type __UNUSED__, void *event) +{ + Ecore_Evas *ee; + Ecore_Win32_Event_Window_Damage *e; + + e = event; + ee = _ecore_evas_win32_match(e->window); + if (!ee) return 1; /* pass on event */ + if (e->window != ee->engine.win32.window) return 1; + + if (ee->prop.avoid_damage) + { +#warning [ECORE] [WIN32] No Region code + } + else + { + printf (" * ee window event damage\n"); + if (ee->rotation == 0) + evas_damage_rectangle_add(ee->evas, + e->x, + e->y, + e->width, + e->height); + else if (ee->rotation == 90) + evas_damage_rectangle_add(ee->evas, + ee->h - e->y - e->height, + e->x, + e->height, + e->width); + else if (ee->rotation == 180) + evas_damage_rectangle_add(ee->evas, + ee->w - e->x - e->width, + ee->h - e->y - e->height, + e->width, + e->height); + else if (ee->rotation == 270) + evas_damage_rectangle_add(ee->evas, + e->y, + ee->w - e->x - e->width, + e->height, + e->width); + } + + return 1; +} + +static int +_ecore_evas_win32_event_window_destroy(void *data __UNUSED__, int type __UNUSED__, void *event) +{ + Ecore_Evas *ee; + Ecore_Win32_Event_Window_Destroy *e; + + e = event; + ee = _ecore_evas_win32_match(e->window); + if (!ee) return 1; /* pass on event */ + if (e->window != ee->engine.win32.window) return 1; + if (ee->func.fn_destroy) ee->func.fn_destroy(ee); + ecore_evas_free(ee); + + printf (" * ee event destroy\n"); + return 1; +} + +static int +_ecore_evas_win32_event_window_show(void *data __UNUSED__, int type __UNUSED__, void *event) +{ + Ecore_Evas *ee; + Ecore_Win32_Event_Window_Show *e; + + printf (" * ee window event show\n"); + e = event; + ee = _ecore_evas_win32_match(e->window); + if (!ee) return 1; /* pass on event */ + if (e->window != ee->engine.win32.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); + + return 1; +} + +static int +_ecore_evas_win32_event_window_hide(void *data __UNUSED__, int type __UNUSED__, void *event) +{ + Ecore_Evas *ee; + Ecore_Win32_Event_Window_Hide *e; + + e = event; + ee = _ecore_evas_win32_match(e->window); + if (!ee) return 1; /* pass on event */ + if (e->window != ee->engine.win32.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); + + return 1; +} + +static int +_ecore_evas_win32_event_window_configure(void *data __UNUSED__, int type __UNUSED__, void *event) +{ + Ecore_Evas *ee; + Ecore_Win32_Event_Window_Configure *e; + + e = event; + ee = _ecore_evas_win32_match(e->window); + if (!ee) return 1; /* pass on event */ + if (e->window != ee->engine.win32.window) return 1; + + if ((ee->x != e->x) || (ee->y != e->y)) + { + ee->x = e->x; + ee->y = e->y; + if (ee->func.fn_move) ee->func.fn_move(ee); + } + + if ((ee->w != e->width) || (ee->h != e->height)) + { + printf (" * ee resize : 1\n"); + ee->w = e->width; + ee->h = e->height; + if ((ee->rotation == 90) || (ee->rotation == 270)) + { + evas_output_size_set(ee->evas, ee->h, ee->w); + evas_output_viewport_set(ee->evas, 0, 0, ee->h, ee->w); + } + else + { + printf (" * ee resize : 2\n"); + evas_output_size_set(ee->evas, ee->w, ee->h); + evas_output_viewport_set(ee->evas, 0, 0, ee->w, ee->h); + } + if (ee->prop.avoid_damage) + { + ecore_evas_avoid_damage_set(ee, 0); + ecore_evas_avoid_damage_set(ee, 1); + } + /* FIXME: to do... */ +/* if (ee->shaped) */ +/* _ecore_evas_x_resize_shape(ee); */ + if ((ee->expecting_resize.w > 0) && + (ee->expecting_resize.h > 0)) + { + printf (" * ee resize : 3\n"); + if ((ee->expecting_resize.w == ee->w) && + (ee->expecting_resize.h == ee->h)) + _ecore_evas_win32_mouse_move_process(ee, ee->mouse.x, ee->mouse.y, + ecore_win32_current_time_get()); + ee->expecting_resize.w = 0; + ee->expecting_resize.h = 0; + } + printf (" * ee resize : 4\n"); + if (ee->func.fn_resize) ee->func.fn_resize(ee); + } + + return 1; +} + +static int +_ecore_evas_win32_event_window_delete_request(void *data __UNUSED__, int type __UNUSED__, void *event) +{ + Ecore_Evas *ee; + Ecore_Win32_Event_Window_Delete_Request *e; + + e = event; + ee = _ecore_evas_win32_match(e->window); + if (!ee) return 1; /* pass on event */ + if (e->window != ee->engine.win32.window) return 1; + if (ee->func.fn_delete_request) ee->func.fn_delete_request(ee); + + printf (" * ee event delete\n"); + return 1; +} + + +/* Ecore_Evas interface */ + +static void +_ecore_evas_win32_free(Ecore_Evas *ee) +{ + ecore_win32_window_del(ee->engine.win32.window); + ecore_evases_hash = evas_hash_del(ecore_evases_hash, _ecore_evas_win32_winid_str_get(ee->engine.win32.window), ee); + ecore_evases = _ecore_list2_remove(ecore_evases, ee); + _ecore_evas_win32_shutdown(); + ecore_win32_shutdown(); +} + +static void +_ecore_evas_win32_callback_delete_request_set(Ecore_Evas *ee, + void (*func) (Ecore_Evas *ee)) +{ + ee->func.fn_delete_request = func; +} + +static void +_ecore_evas_win32_move(Ecore_Evas *ee, int x, int y) +{ + if ((x != ee->x) || (y != ee->y)) + { + ee->x = x; + ee->y = y; + ecore_win32_window_move(ee->engine.win32.window, x, y); + if (ee->func.fn_move) ee->func.fn_move(ee); + } +} + +static void +_ecore_evas_win32_resize(Ecore_Evas *ee, int width, int height) +{ + printf (" * _ecore_evas_win32_resize %d %d\n", width, height); + if ((ee->w != width) || (ee->h != height)) + { + ee->w = width; + ee->h = height; + ecore_win32_window_resize(ee->engine.win32.window, width, height); + if ((ee->rotation == 90) || (ee->rotation == 270)) + { + evas_output_size_set(ee->evas, ee->h, ee->w); + evas_output_viewport_set(ee->evas, 0, 0, ee->h, ee->w); + } + else + { + evas_output_size_set(ee->evas, ee->w, ee->h); + evas_output_viewport_set(ee->evas, 0, 0, ee->w, ee->h); + } + /* FIXME: damage and shape */ + + if (ee->func.fn_resize) ee->func.fn_resize(ee); + } +} + +static void +_ecore_evas_win32_move_resize(Ecore_Evas *ee, int x, int y, int width, int height) +{ + printf (" * _ecore_evas_win32_resize\n"); + if ((ee->w != width) || (ee->h != height) || (x != ee->x) || (y != ee->y)) + { + int change_size = 0; + int change_pos = 0; + + if ((ee->w != width) || (ee->h != height)) change_size = 1; + if ((x != ee->x) || (y != ee->y)) change_pos = 1; + + ee->x = x; + ee->y = y; + ee->w = width; + ee->h = height; + ecore_win32_window_move_resize(ee->engine.win32.window, x, y, width, height); + if ((ee->rotation == 90) || (ee->rotation == 270)) + { + evas_output_size_set(ee->evas, ee->h, ee->w); + evas_output_viewport_set(ee->evas, 0, 0, ee->h, ee->w); + } + else + { + evas_output_size_set(ee->evas, ee->w, ee->h); + evas_output_viewport_set(ee->evas, 0, 0, ee->w, ee->h); + } + /* FIXME: damage and shape */ + if (change_pos) + { + if (ee->func.fn_move) ee->func.fn_move(ee); + } + if (change_size) + { + if (ee->func.fn_resize) ee->func.fn_resize(ee); + } + } +} + +static void +_ecore_evas_win32_rotation_set(Ecore_Evas *ee, int rotation) +{ + int rot_dif; + + if (ee->rotation == rotation) return; + rot_dif = ee->rotation - rotation; + if (rot_dif < 0) rot_dif = -rot_dif; + if (!strcmp(ee->driver, "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->engine.win32.window, ee->h, ee->w); + ee->expecting_resize.w = ee->h; + ee->expecting_resize.h = ee->w; + } + else + { + int w, h; + + ecore_win32_window_s... [truncated message content] |