mirror of
				https://github.com/encounter/SDL.git
				synced 2025-10-26 03:30:23 +00:00 
			
		
		
		
	Added a window flash operation to be explicit about window flash behavior
This commit is contained in:
		
							parent
							
								
									b2c8d3e9e4
								
							
						
					
					
						commit
						f1633127d1
					
				| @ -1440,15 +1440,6 @@ extern "C" { | |||||||
|  */ |  */ | ||||||
| #define SDL_HINT_WAVE_TRUNCATION   "SDL_WAVE_TRUNCATION" | #define SDL_HINT_WAVE_TRUNCATION   "SDL_WAVE_TRUNCATION" | ||||||
| 
 | 
 | ||||||
| /**
 |  | ||||||
|  *  \brief  Controls the number of times a window flashes with SDL_FlashWindow() |  | ||||||
|  * |  | ||||||
|  *  On Windows, if this variable is set, the SDL_FlashWindow() call will flash |  | ||||||
|  *  the specified number of times. Otherwise the window will flash until it |  | ||||||
|  *  becomes the foreground window. |  | ||||||
|  */ |  | ||||||
| #define SDL_HINT_WINDOW_FLASH_COUNT "SDL_WINDOW_FLASH_COUNT" |  | ||||||
| 
 |  | ||||||
| /**
 | /**
 | ||||||
|  * \brief Tell SDL not to name threads on Windows with the 0x406D1388 Exception. |  * \brief Tell SDL not to name threads on Windows with the 0x406D1388 Exception. | ||||||
|  *        The 0x406D1388 Exception is a trick used to inform Visual Studio of a |  *        The 0x406D1388 Exception is a trick used to inform Visual Studio of a | ||||||
|  | |||||||
| @ -64,6 +64,7 @@ typedef struct | |||||||
|     const char *window_title; |     const char *window_title; | ||||||
|     const char *window_icon; |     const char *window_icon; | ||||||
|     Uint32 window_flags; |     Uint32 window_flags; | ||||||
|  |     SDL_bool flash_on_focus_loss; | ||||||
|     int window_x; |     int window_x; | ||||||
|     int window_y; |     int window_y; | ||||||
|     int window_w; |     int window_w; | ||||||
|  | |||||||
| @ -188,6 +188,9 @@ typedef enum | |||||||
|     SDL_DISPLAYEVENT_DISCONNECTED   /**< Display has been removed from the system */ |     SDL_DISPLAYEVENT_DISCONNECTED   /**< Display has been removed from the system */ | ||||||
| } SDL_DisplayEventID; | } SDL_DisplayEventID; | ||||||
| 
 | 
 | ||||||
|  | /**
 | ||||||
|  |  *  \brief Display orientation | ||||||
|  |  */ | ||||||
| typedef enum | typedef enum | ||||||
| { | { | ||||||
|     SDL_ORIENTATION_UNKNOWN,            /**< The display orientation can't be determined */ |     SDL_ORIENTATION_UNKNOWN,            /**< The display orientation can't be determined */ | ||||||
| @ -197,6 +200,16 @@ typedef enum | |||||||
|     SDL_ORIENTATION_PORTRAIT_FLIPPED    /**< The display is in portrait mode, upside down */ |     SDL_ORIENTATION_PORTRAIT_FLIPPED    /**< The display is in portrait mode, upside down */ | ||||||
| } SDL_DisplayOrientation; | } SDL_DisplayOrientation; | ||||||
| 
 | 
 | ||||||
|  | /**
 | ||||||
|  |  *  \brief Window flash operation | ||||||
|  |  */ | ||||||
|  | typedef enum | ||||||
|  | { | ||||||
|  |     SDL_FLASH_CANCEL,                   /**< Cancel any window flash state */ | ||||||
|  |     SDL_FLASH_BRIEFLY,                  /**< Flash the window briefly to get attention */ | ||||||
|  |     SDL_FLASH_UNTIL_FOCUSED,            /**< Flash the window until it gets focus */ | ||||||
|  | } SDL_FlashOperation; | ||||||
|  | 
 | ||||||
| /**
 | /**
 | ||||||
|  *  \brief An opaque handle to an OpenGL context. |  *  \brief An opaque handle to an OpenGL context. | ||||||
|  */ |  */ | ||||||
| @ -1511,10 +1524,11 @@ extern DECLSPEC int SDLCALL SDL_SetWindowHitTest(SDL_Window * window, | |||||||
|  * Request a window to demand attention from the user. |  * Request a window to demand attention from the user. | ||||||
|  * |  * | ||||||
|  * \param window the window to be flashed |  * \param window the window to be flashed | ||||||
|  |  * \param the flash operation | ||||||
|  * \returns 0 on success or a negative error code on failure; call |  * \returns 0 on success or a negative error code on failure; call | ||||||
|  *          SDL_GetError() for more information. |  *          SDL_GetError() for more information. | ||||||
|  */ |  */ | ||||||
| extern DECLSPEC int SDLCALL SDL_FlashWindow(SDL_Window * window); | extern DECLSPEC int SDLCALL SDL_FlashWindow(SDL_Window * window, SDL_FlashOperation operation); | ||||||
| 
 | 
 | ||||||
| /**
 | /**
 | ||||||
|  * Destroy a window. |  * Destroy a window. | ||||||
|  | |||||||
| @ -876,6 +876,6 @@ SDL_DYNAPI_PROC(int,SDL_AndroidShowToast,(const char *a, int b, int c, int d, in | |||||||
| SDL_DYNAPI_PROC(int,SDL_GetAudioDeviceSpec,(int a, int b, SDL_AudioSpec *c),(a,b,c),return) | SDL_DYNAPI_PROC(int,SDL_GetAudioDeviceSpec,(int a, int b, SDL_AudioSpec *c),(a,b,c),return) | ||||||
| SDL_DYNAPI_PROC(void,SDL_TLSCleanup,(void),(),) | SDL_DYNAPI_PROC(void,SDL_TLSCleanup,(void),(),) | ||||||
| SDL_DYNAPI_PROC(void,SDL_SetWindowAlwaysOnTop,(SDL_Window *a, SDL_bool b),(a,b),) | SDL_DYNAPI_PROC(void,SDL_SetWindowAlwaysOnTop,(SDL_Window *a, SDL_bool b),(a,b),) | ||||||
| SDL_DYNAPI_PROC(int,SDL_FlashWindow,(SDL_Window *a),(a),return) | SDL_DYNAPI_PROC(int,SDL_FlashWindow,(SDL_Window *a, SDL_FlashOperation b),(a,b),return) | ||||||
| SDL_DYNAPI_PROC(int,SDL_GameControllerSendEffect,(SDL_GameController *a, const void *b, int c),(a,b,c),return) | SDL_DYNAPI_PROC(int,SDL_GameControllerSendEffect,(SDL_GameController *a, const void *b, int c),(a,b,c),return) | ||||||
| SDL_DYNAPI_PROC(int,SDL_JoystickSendEffect,(SDL_Joystick *a, const void *b, int c),(a,b,c),return) | SDL_DYNAPI_PROC(int,SDL_JoystickSendEffect,(SDL_Joystick *a, const void *b, int c),(a,b,c),return) | ||||||
|  | |||||||
| @ -37,7 +37,7 @@ static const char *video_usage[] = { | |||||||
|     "[--scale N]", "[--depth N]", "[--refresh R]", "[--vsync]", "[--noframe]", |     "[--scale N]", "[--depth N]", "[--refresh R]", "[--vsync]", "[--noframe]", | ||||||
|     "[--resizable]", "[--minimize]", "[--maximize]", "[--grab]", "[--keyboard-grab]", |     "[--resizable]", "[--minimize]", "[--maximize]", "[--grab]", "[--keyboard-grab]", | ||||||
|     "[--shown]", "[--hidden]", "[--input-focus]", "[--mouse-focus]", |     "[--shown]", "[--hidden]", "[--input-focus]", "[--mouse-focus]", | ||||||
|     "[--allow-highdpi]", "[--usable-bounds]" |     "[--flash-on-focus-loss]", "[--allow-highdpi]", "[--usable-bounds]" | ||||||
| }; | }; | ||||||
| 
 | 
 | ||||||
| static const char *audio_usage[] = { | static const char *audio_usage[] = { | ||||||
| @ -441,6 +441,10 @@ SDLTest_CommonArg(SDLTest_CommonState * state, int index) | |||||||
|         state->window_flags |= SDL_WINDOW_MOUSE_FOCUS; |         state->window_flags |= SDL_WINDOW_MOUSE_FOCUS; | ||||||
|         return 1; |         return 1; | ||||||
|     } |     } | ||||||
|  |     if (SDL_strcasecmp(argv[index], "--flash-on-focus-loss") == 0) { | ||||||
|  |         state->flash_on_focus_loss = SDL_TRUE; | ||||||
|  |         return 1; | ||||||
|  |     } | ||||||
|     if (SDL_strcasecmp(argv[index], "--grab") == 0) { |     if (SDL_strcasecmp(argv[index], "--grab") == 0) { | ||||||
|         state->window_flags |= SDL_WINDOW_MOUSE_GRABBED; |         state->window_flags |= SDL_WINDOW_MOUSE_GRABBED; | ||||||
|         return 1; |         return 1; | ||||||
| @ -1808,6 +1812,16 @@ SDLTest_CommonEvent(SDLTest_CommonState * state, SDL_Event * event, int *done) | |||||||
|                 } |                 } | ||||||
|             } |             } | ||||||
|             break; |             break; | ||||||
|  |         case SDL_WINDOWEVENT_FOCUS_LOST: | ||||||
|  |             if (state->flash_on_focus_loss) { | ||||||
|  |                 SDL_Window *window = SDL_GetWindowFromID(event->window.windowID); | ||||||
|  |                 if (window) { | ||||||
|  |                     SDL_FlashWindow(window, SDL_FLASH_UNTIL_FOCUSED); | ||||||
|  |                 } | ||||||
|  |             } | ||||||
|  |             break; | ||||||
|  |         default: | ||||||
|  |             break; | ||||||
|         } |         } | ||||||
|         break; |         break; | ||||||
|     case SDL_KEYDOWN: { |     case SDL_KEYDOWN: { | ||||||
| @ -1963,7 +1977,7 @@ SDLTest_CommonEvent(SDLTest_CommonState * state, SDL_Event * event, int *done) | |||||||
|                 /* Ctrl-F flash the window */ |                 /* Ctrl-F flash the window */ | ||||||
|                 SDL_Window *window = SDL_GetWindowFromID(event->key.windowID); |                 SDL_Window *window = SDL_GetWindowFromID(event->key.windowID); | ||||||
|                 if (window) { |                 if (window) { | ||||||
|                     SDL_FlashWindow(window); |                     SDL_FlashWindow(window, SDL_FLASH_BRIEFLY); | ||||||
|                 } |                 } | ||||||
|             } |             } | ||||||
|             break; |             break; | ||||||
|  | |||||||
| @ -240,7 +240,7 @@ struct SDL_VideoDevice | |||||||
|     int (*UpdateWindowFramebuffer) (_THIS, SDL_Window * window, const SDL_Rect * rects, int numrects); |     int (*UpdateWindowFramebuffer) (_THIS, SDL_Window * window, const SDL_Rect * rects, int numrects); | ||||||
|     void (*DestroyWindowFramebuffer) (_THIS, SDL_Window * window); |     void (*DestroyWindowFramebuffer) (_THIS, SDL_Window * window); | ||||||
|     void (*OnWindowEnter) (_THIS, SDL_Window * window); |     void (*OnWindowEnter) (_THIS, SDL_Window * window); | ||||||
|     int (*FlashWindow) (_THIS, SDL_Window * window); |     int (*FlashWindow) (_THIS, SDL_Window * window, SDL_FlashOperation operation); | ||||||
| 
 | 
 | ||||||
|     /* * * */ |     /* * * */ | ||||||
|     /*
 |     /*
 | ||||||
|  | |||||||
| @ -2793,12 +2793,12 @@ SDL_GetGrabbedWindow(void) | |||||||
| } | } | ||||||
| 
 | 
 | ||||||
| int | int | ||||||
| SDL_FlashWindow(SDL_Window * window) | SDL_FlashWindow(SDL_Window * window, SDL_FlashOperation operation) | ||||||
| { | { | ||||||
|     CHECK_WINDOW_MAGIC(window, -1); |     CHECK_WINDOW_MAGIC(window, -1); | ||||||
| 
 | 
 | ||||||
|     if (_this->FlashWindow) { |     if (_this->FlashWindow) { | ||||||
|         return _this->FlashWindow(_this, window); |         return _this->FlashWindow(_this, window, operation); | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     return SDL_Unsupported(); |     return SDL_Unsupported(); | ||||||
|  | |||||||
| @ -117,6 +117,7 @@ struct SDL_WindowData | |||||||
|     NSMutableArray *nscontexts; |     NSMutableArray *nscontexts; | ||||||
|     SDL_bool created; |     SDL_bool created; | ||||||
|     SDL_bool inWindowFullscreenTransition; |     SDL_bool inWindowFullscreenTransition; | ||||||
|  |     NSInteger flash_request; | ||||||
|     Cocoa_WindowListener *listener; |     Cocoa_WindowListener *listener; | ||||||
|     struct SDL_VideoData *videodata; |     struct SDL_VideoData *videodata; | ||||||
| #if SDL_VIDEO_OPENGL_EGL | #if SDL_VIDEO_OPENGL_EGL | ||||||
| @ -151,7 +152,7 @@ extern void Cocoa_DestroyWindow(_THIS, SDL_Window * window); | |||||||
| extern SDL_bool Cocoa_GetWindowWMInfo(_THIS, SDL_Window * window, struct SDL_SysWMinfo *info); | extern SDL_bool Cocoa_GetWindowWMInfo(_THIS, SDL_Window * window, struct SDL_SysWMinfo *info); | ||||||
| extern int Cocoa_SetWindowHitTest(SDL_Window *window, SDL_bool enabled); | extern int Cocoa_SetWindowHitTest(SDL_Window *window, SDL_bool enabled); | ||||||
| extern void Cocoa_AcceptDragAndDrop(SDL_Window * window, SDL_bool accept); | extern void Cocoa_AcceptDragAndDrop(SDL_Window * window, SDL_bool accept); | ||||||
| extern int Cocoa_FlashWindow(_THIS, SDL_Window * window); | extern int Cocoa_FlashWindow(_THIS, SDL_Window * window, SDL_FlashOperation operation); | ||||||
| 
 | 
 | ||||||
| #endif /* SDL_cocoawindow_h_ */ | #endif /* SDL_cocoawindow_h_ */ | ||||||
| 
 | 
 | ||||||
|  | |||||||
| @ -2117,11 +2117,30 @@ Cocoa_AcceptDragAndDrop(SDL_Window * window, SDL_bool accept) | |||||||
| } | } | ||||||
| 
 | 
 | ||||||
| int | int | ||||||
| Cocoa_FlashWindow(_THIS, SDL_Window *window) | Cocoa_FlashWindow(_THIS, SDL_Window *window, SDL_FlashOperation operation) | ||||||
| { @autoreleasepool | { @autoreleasepool | ||||||
| { | { | ||||||
|     /* Note that this is app-wide and not window-specific! */ |     /* Note that this is app-wide and not window-specific! */ | ||||||
|     [NSApp requestUserAttention:NSInformationalRequest]; |     SDL_WindowData *data = (SDL_WindowData *) window->driverdata; | ||||||
|  | 
 | ||||||
|  |     if (data->flash_request) { | ||||||
|  |         [NSApp cancelUserAttentionRequest:data->flash_request]; | ||||||
|  |         data->flash_request = 0; | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     switch (operation) { | ||||||
|  |     case SDL_FLASH_CANCEL: | ||||||
|  |         /* Canceled above */ | ||||||
|  |         break; | ||||||
|  |     case SDL_FLASH_BRIEFLY: | ||||||
|  |         data->flash_request = [NSApp requestUserAttention:NSInformationalRequest]; | ||||||
|  |         break; | ||||||
|  |     case SDL_FLASH_UNTIL_FOCUSED: | ||||||
|  |         data->flash_request = [NSApp requestUserAttention:NSCriticalRequest]; | ||||||
|  |         break; | ||||||
|  |     default: | ||||||
|  |         return SDL_Unsupported(); | ||||||
|  |     } | ||||||
|     return 0; |     return 0; | ||||||
| }} | }} | ||||||
| 
 | 
 | ||||||
|  | |||||||
| @ -920,7 +920,7 @@ Wayland_RaiseWindow(_THIS, SDL_Window *window) | |||||||
| } | } | ||||||
| 
 | 
 | ||||||
| int | int | ||||||
| Wayland_FlashWindow(_THIS, SDL_Window *window) | Wayland_FlashWindow(_THIS, SDL_Window *window, SDL_FlashOperation operation) | ||||||
| { | { | ||||||
|     Wayland_activate_window(_this->driverdata, |     Wayland_activate_window(_this->driverdata, | ||||||
|                             window->driverdata, |                             window->driverdata, | ||||||
|  | |||||||
| @ -113,7 +113,7 @@ extern void Wayland_SuspendScreenSaver(_THIS); | |||||||
| extern SDL_bool | extern SDL_bool | ||||||
| Wayland_GetWindowWMInfo(_THIS, SDL_Window * window, SDL_SysWMinfo * info); | Wayland_GetWindowWMInfo(_THIS, SDL_Window * window, SDL_SysWMinfo * info); | ||||||
| extern int Wayland_SetWindowHitTest(SDL_Window *window, SDL_bool enabled); | extern int Wayland_SetWindowHitTest(SDL_Window *window, SDL_bool enabled); | ||||||
| extern int Wayland_FlashWindow(_THIS, SDL_Window * window); | extern int Wayland_FlashWindow(_THIS, SDL_Window * window, SDL_FlashOperation operation); | ||||||
| 
 | 
 | ||||||
| extern void Wayland_HandlePendingResize(SDL_Window *window); | extern void Wayland_HandlePendingResize(SDL_Window *window); | ||||||
| 
 | 
 | ||||||
|  | |||||||
| @ -1064,19 +1064,26 @@ WIN_AcceptDragAndDrop(SDL_Window * window, SDL_bool accept) | |||||||
| } | } | ||||||
| 
 | 
 | ||||||
| int | int | ||||||
| WIN_FlashWindow(_THIS, SDL_Window * window) | WIN_FlashWindow(_THIS, SDL_Window * window, SDL_FlashOperation operation) | ||||||
| { | { | ||||||
|     FLASHWINFO desc; |     FLASHWINFO desc; | ||||||
|     const char *hint = SDL_GetHint(SDL_HINT_WINDOW_FLASH_COUNT); |  | ||||||
| 
 | 
 | ||||||
|     SDL_zero(desc); |     SDL_zero(desc); | ||||||
|     desc.cbSize = sizeof(desc); |     desc.cbSize = sizeof(desc); | ||||||
|     desc.hwnd = ((SDL_WindowData *) window->driverdata)->hwnd; |     desc.hwnd = ((SDL_WindowData *) window->driverdata)->hwnd; | ||||||
|  |     switch (operation) { | ||||||
|  |     case SDL_FLASH_CANCEL: | ||||||
|  |         desc.dwFlags = FLASHW_STOP; | ||||||
|  |         break; | ||||||
|  |     case SDL_FLASH_BRIEFLY: | ||||||
|         desc.dwFlags = FLASHW_TRAY; |         desc.dwFlags = FLASHW_TRAY; | ||||||
|     if (hint && *hint) { |         desc.uCount = 1; | ||||||
|         desc.uCount = SDL_atoi(hint); |         break; | ||||||
|     } else { |     case SDL_FLASH_UNTIL_FOCUSED: | ||||||
|         desc.dwFlags |= FLASHW_TIMERNOFG; |         desc.dwFlags = (FLASHW_TRAY | FLASHW_TIMERNOFG); | ||||||
|  |         break; | ||||||
|  |     default: | ||||||
|  |         return SDL_Unsupported(); | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     FlashWindowEx(&desc); |     FlashWindowEx(&desc); | ||||||
|  | |||||||
| @ -86,7 +86,7 @@ extern void WIN_OnWindowEnter(_THIS, SDL_Window * window); | |||||||
| extern void WIN_UpdateClipCursor(SDL_Window *window); | extern void WIN_UpdateClipCursor(SDL_Window *window); | ||||||
| extern int WIN_SetWindowHitTest(SDL_Window *window, SDL_bool enabled); | extern int WIN_SetWindowHitTest(SDL_Window *window, SDL_bool enabled); | ||||||
| extern void WIN_AcceptDragAndDrop(SDL_Window * window, SDL_bool accept); | extern void WIN_AcceptDragAndDrop(SDL_Window * window, SDL_bool accept); | ||||||
| extern int WIN_FlashWindow(_THIS, SDL_Window * window); | extern int WIN_FlashWindow(_THIS, SDL_Window * window, SDL_FlashOperation operation); | ||||||
| 
 | 
 | ||||||
| #endif /* SDL_windowswindow_h_ */ | #endif /* SDL_windowswindow_h_ */ | ||||||
| 
 | 
 | ||||||
|  | |||||||
| @ -1749,7 +1749,7 @@ X11_AcceptDragAndDrop(SDL_Window * window, SDL_bool accept) | |||||||
| } | } | ||||||
| 
 | 
 | ||||||
| int | int | ||||||
| X11_FlashWindow(_THIS, SDL_Window * window) | X11_FlashWindow(_THIS, SDL_Window * window, SDL_FlashOperation operation) | ||||||
| { | { | ||||||
|     SDL_WindowData *data = (SDL_WindowData *) window->driverdata; |     SDL_WindowData *data = (SDL_WindowData *) window->driverdata; | ||||||
|     SDL_DisplayData *displaydata = (SDL_DisplayData *) SDL_GetDisplayForWindow(window)->driverdata; |     SDL_DisplayData *displaydata = (SDL_DisplayData *) SDL_GetDisplayForWindow(window)->driverdata; | ||||||
|  | |||||||
| @ -107,7 +107,7 @@ extern SDL_bool X11_GetWindowWMInfo(_THIS, SDL_Window * window, | |||||||
|                                     struct SDL_SysWMinfo *info); |                                     struct SDL_SysWMinfo *info); | ||||||
| extern int X11_SetWindowHitTest(SDL_Window *window, SDL_bool enabled); | extern int X11_SetWindowHitTest(SDL_Window *window, SDL_bool enabled); | ||||||
| extern void X11_AcceptDragAndDrop(SDL_Window * window, SDL_bool accept); | extern void X11_AcceptDragAndDrop(SDL_Window * window, SDL_bool accept); | ||||||
| extern int X11_FlashWindow(_THIS, SDL_Window * window); | extern int X11_FlashWindow(_THIS, SDL_Window * window, SDL_FlashOperation operation); | ||||||
| 
 | 
 | ||||||
| #endif /* SDL_x11window_h_ */ | #endif /* SDL_x11window_h_ */ | ||||||
| 
 | 
 | ||||||
|  | |||||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user