forked from eden-emu/eden
		
	Merge citra-emu PR#3001 by Styleoshin(citra-qt : Adding fullscreen mode)
This commit is contained in:
		
							parent
							
								
									713c1ed203
								
							
						
					
					
						commit
						f473780c52
					
				
					 5 changed files with 57 additions and 1 deletions
				
			
		|  | @ -137,6 +137,7 @@ void Config::ReadValues() { | |||
|     qt_config->endGroup(); | ||||
| 
 | ||||
|     UISettings::values.single_window_mode = qt_config->value("singleWindowMode", true).toBool(); | ||||
|     UISettings::values.fullscreen = qt_config->value("fullscreen", false).toBool(); | ||||
|     UISettings::values.display_titlebar = qt_config->value("displayTitleBars", true).toBool(); | ||||
|     UISettings::values.show_filter_bar = qt_config->value("showFilterBar", true).toBool(); | ||||
|     UISettings::values.show_status_bar = qt_config->value("showStatusBar", true).toBool(); | ||||
|  | @ -216,6 +217,7 @@ void Config::SaveValues() { | |||
|     qt_config->endGroup(); | ||||
| 
 | ||||
|     qt_config->setValue("singleWindowMode", UISettings::values.single_window_mode); | ||||
|     qt_config->setValue("fullscreen", UISettings::values.fullscreen); | ||||
|     qt_config->setValue("displayTitleBars", UISettings::values.display_titlebar); | ||||
|     qt_config->setValue("showFilterBar", UISettings::values.show_filter_bar); | ||||
|     qt_config->setValue("showStatusBar", UISettings::values.show_status_bar); | ||||
|  |  | |||
|  | @ -185,12 +185,24 @@ void GMainWindow::InitializeRecentFileMenuActions() { | |||
| void GMainWindow::InitializeHotkeys() { | ||||
|     RegisterHotkey("Main Window", "Load File", QKeySequence::Open); | ||||
|     RegisterHotkey("Main Window", "Start Emulation"); | ||||
|     RegisterHotkey( "Main Window", "Fullscreen", QKeySequence::FullScreen ); | ||||
|     RegisterHotkey( "Main Window", "Exit Fullscreen", QKeySequence::Cancel, Qt::ApplicationShortcut ); | ||||
|     LoadHotkeys(); | ||||
| 
 | ||||
|     connect(GetHotkey("Main Window", "Load File", this), SIGNAL(activated()), this, | ||||
|             SLOT(OnMenuLoadFile())); | ||||
|     connect(GetHotkey("Main Window", "Start Emulation", this), SIGNAL(activated()), this, | ||||
|             SLOT(OnStartGame())); | ||||
|     connect(GetHotkey("Main Window", "Fullscreen", render_window), &QShortcut::activated, | ||||
|              ui.action_Fullscreen, &QAction::trigger); | ||||
|     connect(GetHotkey("Main Window", "Fullscreen", render_window), &QShortcut::activatedAmbiguously, | ||||
|              ui.action_Fullscreen, &QAction::trigger); | ||||
|     connect(GetHotkey("Main Window", "Exit Fullscreen", this), &QShortcut::activated, this, [&] { | ||||
|         if (emulation_running) { | ||||
|             ui.action_Fullscreen->setChecked(false); | ||||
|             ToggleFullscreen(); | ||||
|         } | ||||
|     }); | ||||
| } | ||||
| 
 | ||||
| void GMainWindow::SetDefaultUIGeometry() { | ||||
|  | @ -219,6 +231,8 @@ void GMainWindow::RestoreUIState() { | |||
|     ui.action_Single_Window_Mode->setChecked(UISettings::values.single_window_mode); | ||||
|     ToggleWindowMode(); | ||||
| 
 | ||||
|     ui.action_Fullscreen->setChecked(UISettings::values.fullscreen); | ||||
| 
 | ||||
|     ui.action_Display_Dock_Widget_Headers->setChecked(UISettings::values.display_titlebar); | ||||
|     OnDisplayTitleBars(ui.action_Display_Dock_Widget_Headers->isChecked()); | ||||
| 
 | ||||
|  | @ -263,6 +277,10 @@ void GMainWindow::ConnectMenuEvents() { | |||
|     connect(ui.action_Show_Filter_Bar, &QAction::triggered, this, &GMainWindow::OnToggleFilterBar); | ||||
|     connect(ui.action_Show_Status_Bar, &QAction::triggered, statusBar(), &QStatusBar::setVisible); | ||||
| 
 | ||||
|     // Fullscreen
 | ||||
|     ui.action_Fullscreen->setShortcut(GetHotkey("Main Window", "Fullscreen", this)->key()); | ||||
|     connect(ui.action_Fullscreen, &QAction::triggered, this, &GMainWindow::ToggleFullscreen); | ||||
| 
 | ||||
|     // Help
 | ||||
|     connect(ui.action_About, &QAction::triggered, this, &GMainWindow::OnAbout); | ||||
| } | ||||
|  | @ -402,6 +420,7 @@ void GMainWindow::BootGame(const QString& filename) { | |||
|     render_window->setFocus(); | ||||
| 
 | ||||
|     emulation_running = true; | ||||
|     ToggleFullscreen(); | ||||
|     OnStartGame(); | ||||
| } | ||||
| 
 | ||||
|  | @ -548,6 +567,29 @@ void GMainWindow::OnStopGame() { | |||
|     ShutdownGame(); | ||||
| } | ||||
| 
 | ||||
| void GMainWindow::ToggleFullscreen() { | ||||
|     if (!emulation_running) { | ||||
|         return; | ||||
|     } | ||||
|     if (ui.action_Fullscreen->isChecked()) { | ||||
|         if (ui.action_Single_Window_Mode->isChecked()) { | ||||
|             ui.menubar->hide(); | ||||
|             statusBar()->hide(); | ||||
|             showFullScreen(); | ||||
|         } else { | ||||
|             render_window->showFullScreen(); | ||||
|         } | ||||
|     } else { | ||||
|         if (ui.action_Single_Window_Mode->isChecked()) { | ||||
|             statusBar()->setVisible(ui.action_Show_Status_Bar->isChecked()); | ||||
|             ui.menubar->show(); | ||||
|             showNormal(); | ||||
|         } else { | ||||
|             render_window->showNormal(); | ||||
|         } | ||||
|     } | ||||
| } | ||||
| 
 | ||||
| void GMainWindow::ToggleWindowMode() { | ||||
|     if (ui.action_Single_Window_Mode->isChecked()) { | ||||
|         // Render in the main window...
 | ||||
|  | @ -700,6 +742,7 @@ void GMainWindow::closeEvent(QCloseEvent* event) { | |||
|     UISettings::values.microprofile_visible = microProfileDialog->isVisible(); | ||||
| #endif | ||||
|     UISettings::values.single_window_mode = ui.action_Single_Window_Mode->isChecked(); | ||||
|     UISettings::values.fullscreen = ui.action_Fullscreen->isChecked(); | ||||
|     UISettings::values.display_titlebar = ui.action_Display_Dock_Widget_Headers->isChecked(); | ||||
|     UISettings::values.show_filter_bar = ui.action_Show_Filter_Bar->isChecked(); | ||||
|     UISettings::values.show_status_bar = ui.action_Show_Status_Bar->isChecked(); | ||||
|  |  | |||
|  | @ -127,6 +127,7 @@ private slots: | |||
|     void OnAbout(); | ||||
|     void OnToggleFilterBar(); | ||||
|     void OnDisplayTitleBars(bool); | ||||
|     void ToggleFullscreen(); | ||||
|     void ToggleWindowMode(); | ||||
|     void OnCoreError(Core::System::ResultStatus, std::string); | ||||
| 
 | ||||
|  |  | |||
|  | @ -83,6 +83,7 @@ | |||
|       <string>Debugging</string> | ||||
|      </property> | ||||
|     </widget> | ||||
|     <addaction name="action_Fullscreen"/> | ||||
|     <addaction name="action_Single_Window_Mode"/> | ||||
|     <addaction name="action_Display_Dock_Widget_Headers"/> | ||||
|     <addaction name="action_Show_Filter_Bar"/> | ||||
|  | @ -189,6 +190,14 @@ | |||
|     <string>Selects a folder to display in the game list</string> | ||||
|    </property> | ||||
|   </action> | ||||
|  </widget> | ||||
|   <action name="action_Fullscreen"> | ||||
|    <property name="checkable"> | ||||
|     <bool>true</bool> | ||||
|    </property> | ||||
|    <property name="text"> | ||||
|     <string>Fullscreen</string> | ||||
|    </property> | ||||
|   </action> | ||||
|   </widget> | ||||
|  <resources/> | ||||
| </ui> | ||||
|  |  | |||
|  | @ -27,6 +27,7 @@ struct Values { | |||
|     bool microprofile_visible; | ||||
| 
 | ||||
|     bool single_window_mode; | ||||
|     bool fullscreen; | ||||
|     bool display_titlebar; | ||||
|     bool show_filter_bar; | ||||
|     bool show_status_bar; | ||||
|  |  | |||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue
	
	 goaaats
						goaaats