mirror of
				https://github.com/libsdl-org/SDL.git
				synced 2025-10-25 20:07:17 +00:00 
			
		
		
		
	Make certain we only hide system UI when we're fullscreen for real. (thanks Rachel!)
This commit is contained in:
		| @@ -444,6 +444,8 @@ public class SDLActivity extends Activity implements View.OnSystemUiVisibilityCh | |||||||
|  |  | ||||||
|     protected static final int COMMAND_USER = 0x8000; |     protected static final int COMMAND_USER = 0x8000; | ||||||
|  |  | ||||||
|  |     protected static boolean mFullscreenModeActive; | ||||||
|  |  | ||||||
|     /** |     /** | ||||||
|      * This method is called by SDL if SDL did not handle a message itself. |      * This method is called by SDL if SDL did not handle a message itself. | ||||||
|      * This happens if a received message contains an unsupported command. |      * This happens if a received message contains an unsupported command. | ||||||
| @@ -495,11 +497,13 @@ public class SDLActivity extends Activity implements View.OnSystemUiVisibilityCh | |||||||
|                             window.getDecorView().setSystemUiVisibility(flags);         |                             window.getDecorView().setSystemUiVisibility(flags);         | ||||||
|                             window.addFlags(WindowManager.LayoutParams.FLAG_FULLSCREEN); |                             window.addFlags(WindowManager.LayoutParams.FLAG_FULLSCREEN); | ||||||
|                             window.clearFlags(WindowManager.LayoutParams.FLAG_FORCE_NOT_FULLSCREEN); |                             window.clearFlags(WindowManager.LayoutParams.FLAG_FORCE_NOT_FULLSCREEN); | ||||||
|  |                             SDLActivity.mFullscreenModeActive = true; | ||||||
|                         } else { |                         } else { | ||||||
|                             int flags = View.SYSTEM_UI_FLAG_LAYOUT_STABLE | View.SYSTEM_UI_FLAG_VISIBLE; |                             int flags = View.SYSTEM_UI_FLAG_LAYOUT_STABLE | View.SYSTEM_UI_FLAG_VISIBLE; | ||||||
|                             window.getDecorView().setSystemUiVisibility(flags); |                             window.getDecorView().setSystemUiVisibility(flags); | ||||||
|                             window.addFlags(WindowManager.LayoutParams.FLAG_FORCE_NOT_FULLSCREEN); |                             window.addFlags(WindowManager.LayoutParams.FLAG_FORCE_NOT_FULLSCREEN); | ||||||
|                             window.clearFlags(WindowManager.LayoutParams.FLAG_FULLSCREEN); |                             window.clearFlags(WindowManager.LayoutParams.FLAG_FULLSCREEN); | ||||||
|  |                             SDLActivity.mFullscreenModeActive = false; | ||||||
|                         } |                         } | ||||||
|                     } |                     } | ||||||
|                 } else { |                 } else { | ||||||
| @@ -1129,7 +1133,7 @@ public class SDLActivity extends Activity implements View.OnSystemUiVisibilityCh | |||||||
|     }; |     }; | ||||||
|  |  | ||||||
|     public void onSystemUiVisibilityChange(int visibility) { |     public void onSystemUiVisibilityChange(int visibility) { | ||||||
|         if ((visibility & View.SYSTEM_UI_FLAG_FULLSCREEN) == 0 || (visibility & View.SYSTEM_UI_FLAG_HIDE_NAVIGATION) == 0) { |         if (SDLActivity.mFullscreenModeActive && (visibility & View.SYSTEM_UI_FLAG_FULLSCREEN) == 0 || (visibility & View.SYSTEM_UI_FLAG_HIDE_NAVIGATION) == 0) { | ||||||
|  |  | ||||||
|             Handler handler = getWindow().getDecorView().getHandler(); |             Handler handler = getWindow().getDecorView().getHandler(); | ||||||
|             if (handler != null) { |             if (handler != null) { | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user
	 Sam Lantinga
					Sam Lantinga