mirror of
				https://github.com/PabloMK7/citra.git
				synced 2025-10-31 13:50:03 +00:00 
			
		
		
		
	citra_qt/configuration: fix language configuration issues
This commit is contained in:
		
							parent
							
								
									7c3d325aff
								
							
						
					
					
						commit
						ab07d44193
					
				
					 12 changed files with 54 additions and 31 deletions
				
			
		|  | @ -20,12 +20,12 @@ public: | |||
| 
 | ||||
|     void applyConfiguration(); | ||||
|     void retranslateUi(); | ||||
|     void setConfiguration(); | ||||
| 
 | ||||
| public slots: | ||||
|     void updateAudioDevices(int sink_index); | ||||
| 
 | ||||
| private: | ||||
|     void setConfiguration(); | ||||
|     void setOutputSinkFromSinkID(); | ||||
|     void setAudioDeviceFromDeviceID(); | ||||
|     void setVolumeIndicatorText(int percentage); | ||||
|  |  | |||
|  | @ -20,8 +20,6 @@ public: | |||
| 
 | ||||
|     void applyConfiguration(); | ||||
|     void retranslateUi(); | ||||
| 
 | ||||
| private: | ||||
|     void setConfiguration(); | ||||
| 
 | ||||
| private: | ||||
|  |  | |||
|  | @ -14,7 +14,6 @@ ConfigureDialog::ConfigureDialog(QWidget* parent, const HotkeyRegistry& registry | |||
|     : QDialog(parent), ui(new Ui::ConfigureDialog) { | ||||
|     ui->setupUi(this); | ||||
|     ui->generalTab->PopulateHotkeyList(registry); | ||||
|     this->setConfiguration(); | ||||
|     this->PopulateSelectionList(); | ||||
|     connect(ui->uiTab, &ConfigureUi::languageChanged, this, &ConfigureDialog::onLanguageChanged); | ||||
|     connect(ui->selectorList, &QListWidget::itemSelectionChanged, this, | ||||
|  | @ -27,7 +26,17 @@ ConfigureDialog::ConfigureDialog(QWidget* parent, const HotkeyRegistry& registry | |||
| 
 | ||||
| ConfigureDialog::~ConfigureDialog() = default; | ||||
| 
 | ||||
| void ConfigureDialog::setConfiguration() {} | ||||
| void ConfigureDialog::setConfiguration() { | ||||
|     ui->generalTab->setConfiguration(); | ||||
|     ui->systemTab->setConfiguration(); | ||||
|     ui->inputTab->loadConfiguration(); | ||||
|     ui->graphicsTab->setConfiguration(); | ||||
|     ui->audioTab->setConfiguration(); | ||||
|     ui->cameraTab->setConfiguration(); | ||||
|     ui->debugTab->setConfiguration(); | ||||
|     ui->webTab->setConfiguration(); | ||||
|     ui->uiTab->setConfiguration(); | ||||
| } | ||||
| 
 | ||||
| void ConfigureDialog::applyConfiguration() { | ||||
|     ui->generalTab->applyConfiguration(); | ||||
|  | @ -44,12 +53,14 @@ void ConfigureDialog::applyConfiguration() { | |||
| } | ||||
| 
 | ||||
| void ConfigureDialog::PopulateSelectionList() { | ||||
|     ui->selectorList->clear(); | ||||
| 
 | ||||
|     const std::array<std::pair<QString, QStringList>, 4> items{ | ||||
|         {{tr("General"), {tr("General"), tr("Web"), tr("Debug"), tr("UI")}}, | ||||
|          {tr("System"), {tr("System"), tr("Audio"), tr("Camera")}}, | ||||
|          {tr("Graphics"), {tr("Graphics")}}, | ||||
|          {tr("Controls"), {tr("Input")}}}}; | ||||
|         {{tr("General"), | ||||
|           {QT_TR_NOOP("General"), QT_TR_NOOP("Web"), QT_TR_NOOP("Debug"), QT_TR_NOOP("UI")}}, | ||||
|          {tr("System"), {QT_TR_NOOP("System"), QT_TR_NOOP("Audio"), QT_TR_NOOP("Camera")}}, | ||||
|          {tr("Graphics"), {QT_TR_NOOP("Graphics")}}, | ||||
|          {tr("Controls"), {QT_TR_NOOP("Input")}}}}; | ||||
| 
 | ||||
|     for (const auto& entry : items) { | ||||
|         auto* item = new QListWidgetItem(entry.first); | ||||
|  | @ -61,7 +72,21 @@ void ConfigureDialog::PopulateSelectionList() { | |||
| 
 | ||||
| void ConfigureDialog::onLanguageChanged(const QString& locale) { | ||||
|     emit languageChanged(locale); | ||||
|     // first apply the configuration, and then restore the display
 | ||||
|     applyConfiguration(); | ||||
|     retranslateUi(); | ||||
|     setConfiguration(); | ||||
| } | ||||
| 
 | ||||
| void ConfigureDialog::retranslateUi() { | ||||
|     int old_row = ui->selectorList->currentRow(); | ||||
|     int old_index = ui->tabWidget->currentIndex(); | ||||
|     ui->retranslateUi(this); | ||||
|     PopulateSelectionList(); | ||||
|     // restore selection after repopulating
 | ||||
|     ui->selectorList->setCurrentRow(old_row); | ||||
|     ui->tabWidget->setCurrentIndex(old_index); | ||||
| 
 | ||||
|     ui->generalTab->retranslateUi(); | ||||
|     ui->systemTab->retranslateUi(); | ||||
|     ui->inputTab->retranslateUi(); | ||||
|  | @ -78,20 +103,15 @@ void ConfigureDialog::UpdateVisibleTabs() { | |||
|     if (items.isEmpty()) | ||||
|         return; | ||||
| 
 | ||||
|     const QHash<QString, QWidget*> widgets = {{tr("General"), ui->generalTab}, | ||||
|                                               {tr("System"), ui->systemTab}, | ||||
|                                               {tr("Input"), ui->inputTab}, | ||||
|                                               {tr("Graphics"), ui->graphicsTab}, | ||||
|                                               {tr("Audio"), ui->audioTab}, | ||||
|                                               {tr("Camera"), ui->cameraTab}, | ||||
|                                               {tr("Debug"), ui->debugTab}, | ||||
|                                               {tr("Web"), ui->webTab}, | ||||
|                                               {tr("UI"), ui->uiTab}}; | ||||
|     const QHash<QString, QWidget*> widgets = { | ||||
|         {"General", ui->generalTab},   {"System", ui->systemTab}, {"Input", ui->inputTab}, | ||||
|         {"Graphics", ui->graphicsTab}, {"Audio", ui->audioTab},   {"Camera", ui->cameraTab}, | ||||
|         {"Debug", ui->debugTab},       {"Web", ui->webTab},       {"UI", ui->uiTab}}; | ||||
| 
 | ||||
|     ui->tabWidget->clear(); | ||||
| 
 | ||||
|     QStringList tabs = items[0]->data(Qt::UserRole).toStringList(); | ||||
| 
 | ||||
|     for (const auto& tab : tabs) | ||||
|         ui->tabWidget->addTab(widgets[tab], tab); | ||||
|         ui->tabWidget->addTab(widgets[tab], tr(qPrintable(tab))); | ||||
| } | ||||
|  |  | |||
|  | @ -32,6 +32,7 @@ signals: | |||
| 
 | ||||
| private: | ||||
|     void setConfiguration(); | ||||
|     void retranslateUi(); | ||||
| 
 | ||||
| private: | ||||
|     std::unique_ptr<Ui::ConfigureDialog> ui; | ||||
|  |  | |||
|  | @ -24,9 +24,8 @@ public: | |||
|     void ResetDefaults(); | ||||
|     void applyConfiguration(); | ||||
|     void retranslateUi(); | ||||
| 
 | ||||
| private: | ||||
|     void setConfiguration(); | ||||
| 
 | ||||
| private: | ||||
|     std::unique_ptr<Ui::ConfigureGeneral> ui; | ||||
| }; | ||||
|  |  | |||
|  | @ -20,8 +20,6 @@ public: | |||
| 
 | ||||
|     void applyConfiguration(); | ||||
|     void retranslateUi(); | ||||
| 
 | ||||
| private: | ||||
|     void setConfiguration(); | ||||
| 
 | ||||
| private: | ||||
|  |  | |||
|  | @ -343,5 +343,4 @@ void ConfigureInput::keyPressEvent(QKeyEvent* event) { | |||
| 
 | ||||
| void ConfigureInput::retranslateUi() { | ||||
|     ui->retranslateUi(this); | ||||
|     updateButtonLabels(); | ||||
| } | ||||
|  |  | |||
|  | @ -35,6 +35,9 @@ public: | |||
|     void applyConfiguration(); | ||||
|     void retranslateUi(); | ||||
| 
 | ||||
|     /// Load configuration settings.
 | ||||
|     void loadConfiguration(); | ||||
| 
 | ||||
| private: | ||||
|     std::unique_ptr<Ui::ConfigureInput> ui; | ||||
| 
 | ||||
|  | @ -69,8 +72,6 @@ private: | |||
|     /// keyboard events are ignored.
 | ||||
|     bool want_keyboard_keys = false; | ||||
| 
 | ||||
|     /// Load configuration settings.
 | ||||
|     void loadConfiguration(); | ||||
|     /// Restore all buttons to their default values.
 | ||||
|     void restoreDefaults(); | ||||
|     /// Clear all input configuration
 | ||||
|  |  | |||
|  | @ -422,5 +422,4 @@ void ConfigureSystem::RefreshConsoleID() { | |||
| 
 | ||||
| void ConfigureSystem::retranslateUi() { | ||||
|     ui->retranslateUi(this); | ||||
|     ReadSystemSettings(); | ||||
| } | ||||
|  |  | |||
|  | @ -20,6 +20,7 @@ public: | |||
| 
 | ||||
|     void applyConfiguration(); | ||||
|     void retranslateUi(); | ||||
|     void setConfiguration(); | ||||
| 
 | ||||
| private slots: | ||||
|     void onLanguageChanged(int index); | ||||
|  | @ -28,7 +29,5 @@ signals: | |||
|     void languageChanged(const QString& locale); | ||||
| 
 | ||||
| private: | ||||
|     void setConfiguration(); | ||||
| 
 | ||||
|     std::unique_ptr<Ui::ConfigureUi> ui; | ||||
| }; | ||||
|  |  | |||
|  | @ -22,6 +22,16 @@ | |||
|      <layout class="QHBoxLayout" name="horizontalLayout"> | ||||
|       <item> | ||||
|        <layout class="QVBoxLayout" name="verticalLayout_2"> | ||||
|         <item> | ||||
|          <widget class="QLabel" name="label_change_language_info"> | ||||
|           <property name="text"> | ||||
|            <string>Note: Changing language will apply your configuration.</string> | ||||
|           </property> | ||||
|           <property name="wordWrap"> | ||||
|            <bool>true</bool> | ||||
|           </property> | ||||
|          </widget> | ||||
|         </item> | ||||
|         <item> | ||||
|          <layout class="QHBoxLayout" name="horizontalLayout_2"> | ||||
|           <item> | ||||
|  |  | |||
|  | @ -21,6 +21,7 @@ public: | |||
| 
 | ||||
|     void applyConfiguration(); | ||||
|     void retranslateUi(); | ||||
|     void setConfiguration(); | ||||
| 
 | ||||
| public slots: | ||||
|     void RefreshTelemetryID(); | ||||
|  | @ -29,8 +30,6 @@ public slots: | |||
|     void OnLoginVerified(); | ||||
| 
 | ||||
| private: | ||||
|     void setConfiguration(); | ||||
| 
 | ||||
|     bool user_verified = true; | ||||
|     QFutureWatcher<bool> verify_watcher; | ||||
| 
 | ||||
|  |  | |||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue