diff --git a/README.md b/README.md index d291a55..2e91fd0 100644 --- a/README.md +++ b/README.md @@ -40,21 +40,22 @@ - 配置项位于 `scsp-config.json` 文件中 -| 配置项 | 类型 | 默认值 | 说明 | -| --------------------- | ---------------------------------------- | -------------------------------------- | ---------------------------------------------------- | -| enableConsole | Bool | `true` | 是否开启控制台 | -| enableVSync | Bool | `false` | 是否启用垂直同步 | -| maxFps | Int | `60` | 最大帧数
当启用 `enableVSync` 时,此项配置失效 | -| 3DResolutionScale | Float | `1.0` | 3D 渲染分辨率倍率 | -| localifyBasePath | String | `scsp_localify` | 本地化文件目录 | -| hotKey | String (Char) | `u` | 按下 `Ctrl` + 此项配置的热键,**打开插件 GUI** | -| dumpUntransLyrics | Bool | `false` | dump 未翻译的歌词 | -| dumpUntransLocal2 | Bool | `false` | dump 未翻译的文本 | -| autoDumpAllJson | Bool | `false` | dump 所有游戏加载的 JSON | -| extraAssetBundlePaths | String[] | `["scsp_localify/scsp-bundle"]` | 自定义数据包路径 | -| customFontPath | String | `assets/font/sbtphumminge-regular.ttf` | 自定义数据包中字体路径
用于替换游戏内置字体 | -| blockOutOfFocus | Bool | `true` | 拦截窗口失焦事件
切换到其它窗口后不会触发游戏暂停 | -| baseFreeCamera | [BaseFreeCamera](#BaseFreeCamera) Object | [BaseFreeCamera](#BaseFreeCamera) | 自由视角配置 | +| 配置项 | 类型 | 默认值 | 说明 | +| -------------------------- | ---------------------------------------- | -------------------------------------- | ---------------------------------------------------- | +| enableConsole | Bool | `true` | 是否开启控制台 | +| enableVSync | Bool | `false` | 是否启用垂直同步 | +| maxFps | Int | `60` | 最大帧数
当启用 `enableVSync` 时,此项配置失效 | +| 3DResolutionScale | Float | `1.0` | 3D 渲染分辨率倍率 | +| localifyBasePath | String | `scsp_localify` | 本地化文件目录 | +| hotKey | String (Char) | `u` | 按下 `Ctrl` + 此项配置的热键,**打开插件 GUI** | +| dumpUntransLyrics | Bool | `false` | dump 未翻译的歌词 | +| dumpUntransLocal2 | Bool | `false` | dump 未翻译的文本 | +| autoDumpAllJson | Bool | `false` | dump 所有游戏加载的 JSON | +| extraAssetBundlePaths | String[] | `["scsp_localify/scsp-bundle"]` | 自定义数据包路径 | +| customFontPath | String | `assets/font/sbtphumminge-regular.ttf` | 自定义数据包中字体路径
用于替换游戏内置字体 | +| blockOutOfFocus | Bool | `true` | 拦截窗口失焦事件
切换到其它窗口后不会触发游戏暂停 | +| baseFreeCamera | [BaseFreeCamera](#BaseFreeCamera) Object | [BaseFreeCamera](#BaseFreeCamera) | 自由视角配置 | +| unlockPIdolAndSCharaEvents | Bool | `false` | 解锁 `角色` - `一览` 中的P卡和S卡事件 | diff --git a/readme_EN.md b/readme_EN.md index d4812f8..cbaeb13 100644 --- a/readme_EN.md +++ b/readme_EN.md @@ -54,6 +54,7 @@ iM@S SCSP localify plugin. | customFontPath | String | `assets/font/sbtphumminge-regular.ttf` | Custom font path in asset bundles
Used for replacing built-in fonts in the game | | blockOutOfFocus | Bool | `true` | Intercept window out-of-focus events
Game won't pause when switching to other windows | | baseFreeCamera | [BaseFreeCamera](#BaseFreeCamera) Object | [BaseFreeCamera](#BaseFreeCamera) | Free camera configuration | +| unlockPIdolAndSCharaEvents | Bool | `false` | Unlock Idol Event (アイドルイベント) and Support Event (サポートイベント) in `Characters` - `Overview` | diff --git a/resources/scsp-config.json b/resources/scsp-config.json index 93f9711..9b2a693 100644 --- a/resources/scsp-config.json +++ b/resources/scsp-config.json @@ -18,5 +18,6 @@ "enable": false, "moveStep": 50, "mouseSpeed": 35 - } + }, + "unlockPIdolAndSCharaEvents": false } \ No newline at end of file diff --git a/src/hook.cpp b/src/hook.cpp index c7be9fd..8a774b5 100644 --- a/src/hook.cpp +++ b/src/hook.cpp @@ -593,6 +593,48 @@ namespace } + // NOT HOOK + void* PIdolDetailPopupViewModel_Create_orig; + void* PIdolDetailPopupViewModel_Create_hook(void* produceIdol, void* costumeSetInfoList, void* idolBase, void* idolParameter, bool isChangeableIdolSkill, bool isChangeableFavorite, void* produceAdvStatusList, bool isPlayableAdv, bool inLive, bool upgradingButtonActive) { + auto ret = reinterpret_cast(PIdolDetailPopupViewModel_Create_orig)( + produceIdol, costumeSetInfoList, idolBase, idolParameter, isChangeableIdolSkill, isChangeableFavorite, produceAdvStatusList, isPlayableAdv, inLive, upgradingButtonActive + ); + return ret; + /* // 功能被 EventModel_ctor_hook 替代 + static auto get_EventList = reinterpret_cast( + il2cpp_symbols::get_method_pointer("PRISM.Adapters.dll", "PRISM.Adapters", + "PIdolDetailPopupViewModel", "get_EventList", 0) + ); + static auto EventModel_klass = il2cpp_symbols::get_class("PRISM.Adapters.dll", "PRISM.Adapters", "EventModel"); + static auto Read_field = il2cpp_class_get_field_from_name(EventModel_klass, "k__BackingField"); + static auto IsAdvPlayable_field = il2cpp_class_get_field_from_name(EventModel_klass, "k__BackingField"); + + printf("PIdolDetailPopupViewModel_Create\n"); + + auto events = get_EventList(ret); + + il2cpp_symbols::iterate_IEnumerable(events, [](void* event) { + const auto read = il2cpp_symbols::read_field(event, Read_field); + const auto isAdvPlayable = il2cpp_symbols::read_field(event, IsAdvPlayable_field); + printf("read: %d, isAdvPlayable: %d\n", read, isAdvPlayable); + + il2cpp_symbols::write_field(event, Read_field, true); + }); + + return ret;*/ + } + + void* EventModel_ctor_orig; + void EventModel_ctor_hook(void* _this, void* scenarioID, Il2CppString* title, Il2CppString* summary, bool read, bool isAdvPlayable) { + if (g_unlock_PIdol_and_SChara_events) { + if (!read) { + wprintf(L"Force Unlock Event: %ls\n", title->start_char); + read = true; + } + } + return reinterpret_cast(EventModel_ctor_orig)(_this, scenarioID, title, summary, read, isAdvPlayable); + } + void* LocalizationManager_GetTextOrNull_orig; Il2CppString* LocalizationManager_GetTextOrNull_hook(void* _this, Il2CppString* category, int id) { if (g_max_fps != -1) set_fps_hook(g_max_fps); @@ -2025,6 +2067,15 @@ namespace "TextLog", "AddLog", 4 ); + auto PIdolDetailPopupViewModel_Create_addr = il2cpp_symbols::get_method_pointer( + "PRISM.Adapters.dll", "PRISM.Adapters", + "PIdolDetailPopupViewModel", "Create", 10 + ); + auto EventModel_ctor_addr = il2cpp_symbols::get_method_pointer( + "PRISM.Adapters.dll", "PRISM.Adapters", + "EventModel", ".ctor", 5 + ); + auto LocalizationManager_GetTextOrNull_addr = il2cpp_symbols::get_method_pointer( "ENTERPRISE.Localization.dll", "ENTERPRISE.Localization", "LocalizationManager", "GetTextOrNull", 2 @@ -2215,6 +2266,8 @@ namespace ); #pragma endregion + // ADD_HOOK(PIdolDetailPopupViewModel_Create, "PIdolDetailPopupViewModel_Create at %p"); + ADD_HOOK(EventModel_ctor, "EventModel_ctor at %p"); ADD_HOOK(LocalizationManager_GetTextOrNull, "LocalizationManager_GetTextOrNull at %p"); ADD_HOOK(get_NeedsLocalization, "get_NeedsLocalization at %p"); ADD_HOOK(GetResolutionSize, "GetResolutionSize at %p"); diff --git a/src/main.cpp b/src/main.cpp index c9279f7..e9358cf 100644 --- a/src/main.cpp +++ b/src/main.cpp @@ -43,6 +43,7 @@ bool g_allow_same_idol = false; bool g_unlock_all_dress = false; bool g_unlock_all_headwear = false; bool g_enable_chara_param_edit = false; +bool g_unlock_PIdol_and_SChara_events = false; std::filesystem::path g_localify_base("scsp_localify"); constexpr const char ConfigJson[] = "scsp-config.json"; @@ -180,6 +181,9 @@ namespace if (document.HasMember("unlockAllHeadwear")) { g_unlock_all_headwear = document["unlockAllHeadwear"].GetBool() && g_unlock_all_dress; } + if (document.HasMember("unlockPIdolAndSCharaEvents")) { + g_unlock_PIdol_and_SChara_events = document["unlockPIdolAndSCharaEvents"].GetBool(); + } } diff --git a/src/scgui/scGUILoop.cpp b/src/scgui/scGUILoop.cpp index 8ffa1d7..77107df 100644 --- a/src/scgui/scGUILoop.cpp +++ b/src/scgui/scGUILoop.cpp @@ -172,6 +172,10 @@ namespace SCGUILoop { ImGui::SameLine(); HELP_TOOLTIP("(?)", "启用角色身体参数编辑器") + ImGui::Checkbox("Unlock PIdol And SChara Events", &g_unlock_PIdol_and_SChara_events); + ImGui::SameLine(); + HELP_TOOLTIP("(?)", "解锁 角色 - 一览 中的P卡和S卡事件\nUnlock Idol Event (アイドルイベント) and Support Event (サポートイベント)") + if (ImGui::CollapsingHeader("Resolution Settings", ImGuiTreeNodeFlags_DefaultOpen)) { ImGui::Text("Window Resolution Settings"); diff --git a/src/stdinclude.hpp b/src/stdinclude.hpp index 3ed7566..9ebbdfb 100644 --- a/src/stdinclude.hpp +++ b/src/stdinclude.hpp @@ -175,3 +175,4 @@ extern bool g_unlock_all_headwear; extern bool g_enable_chara_param_edit; extern float g_font_size_offset; extern float g_3d_resolution_scale; +extern bool g_unlock_PIdol_and_SChara_events;