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_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 void
+_ecore_evas_win32_fullscreen_set(Ecore_Evas *ee, int on)
+{
+ if ((ee->prop.fullscreen && on) ||
+ (!ee->prop.fullscreen && !on)) return;
+
+ ee->engine.win32.state.fullscreen = on;
+ ecore_win32_window_fullscreen_set(ee->engine.win32.window, ee->prop.borderless);
+ /* FIXME: what to do with that code ?? */
+/* if (ee->should_be_visible) */
+/* ecore_x_netwm_state_request_send(ee->engine.x.win, ee->engine.x.win_root, */
+/* ECORE_X_WINDOW_STATE_FULLSCREEN, -1, on); */
+/* else */
+/* _ecore_evas_win32_state_update(ee); */
+}
+
+
+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,
+ _ecore_evas_win32_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_Win32_Window *
+ecore_evas_software_ddraw_window_get(Ecore_Evas *ee)
+{
+#ifdef BUILD_ECORE_WIN32
+ return ee->engine.win32.window;
+#else
+ return NULL;
+#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 */
+}
+
+EAPI Ecore_Win32_Window *
+ecore_evas_direct3d_window_get(Ecore_Evas *ee)
+{
+#ifdef BUILD_ECORE_WIN32
+ return ee->engine.win32.window;
+#else
+ return NULL;
+#endif /* BUILD_ECORE_WIN32 */
+}
|