diff --git a/book.toml b/book.toml index 13d3dff..3069234 100644 --- a/book.toml +++ b/book.toml @@ -8,4 +8,4 @@ title = "UE4 Modding Guide" [output.html] default-theme = "navy" git-repository-url = "https://github.com/bananaturtlesandwich/UE4-Modding-Guide" -edit-url-template = "https://github.com/bananaturtlesandwich/UE4-Modding-Guide/edit/master/{path}" \ No newline at end of file +edit-url-template = "https://github.com/bananaturtlesandwich/UE4-Modding-Guide/edit/main/{path}" \ No newline at end of file diff --git a/src/Concepts/Concepts.md b/src/Concepts/Concepts.md index af30994..8fc2d4f 100644 --- a/src/Concepts/Concepts.md +++ b/src/Concepts/Concepts.md @@ -1,23 +1,3 @@ # Core UE4 Modding Concepts -### .pak files -- Pak files are essentially archive files that store most of the resources that the game in question requires to run (think differently structured .zip files) -- The game's main pak will always be contained in the `Content/Paks` directory -- Pak files will sometimes be encrypted via AES keys, however these can be easilyfound with [AESkeyFinder](https://zenhax.com/viewtopic.php?t=9407&start=20) -- Pak files can also be splitted into chunks for a bit of extra security -- Pak files are normally able to be viewed with [UEViewer](https://www.gildor.org/en/projects/umodel) or [Fmodel](https://fmodel.app/) -### Mod Loading -- Traditional mods are loaded as pak files in the same directory as the main game pak (these pak files are created using a tool such as [unrealpak](https://fluffyquack.com/tools/unrealpak.rar)) -- The content inside these paks files will just be content that has been created and then cooked using the same version of unreal as the game in question -- These mods will likely need a `_P` at the end of their name to remove the mount point of the pak and clarify it as a patch so that it overwrites original game content -- The mods should be place in a mod folder (`~mods` works for every game) to ensure proper load order (so the main game pak doesn't overwrite the mod's content) -- Paks are loaded alphabetically in each directory -- Mods can also be loaded via modloader frameworks such as the [Unreal Mod Loader](https://github.com/RussellJerome/UnrealModLoader) (a tool that allows the execution of any arbitrary blueprint code) and [UE4SS](https://github.com/UE4SS/UE4SS) (a tool that allows Lua scripting via reflection) -### Cooking -- Before being put in a pak file, assets undergo a process called cooking where the data used by the engine is erased so only the data needed for the game is in the final pak -- Cooked assets are not able to be edited in the engine however they can be edited through the use of programs such as [UAssetGUI](https://github.com/atenfyr/UAssetGUI) or [Asset Editor](https://github.com/kaiheilos/Utilities) -### .uasset,.umap,.uexp and .ubulk files -- Data is stored in .uasset or .umap files both before and after packaging(.umap files are only used for levels), however after cooking the file structure is different from the structure beforehand -- If the event driven loader is used by the game (introduced around version 4.15) then the cooked file is also split up into the .uasset and the .uexp for faster loading -- In the above case the .uasset/.umap file defines the structure of the asset while the associated .uexp holds the data -- In some cases where more external data is required a .ubulk file is generated which stores this external data such as baked lightmaps for levels +These are general concepts that must be understood if you are to do more in the field of unreal engine 4 modding \ No newline at end of file diff --git a/src/Concepts/Cooking.md b/src/Concepts/Cooking.md new file mode 100644 index 0000000..5c7c301 --- /dev/null +++ b/src/Concepts/Cooking.md @@ -0,0 +1,3 @@ +# Cooking +- Before being put in a pak file, assets undergo a process called cooking where the data used by the engine is erased so only the data needed for the game is in the final pak +- Cooked assets are not able to be edited in the engine however they can be edited through the use of programs such as [UAssetGUI](https://github.com/atenfyr/UAssetGUI) or [Asset Editor](https://github.com/kaiheilos/Utilities) \ No newline at end of file diff --git a/src/Concepts/Dummying.md b/src/Concepts/Dummying.md new file mode 100644 index 0000000..ff2e9c1 --- /dev/null +++ b/src/Concepts/Dummying.md @@ -0,0 +1,15 @@ +# Dummying +- There is a trick called dummying that can be utilised in many situations +- How it works is that you create an empty asset that is the same name and type as an asset in the original pak file +- Another asset will reference this and will contain references after cooking +- In final mod packaging, you omit the dummy asset but nothing else +- This means that in game instead of the dummy asset the other asset will use the asset in the pak + +- The most notable example of this is in mesh modding +- If you want the mesh to continue to use the materials it uses then you would dummy the materials and material instances that it uses +- In packaging these are removed and the mesh uses the original materials in game + +- Another interesting example is dummying an actor or function library to use a function +- The dummy asset is created and a function is added with the same name, parameters and output as the original one +- Another actor calls this function as normal +- The dummy is removed and the function is used as normal in-game \ No newline at end of file diff --git a/src/Concepts/Files.md b/src/Concepts/Files.md new file mode 100644 index 0000000..3b48163 --- /dev/null +++ b/src/Concepts/Files.md @@ -0,0 +1,5 @@ +# Unreal files +- Data is stored in .uasset or .umap files both before and after packaging(.umap files are only used for levels), however after cooking the file structure is different from the structure beforehand +- If the event driven loader is used by the game (introduced around version 4.15) then the cooked file is also split up into the .uasset and the .uexp for faster loading +- In the above case the .uasset/.umap file defines the structure of the asset while the associated .uexp holds the data +- In some cases where more external data is required a .ubulk file is generated which stores this external data such as baked lightmaps for levels \ No newline at end of file diff --git a/src/Concepts/Loading.md b/src/Concepts/Loading.md new file mode 100644 index 0000000..8cafa84 --- /dev/null +++ b/src/Concepts/Loading.md @@ -0,0 +1,7 @@ +# Mod Loading +- Traditional mods are loaded as pak files in the same directory as the main game pak (these pak files are created using a tool such as [unrealpak](https://fluffyquack.com/tools/unrealpak.rar)) +- The content inside these paks files will just be content that has been created and then cooked using the same version of unreal as the game in question +- These mods will likely need a `_P` at the end of their name to remove the mount point of the pak and clarify it as a patch so that it overwrites original game content +- The mods should be place in a mod folder (`~mods` works for every game) to ensure proper load order (so the main game pak doesn't overwrite the mod's content) +- Paks are loaded alphabetically in each directory +- Mods can also be loaded via modloader frameworks such as the [Unreal Mod Loader](https://github.com/RussellJerome/UnrealModLoader) (a tool that allows the execution of any arbitrary blueprint code) and [UE4SS](https://github.com/UE4SS/UE4SS) (a tool that allows Lua scripting via reflection) \ No newline at end of file diff --git a/src/Concepts/Paks.md b/src/Concepts/Paks.md new file mode 100644 index 0000000..168f2ac --- /dev/null +++ b/src/Concepts/Paks.md @@ -0,0 +1,7 @@ +# Pak files +- Pak files are essentially archive files that store most of the resources that the game in question requires to run (think of them as custom .zip files) +- The game's main pak will always be contained in the `Content/Paks` directory +- Pak files will sometimes be encrypted via AES keys, however these can be easilyfound with [AESKeyFinder](https://zenhax.com/viewtopic.php?t=9407&start=20) +- Pak files can also be split into chunks for a bit of extra security +- Pak files are normally able to be viewed with [UEViewer](https://www.gildor.org/en/projects/umodel) or [Fmodel](https://fmodel.app/) +- Pak files can be extracted using tools such as the ones found in [Pakers/Unpakers](../Tools/Pakers.md) \ No newline at end of file diff --git a/src/README.md b/src/Home.md similarity index 98% rename from src/README.md rename to src/Home.md index 5f86c0b..9de1c7f 100644 --- a/src/README.md +++ b/src/Home.md @@ -2,9 +2,9 @@ [![](https://img.shields.io/badge/Nexus%20page-orange?style=for-the-badge&logo=)](https://www.nexusmods.com/bluefire/) ![](https://img.shields.io/github/deployments/bananaturtlesandwich/Blue-Fire-Modding-Guide/github-pages?label=website%20build&style=for-the-badge) -- *If you wish to use this guide to rip assets out of a game and use them for your own benefit and not to mod, kindly **piss off*** +*If you wish to use this guide to rip assets out of a game and use them for your own benefit and not to mod, kindly **piss off*** - This is a general guide for Unreal Engine 4 game modding that uses Blue Fire for examples -- (*Unfortunately Blue Fire doesn't have a big enough modding scene to fascilitate a guide this detailed anyway*) +(*Unfortunately Blue Fire doesn't have a big enough modding scene to fascilitate a guide this detailed anyway*) ### Credits - FatihG_ and Fluffyquack for being patient with me at the start - [Buckminsterfullerene](https://github.com/Buckminsterfullerene02) for making the UE modding discord and pooling resources diff --git a/src/SUMMARY.md b/src/SUMMARY.md index 0304963..fe2a38e 100644 --- a/src/SUMMARY.md +++ b/src/SUMMARY.md @@ -1,9 +1,10 @@ # Summary -[Home Page](README.md) +[Home Page](Home.md) --- +# Starting out - [The Basics](The-Basics/Basics.md) - [Pak Decompression Options](The-Basics/Unpaking/Options.md) - [QuickBMS](The-Basics/Unpaking/QuickBMS.md) @@ -17,8 +18,14 @@ - [Cooking](The-Basics/Paking/Cooking.md) - [Final Packaging](The-Basics/Paking/Final-Paking.md) ---- +- [Core UE4 Modding Concepts](Concepts/Concepts.md) + - [Pak files](Concepts/Paks.md) + - [Mod Loading](Concepts/Loading.md) + - [Cooking](Concepts/Cooking.md) + - [Unreal files](Concepts/Files.md) + - [Dummying](Concepts/Dummying.md) +--- # Specific Guides - [Replacing models]() - [Disabling objects](Specific-Guides/Disabling.md) @@ -31,8 +38,6 @@ --- # Misc. - -- [Core UE4 Modding Concepts](Concepts/Concepts.md) - [Tools](Tools/Tools.md) - [Pakers/Unpakers](Tools/Pakers.md) - [Pak Explorers](Tools/Pak-Explorers.md) diff --git a/src/The-Basics/Basics.md b/src/The-Basics/Basics.md index 1853c96..007d548 100644 --- a/src/The-Basics/Basics.md +++ b/src/The-Basics/Basics.md @@ -7,5 +7,5 @@ You will need to know: ![](projectname.png) - The file path to your game's executable - `Game file path/Game name/Binaries/Win64` - The file path to where your game's content is stored - `Game file path/Game name/Content` -- the version of unreal your game uses - right-click the .exe > Properties > Details and the version of unreal is the File Version which should be in the format 4.XX.X - we only care abount the 4.XX because minor versions don't fundamentally change how content is configured +- the version of unreal your game uses - either hover over the .exe or right-click the .exe > Properties > Details and the version of unreal is the File Version which should be in the format 4.XX.X - we only care abount the 4.XX because minor versions don't fundamentally change how content is configured ![](version.png) \ No newline at end of file diff --git a/src/Tools/Libraries.md b/src/Tools/Libraries.md new file mode 100644 index 0000000..634a1df --- /dev/null +++ b/src/Tools/Libraries.md @@ -0,0 +1,13 @@ +# Libraries + ### Rust crates + - [uasset](https://docs.rs/uasset) + - [unreal unpak](https://docs.rs/rust-unreal-unpak) + - [unreal automation tools](https://docs.rs/cargo-uat) + ### Python + - [PyPakParser](https://pypi.org/project/PyPAKParser/) + ### C sharp + - [UassetAPI](https://github.com/atenfyr/UAssetAPI) + - [UETools](https://github.com/UETools/UETools) + - [UnSave](https://www.nuget.org/packages/UnSave) + - [UnSave.Extensions](https://www.nuget.org/packages/UnSave.Extensions) + - [PakReader](https://www.nuget.org/packages/PakReader/) \ No newline at end of file diff --git a/src/Tools/Pakers.md b/src/Tools/Pakers.md index a97e45f..c568d48 100644 --- a/src/Tools/Pakers.md +++ b/src/Tools/Pakers.md @@ -1,6 +1,8 @@ # Pakers/Unpakers These are tools that are capable of unpaking or creating pak archives +- [QuickBMS](https://aluigi.altervista.org/papers/quickbms.zip) by Luigi Auriemma and [unrealtournament.bms](https://aluigi.altervista.org/bms/unreal_tournament_4.bms) allow for fast unpaking of pak files + - [unrealpak scripts](https://fluffyquack.com/tools/unrealpak.rar) by [Fluffyquack](https://github.com/FluffyQuack) which allows creation of compressed pak files - [u4pak](https://github.com/panzi/u4pak) by [panzi](https://github.com/panzi) which can also mount, list and check pak files diff --git a/src/Tools/Tools.md b/src/Tools/Tools.md index a6a89ef..14c7827 100644 --- a/src/Tools/Tools.md +++ b/src/Tools/Tools.md @@ -1,19 +1,5 @@ # Tools This section is dedicated to listing down tools helpful in Unreal Engine 4 modding -### Blueprint modding - - The [Unreal Modloader](https://github.com/RussellJerome/UnrealModLoader) is a program by [RusselJ]() that allows the spawning of custom blueprint code at runtime -### Assorted libraries - ### Rust crates - - [uasset](https://docs.rs/uasset) - - [unreal unpak](https://docs.rs/rust-unreal-unpak) - - [unreal automation tools](https://docs.rs/cargo-uat) - ### Python - - [PyPakParser](https://pypi.org/project/PyPAKParser/) - ### C sharp - - [UassetAPI](https://github.com/atenfyr/UAssetAPI) - - [UETools](https://github.com/UETools/UETools) - - [UnSave](https://www.nuget.org/packages/UnSave) - - [UnSave.Extensions](https://www.nuget.org/packages/UnSave.Extensions) - - [PakReader](https://www.nuget.org/packages/PakReader/) \ No newline at end of file +This covers pretty much everything useful I could find for *general* UE4 modding \ No newline at end of file