diff options
Diffstat (limited to 'src/yuzu')
| -rw-r--r-- | src/yuzu/main.cpp | 61 | ||||
| -rw-r--r-- | src/yuzu/main.h | 6 | ||||
| -rw-r--r-- | src/yuzu/main.ui | 12 | 
3 files changed, 56 insertions, 23 deletions
| diff --git a/src/yuzu/main.cpp b/src/yuzu/main.cpp index 82625e67f..fb299a39b 100644 --- a/src/yuzu/main.cpp +++ b/src/yuzu/main.cpp @@ -689,6 +689,11 @@ void GMainWindow::InitializeHotkeys() {      ui.action_Capture_Screenshot->setShortcutContext(          hotkey_registry.GetShortcutContext(main_window, capture_screenshot)); +    ui.action_Fullscreen->setShortcut( +        hotkey_registry.GetHotkey(main_window, fullscreen, this)->key()); +    ui.action_Fullscreen->setShortcutContext( +        hotkey_registry.GetShortcutContext(main_window, fullscreen)); +      connect(hotkey_registry.GetHotkey(main_window, QStringLiteral("Load File"), this),              &QShortcut::activated, this, &GMainWindow::OnMenuLoadFile);      connect( @@ -863,6 +868,9 @@ void GMainWindow::ConnectMenuEvents() {      connect(ui.action_Report_Compatibility, &QAction::triggered, this,              &GMainWindow::OnMenuReportCompatibility);      connect(ui.action_Open_Mods_Page, &QAction::triggered, this, &GMainWindow::OnOpenModsPage); +    connect(ui.action_Open_Quickstart_Guide, &QAction::triggered, this, +            &GMainWindow::OnOpenQuickstartGuide); +    connect(ui.action_Open_FAQ, &QAction::triggered, this, &GMainWindow::OnOpenFAQ);      connect(ui.action_Restart, &QAction::triggered, this, [this] { BootGame(QString(game_path)); });      connect(ui.action_Configure, &QAction::triggered, this, &GMainWindow::OnConfigure); @@ -876,10 +884,6 @@ void GMainWindow::ConnectMenuEvents() {      connect(ui.action_Reset_Window_Size, &QAction::triggered, this, &GMainWindow::ResetWindowSize);      // Fullscreen -    ui.action_Fullscreen->setShortcut( -        hotkey_registry -            .GetHotkey(QStringLiteral("Main Window"), QStringLiteral("Fullscreen"), this) -            ->key());      connect(ui.action_Fullscreen, &QAction::triggered, this, &GMainWindow::ToggleFullscreen);      // Movie @@ -1077,17 +1081,19 @@ void GMainWindow::BootGame(const QString& filename) {      const u64 title_id = Core::System::GetInstance().CurrentProcess()->GetTitleID();      std::string title_name; +    std::string title_version;      const auto res = Core::System::GetInstance().GetGameName(title_name); -    if (res != Loader::ResultStatus::Success) { -        const auto metadata = FileSys::PatchManager(title_id).GetControlMetadata(); -        if (metadata.first != nullptr) -            title_name = metadata.first->GetApplicationName(); -        if (title_name.empty()) -            title_name = FileUtil::GetFilename(filename.toStdString()); +    const auto metadata = FileSys::PatchManager(title_id).GetControlMetadata(); +    if (metadata.first != nullptr) { +        title_version = metadata.first->GetVersionString(); +        title_name = metadata.first->GetApplicationName();      } -    LOG_INFO(Frontend, "Booting game: {:016X} | {}", title_id, title_name); -    UpdateWindowTitle(QString::fromStdString(title_name)); +    if (res != Loader::ResultStatus::Success || title_name.empty()) { +        title_name = FileUtil::GetFilename(filename.toStdString()); +    } +    LOG_INFO(Frontend, "Booting game: {:016X} | {} | {}", title_id, title_name, title_version); +    UpdateWindowTitle(title_name, title_version);      loading_screen->Prepare(Core::System::GetInstance().GetAppLoader());      loading_screen->show(); @@ -1838,16 +1844,26 @@ void GMainWindow::OnMenuReportCompatibility() {      }  } -void GMainWindow::OnOpenModsPage() { -    const auto mods_page_url = QStringLiteral("https://github.com/yuzu-emu/yuzu/wiki/Switch-Mods"); -    const QUrl mods_page(mods_page_url); -    const bool open = QDesktopServices::openUrl(mods_page); +void GMainWindow::OpenURL(const QUrl& url) { +    const bool open = QDesktopServices::openUrl(url);      if (!open) {          QMessageBox::warning(this, tr("Error opening URL"), -                             tr("Unable to open the URL \"%1\".").arg(mods_page_url)); +                             tr("Unable to open the URL \"%1\".").arg(url.toString()));      }  } +void GMainWindow::OnOpenModsPage() { +    OpenURL(QUrl(QStringLiteral("https://github.com/yuzu-emu/yuzu/wiki/Switch-Mods"))); +} + +void GMainWindow::OnOpenQuickstartGuide() { +    OpenURL(QUrl(QStringLiteral("https://yuzu-emu.org/help/quickstart/"))); +} + +void GMainWindow::OnOpenFAQ() { +    OpenURL(QUrl(QStringLiteral("https://yuzu-emu.org/wiki/faq/"))); +} +  void GMainWindow::ToggleFullscreen() {      if (!emulation_running) {          return; @@ -2050,7 +2066,8 @@ void GMainWindow::OnCaptureScreenshot() {      OnStartGame();  } -void GMainWindow::UpdateWindowTitle(const QString& title_name) { +void GMainWindow::UpdateWindowTitle(const std::string& title_name, +                                    const std::string& title_version) {      const auto full_name = std::string(Common::g_build_fullname);      const auto branch_name = std::string(Common::g_scm_branch);      const auto description = std::string(Common::g_scm_desc); @@ -2059,7 +2076,7 @@ void GMainWindow::UpdateWindowTitle(const QString& title_name) {      const auto date =          QDateTime::currentDateTime().toString(QStringLiteral("yyyy-MM-dd")).toStdString(); -    if (title_name.isEmpty()) { +    if (title_name.empty()) {          const auto fmt = std::string(Common::g_title_bar_format_idle);          setWindowTitle(QString::fromStdString(fmt::format(fmt.empty() ? "yuzu {0}| {1}-{2}" : fmt,                                                            full_name, branch_name, description, @@ -2067,8 +2084,8 @@ void GMainWindow::UpdateWindowTitle(const QString& title_name) {      } else {          const auto fmt = std::string(Common::g_title_bar_format_running);          setWindowTitle(QString::fromStdString( -            fmt::format(fmt.empty() ? "yuzu {0}| {3} | {1}-{2}" : fmt, full_name, branch_name, -                        description, title_name.toStdString(), date, build_id))); +            fmt::format(fmt.empty() ? "yuzu {0}| {3} | {6} | {1}-{2}" : fmt, full_name, branch_name, +                        description, title_name, date, build_id, title_version)));      }  } @@ -2209,7 +2226,7 @@ void GMainWindow::OnReinitializeKeys(ReinitializeKeyBehavior behavior) {                           "title.keys_autogenerated");      } -    Core::Crypto::KeyManager keys{}; +    Core::Crypto::KeyManager& keys = Core::Crypto::KeyManager::Instance();      if (keys.BaseDeriveNecessary()) {          Core::Crypto::PartitionDataManager pdm{vfs->OpenDirectory(              FileUtil::GetUserPath(FileUtil::UserPath::SysDataDir), FileSys::Mode::Read)}; diff --git a/src/yuzu/main.h b/src/yuzu/main.h index 5581874ed..66c84e5c0 100644 --- a/src/yuzu/main.h +++ b/src/yuzu/main.h @@ -182,6 +182,8 @@ private slots:      void OnStopGame();      void OnMenuReportCompatibility();      void OnOpenModsPage(); +    void OnOpenQuickstartGuide(); +    void OnOpenFAQ();      /// Called whenever a user selects a game in the game list widget.      void OnGameListLoadFile(QString game_path);      void OnGameListOpenFolder(GameListOpenTarget target, const std::string& game_path); @@ -216,10 +218,12 @@ private slots:  private:      std::optional<u64> SelectRomFSDumpTarget(const FileSys::ContentProvider&, u64 program_id); -    void UpdateWindowTitle(const QString& title_name = {}); +    void UpdateWindowTitle(const std::string& title_name = {}, +                           const std::string& title_version = {});      void UpdateStatusBar();      void HideMouseCursor();      void ShowMouseCursor(); +    void OpenURL(const QUrl& url);      Ui::MainWindow ui; diff --git a/src/yuzu/main.ui b/src/yuzu/main.ui index b5745dfd5..bee6e107e 100644 --- a/src/yuzu/main.ui +++ b/src/yuzu/main.ui @@ -114,6 +114,8 @@      </property>      <addaction name="action_Report_Compatibility"/>      <addaction name="action_Open_Mods_Page"/> +    <addaction name="action_Open_Quickstart_Guide"/> +    <addaction name="action_Open_FAQ"/>      <addaction name="separator"/>      <addaction name="action_About"/>     </widget> @@ -262,6 +264,16 @@      <string>Open Mods Page</string>     </property>    </action> +  <action name="action_Open_Quickstart_Guide"> +   <property name="text"> +    <string>Open Quickstart Guide</string> +   </property> +  </action> +  <action name="action_Open_FAQ"> +   <property name="text"> +    <string>FAQ</string> +   </property> +  </action>    <action name="action_Open_yuzu_Folder">     <property name="text">      <string>Open yuzu Folder</string> | 
