mirror of
https://github.com/PabloMK7/citra.git
synced 2025-01-19 17:00:13 +00:00
(zhaowenlan1779) android/applets: Implement Mii Selector
See merge request CitraInternal/citra-android!33 # Conflicts: # src/android/app/src/main/jni/CMakeLists.txt # src/android/app/src/main/jni/id_cache.cpp # src/android/app/src/main/jni/native.cpp # src/android/app/src/main/res/values/strings.xml gl_shader_gen.cpp: Fix separable shaders when GL_EXT_clip_cull_distance is not supported
This commit is contained in:
parent
80799b1e5d
commit
a2109933f6
3 changed files with 46 additions and 35 deletions
|
@ -8,11 +8,7 @@
|
||||||
#include <QString>
|
#include <QString>
|
||||||
#include <QVBoxLayout>
|
#include <QVBoxLayout>
|
||||||
#include "citra_qt/applets/mii_selector.h"
|
#include "citra_qt/applets/mii_selector.h"
|
||||||
#include "common/file_util.h"
|
|
||||||
#include "common/string_util.h"
|
#include "common/string_util.h"
|
||||||
#include "core/file_sys/archive_extsavedata.h"
|
|
||||||
#include "core/file_sys/file_backend.h"
|
|
||||||
#include "core/hle/service/ptm/ptm.h"
|
|
||||||
|
|
||||||
QtMiiSelectorDialog::QtMiiSelectorDialog(QWidget* parent, QtMiiSelector* mii_selector_)
|
QtMiiSelectorDialog::QtMiiSelectorDialog(QWidget* parent, QtMiiSelector* mii_selector_)
|
||||||
: QDialog(parent), mii_selector(mii_selector_) {
|
: QDialog(parent), mii_selector(mii_selector_) {
|
||||||
|
@ -33,37 +29,9 @@ QtMiiSelectorDialog::QtMiiSelectorDialog(QWidget* parent, QtMiiSelector* mii_sel
|
||||||
|
|
||||||
miis.push_back(HLE::Applets::MiiSelector::GetStandardMiiResult().selected_mii_data);
|
miis.push_back(HLE::Applets::MiiSelector::GetStandardMiiResult().selected_mii_data);
|
||||||
combobox->addItem(tr("Standard Mii"));
|
combobox->addItem(tr("Standard Mii"));
|
||||||
|
for (const auto& mii : Frontend::LoadMiis()) {
|
||||||
std::string nand_directory{FileUtil::GetUserPath(FileUtil::UserPath::NANDDir)};
|
miis.push_back(mii);
|
||||||
FileSys::ArchiveFactory_ExtSaveData extdata_archive_factory(nand_directory, true);
|
combobox->addItem(QString::fromStdString(Common::UTF16BufferToUTF8(mii.mii_name)));
|
||||||
|
|
||||||
auto archive_result = extdata_archive_factory.Open(Service::PTM::ptm_shared_extdata_id, 0);
|
|
||||||
if (archive_result.Succeeded()) {
|
|
||||||
auto archive = std::move(archive_result).Unwrap();
|
|
||||||
|
|
||||||
FileSys::Path file_path = "/CFL_DB.dat";
|
|
||||||
FileSys::Mode mode{};
|
|
||||||
mode.read_flag.Assign(1);
|
|
||||||
|
|
||||||
auto file_result = archive->OpenFile(file_path, mode);
|
|
||||||
if (file_result.Succeeded()) {
|
|
||||||
auto file = std::move(file_result).Unwrap();
|
|
||||||
|
|
||||||
u32 saved_miis_offset = 0x8;
|
|
||||||
// The Mii Maker has a 100 Mii limit on the 3ds
|
|
||||||
for (int i = 0; i < 100; ++i) {
|
|
||||||
HLE::Applets::MiiData mii;
|
|
||||||
std::array<u8, sizeof(mii)> mii_raw;
|
|
||||||
file->Read(saved_miis_offset, sizeof(mii), mii_raw.data());
|
|
||||||
std::memcpy(&mii, mii_raw.data(), sizeof(mii));
|
|
||||||
if (mii.mii_id != 0) {
|
|
||||||
std::string name = Common::UTF16BufferToUTF8(mii.mii_name);
|
|
||||||
miis.push_back(mii);
|
|
||||||
combobox->addItem(QString::fromStdString(name));
|
|
||||||
}
|
|
||||||
saved_miis_offset += sizeof(mii);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
if (combobox->count() > static_cast<int>(config.initially_selected_mii_index)) {
|
if (combobox->count() > static_cast<int>(config.initially_selected_mii_index)) {
|
||||||
|
|
|
@ -2,7 +2,12 @@
|
||||||
// Licensed under GPLv2 or any later version
|
// Licensed under GPLv2 or any later version
|
||||||
// Refer to the license.txt file included.
|
// Refer to the license.txt file included.
|
||||||
|
|
||||||
|
#include "common/file_util.h"
|
||||||
|
#include "common/string_util.h"
|
||||||
|
#include "core/file_sys/archive_extsavedata.h"
|
||||||
|
#include "core/file_sys/file_backend.h"
|
||||||
#include "core/frontend/applets/mii_selector.h"
|
#include "core/frontend/applets/mii_selector.h"
|
||||||
|
#include "core/hle/service/ptm/ptm.h"
|
||||||
|
|
||||||
namespace Frontend {
|
namespace Frontend {
|
||||||
|
|
||||||
|
@ -10,6 +15,42 @@ void MiiSelector::Finalize(u32 return_code, HLE::Applets::MiiData mii) {
|
||||||
data = {return_code, mii};
|
data = {return_code, mii};
|
||||||
}
|
}
|
||||||
|
|
||||||
|
std::vector<HLE::Applets::MiiData> LoadMiis() {
|
||||||
|
std::vector<HLE::Applets::MiiData> miis;
|
||||||
|
|
||||||
|
std::string nand_directory{FileUtil::GetUserPath(FileUtil::UserPath::NANDDir)};
|
||||||
|
FileSys::ArchiveFactory_ExtSaveData extdata_archive_factory(nand_directory, true);
|
||||||
|
|
||||||
|
auto archive_result = extdata_archive_factory.Open(Service::PTM::ptm_shared_extdata_id, 0);
|
||||||
|
if (archive_result.Succeeded()) {
|
||||||
|
auto archive = std::move(archive_result).Unwrap();
|
||||||
|
|
||||||
|
FileSys::Path file_path = "/CFL_DB.dat";
|
||||||
|
FileSys::Mode mode{};
|
||||||
|
mode.read_flag.Assign(1);
|
||||||
|
|
||||||
|
auto file_result = archive->OpenFile(file_path, mode);
|
||||||
|
if (file_result.Succeeded()) {
|
||||||
|
auto file = std::move(file_result).Unwrap();
|
||||||
|
|
||||||
|
u32 saved_miis_offset = 0x8;
|
||||||
|
// The Mii Maker has a 100 Mii limit on the 3ds
|
||||||
|
for (int i = 0; i < 100; ++i) {
|
||||||
|
HLE::Applets::MiiData mii;
|
||||||
|
std::array<u8, sizeof(mii)> mii_raw;
|
||||||
|
file->Read(saved_miis_offset, sizeof(mii), mii_raw.data());
|
||||||
|
std::memcpy(&mii, mii_raw.data(), sizeof(mii));
|
||||||
|
if (mii.mii_id != 0) {
|
||||||
|
miis.push_back(mii);
|
||||||
|
}
|
||||||
|
saved_miis_offset += sizeof(mii);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
return miis;
|
||||||
|
}
|
||||||
|
|
||||||
void DefaultMiiSelector::Setup(const Frontend::MiiSelectorConfig& config) {
|
void DefaultMiiSelector::Setup(const Frontend::MiiSelectorConfig& config) {
|
||||||
MiiSelector::Setup(config);
|
MiiSelector::Setup(config);
|
||||||
Finalize(0, HLE::Applets::MiiSelector::GetStandardMiiResult().selected_mii_data);
|
Finalize(0, HLE::Applets::MiiSelector::GetStandardMiiResult().selected_mii_data);
|
||||||
|
|
|
@ -50,6 +50,8 @@ protected:
|
||||||
MiiSelectorData data;
|
MiiSelectorData data;
|
||||||
};
|
};
|
||||||
|
|
||||||
|
std::vector<HLE::Applets::MiiData> LoadMiis();
|
||||||
|
|
||||||
class DefaultMiiSelector final : public MiiSelector {
|
class DefaultMiiSelector final : public MiiSelector {
|
||||||
public:
|
public:
|
||||||
void Setup(const MiiSelectorConfig& config) override;
|
void Setup(const MiiSelectorConfig& config) override;
|
||||||
|
|
Loading…
Reference in a new issue