src/video/windx5/SDL_dx5events.c
changeset 970 fb8b91365766
parent 833 31fa08b36380
child 975 add87cc1de0a
--- a/src/video/windx5/SDL_dx5events.c	Fri Nov 12 22:09:17 2004 +0000
+++ b/src/video/windx5/SDL_dx5events.c	Fri Nov 12 23:14:47 2004 +0000
@@ -141,6 +141,7 @@
 	LPDIRECTINPUTDEVICE device;
 	HRESULT     result;
 	DIPROPDWORD dipdw;
+	HWND        topwnd;
 
 	/* Create the DirectInput object */
 	result = DInputCreate(SDL_Instance, DIRECTINPUT_VERSION,
@@ -167,8 +168,9 @@
 			SetDIerror("DirectInputDevice::QueryInterface", result);
 			return(-1);
 		}
+		topwnd =  GetAncestor(SDL_Window, GA_ROOT);
 		result = IDirectInputDevice2_SetCooperativeLevel(SDL_DIdev[i],
-					SDL_Window, inputs[i].win_level);
+					topwnd, inputs[i].win_level);
 		if ( result != DI_OK ) {
 			SetDIerror("DirectInputDevice::SetCooperativeLevel",
 									result);
@@ -640,6 +642,7 @@
 	DWORD level;
 	int i;
 	HRESULT result;
+	HWND topwnd;
 
 	for ( i=0; i<MAX_INPUTS; ++i ) {
 		if ( SDL_DIdev[i] != NULL ) {
@@ -649,8 +652,9 @@
 				level = inputs[i].win_level;
 			}
 			IDirectInputDevice2_Unacquire(SDL_DIdev[i]);
+			topwnd = GetAncestor(SDL_Window, GA_ROOT);
 			result = IDirectInputDevice2_SetCooperativeLevel(
-					SDL_DIdev[i], SDL_Window, level);
+					SDL_DIdev[i], topwnd, level);
 			IDirectInputDevice2_Acquire(SDL_DIdev[i]);
 			if ( result != DI_OK ) {
 				SetDIerror(