mirror of
				https://github.com/Laupetin/OpenAssetTools.git
				synced 2025-10-24 23:35:52 +00:00 
			
		
		
		
	refactor: restructure image dumper
This commit is contained in:
		| @@ -1,7 +1,8 @@ | ||||
| #include "AssetDumperGfxImage.h" | ||||
| #include "ImageDumperIW3.h" | ||||
| 
 | ||||
| #include "Image/DdsWriter.h" | ||||
| #include "Image/Dx9TextureLoader.h" | ||||
| #include "Image/ImageCommon.h" | ||||
| #include "Image/IwiLoader.h" | ||||
| #include "Image/IwiTypes.h" | ||||
| #include "Image/IwiWriter6.h" | ||||
| @@ -13,7 +14,9 @@ | ||||
| #include <cassert> | ||||
| #include <format> | ||||
| 
 | ||||
| 
 | ||||
| using namespace IW3; | ||||
| using namespace ::image; | ||||
| 
 | ||||
| namespace | ||||
| { | ||||
| @@ -58,48 +61,43 @@ namespace | ||||
|     } | ||||
| } // namespace
 | ||||
| 
 | ||||
| AssetDumperGfxImage::AssetDumperGfxImage() | ||||
| namespace IW3::image | ||||
| { | ||||
|     switch (ObjWriting::Configuration.ImageOutputFormat) | ||||
|     Dumper::Dumper() | ||||
|     { | ||||
|     case ObjWriting::Configuration_t::ImageOutputFormat_e::DDS: | ||||
|         m_writer = std::make_unique<DdsWriter>(); | ||||
|         break; | ||||
|     case ObjWriting::Configuration_t::ImageOutputFormat_e::IWI: | ||||
|         m_writer = std::make_unique<iwi6::IwiWriter>(); | ||||
|         break; | ||||
|     default: | ||||
|         assert(false); | ||||
|         m_writer = nullptr; | ||||
|         break; | ||||
|         switch (ObjWriting::Configuration.ImageOutputFormat) | ||||
|         { | ||||
|         case ObjWriting::Configuration_t::ImageOutputFormat_e::DDS: | ||||
|             m_writer = std::make_unique<DdsWriter>(); | ||||
|             break; | ||||
|         case ObjWriting::Configuration_t::ImageOutputFormat_e::IWI: | ||||
|             m_writer = std::make_unique<iwi6::IwiWriter>(); | ||||
|             break; | ||||
|         default: | ||||
|             assert(false); | ||||
|             m_writer = nullptr; | ||||
|             break; | ||||
|         } | ||||
|     } | ||||
| } | ||||
| 
 | ||||
| bool AssetDumperGfxImage::ShouldDump(XAssetInfo<GfxImage>* asset) | ||||
| { | ||||
|     return true; | ||||
| } | ||||
|     bool Dumper::ShouldDump(XAssetInfo<GfxImage>* asset) | ||||
|     { | ||||
|         return true; | ||||
|     } | ||||
| 
 | ||||
| std::string AssetDumperGfxImage::GetAssetFileName(const XAssetInfo<GfxImage>& asset) const | ||||
| { | ||||
|     auto cleanAssetName = asset.m_name; | ||||
|     std::ranges::replace(cleanAssetName, '*', '_'); | ||||
|     void Dumper::DumpAsset(AssetDumpingContext& context, XAssetInfo<GfxImage>* asset) | ||||
|     { | ||||
|         const auto* image = asset->Asset(); | ||||
|         const auto texture = LoadImageData(context.m_obj_search_path, *image); | ||||
|         if (!texture) | ||||
|             return; | ||||
| 
 | ||||
|     return std::format("images/{}{}", cleanAssetName, m_writer->GetFileExtension()); | ||||
| } | ||||
|         const auto assetFile = context.OpenAssetFile(GetFileNameForAsset(asset->m_name, m_writer->GetFileExtension())); | ||||
| 
 | ||||
| void AssetDumperGfxImage::DumpAsset(AssetDumpingContext& context, XAssetInfo<GfxImage>* asset) | ||||
| { | ||||
|     const auto* image = asset->Asset(); | ||||
|     const auto texture = LoadImageData(context.m_obj_search_path, *image); | ||||
|     if (!texture) | ||||
|         return; | ||||
|         if (!assetFile) | ||||
|             return; | ||||
| 
 | ||||
|     const auto assetFile = context.OpenAssetFile(GetAssetFileName(*asset)); | ||||
| 
 | ||||
|     if (!assetFile) | ||||
|         return; | ||||
| 
 | ||||
|     auto& stream = *assetFile; | ||||
|     m_writer->DumpImage(stream, texture.get()); | ||||
| } | ||||
|         auto& stream = *assetFile; | ||||
|         m_writer->DumpImage(stream, texture.get()); | ||||
|     } | ||||
| } // namespace IW3::image
 | ||||
| @@ -6,19 +6,18 @@ | ||||
| 
 | ||||
| #include <memory> | ||||
| 
 | ||||
| namespace IW3 | ||||
| namespace IW3::image | ||||
| { | ||||
|     class AssetDumperGfxImage final : public AbstractAssetDumper<GfxImage> | ||||
|     class Dumper final : public AbstractAssetDumper<GfxImage> | ||||
|     { | ||||
|         std::unique_ptr<IImageWriter> m_writer; | ||||
| 
 | ||||
|         [[nodiscard]] std::string GetAssetFileName(const XAssetInfo<GfxImage>& asset) const; | ||||
|     public: | ||||
|         Dumper(); | ||||
| 
 | ||||
|     protected: | ||||
|         bool ShouldDump(XAssetInfo<GfxImage>* asset) override; | ||||
|         void DumpAsset(AssetDumpingContext& context, XAssetInfo<GfxImage>* asset) override; | ||||
| 
 | ||||
|     public: | ||||
|         AssetDumperGfxImage(); | ||||
|     private: | ||||
|         std::unique_ptr<IImageWriter> m_writer; | ||||
|     }; | ||||
| } // namespace IW3
 | ||||
| } // namespace IW3::image
 | ||||
| @@ -2,7 +2,7 @@ | ||||
|  | ||||
| #include "Game/IW3/GameAssetPoolIW3.h" | ||||
| #include "Game/IW3/XModel/XModelDumperIW3.h" | ||||
| #include "Image/AssetDumperGfxImage.h" | ||||
| #include "Image/ImageDumperIW3.h" | ||||
| #include "Localize/AssetDumperLocalizeEntry.h" | ||||
| #include "Maps/AssetDumperMapEnts.h" | ||||
| #include "Material/DumperMaterialIW3.h" | ||||
| @@ -30,7 +30,7 @@ bool ObjWriter::DumpZone(AssetDumpingContext& context) const | ||||
|     DUMP_ASSET_POOL(AssetDumperXModel, m_xmodel, ASSET_TYPE_XMODEL) | ||||
|     DUMP_ASSET_POOL(AssetDumperMaterial, m_material, ASSET_TYPE_MATERIAL) | ||||
|     // DUMP_ASSET_POOL(AssetDumperMaterialTechniqueSet, m_technique_set, ASSET_TYPE_TECHNIQUE_SET) | ||||
|     DUMP_ASSET_POOL(AssetDumperGfxImage, m_image, ASSET_TYPE_IMAGE) | ||||
|     DUMP_ASSET_POOL(image::Dumper, m_image, ASSET_TYPE_IMAGE) | ||||
|     // DUMP_ASSET_POOL(AssetDumpersnd_alias_list_t, m_sound, ASSET_TYPE_SOUND) | ||||
|     // DUMP_ASSET_POOL(AssetDumperSndCurve, m_sound_curve, ASSET_TYPE_SOUND_CURVE) | ||||
|     DUMP_ASSET_POOL(AssetDumperLoadedSound, m_loaded_sound, ASSET_TYPE_LOADED_SOUND) | ||||
|   | ||||
| @@ -1,7 +1,8 @@ | ||||
| #include "AssetDumperGfxImage.h" | ||||
| #include "ImageDumperIW4.h" | ||||
| 
 | ||||
| #include "Image/DdsWriter.h" | ||||
| #include "Image/Dx9TextureLoader.h" | ||||
| #include "Image/ImageCommon.h" | ||||
| #include "Image/IwiLoader.h" | ||||
| #include "Image/IwiWriter8.h" | ||||
| #include "ObjWriting.h" | ||||
| @@ -11,6 +12,7 @@ | ||||
| #include <format> | ||||
| 
 | ||||
| using namespace IW4; | ||||
| using namespace ::image; | ||||
| 
 | ||||
| namespace | ||||
| { | ||||
| @@ -55,48 +57,43 @@ namespace | ||||
|     } | ||||
| } // namespace
 | ||||
| 
 | ||||
| AssetDumperGfxImage::AssetDumperGfxImage() | ||||
| namespace IW4::image | ||||
| { | ||||
|     switch (ObjWriting::Configuration.ImageOutputFormat) | ||||
|     Dumper::Dumper() | ||||
|     { | ||||
|     case ObjWriting::Configuration_t::ImageOutputFormat_e::DDS: | ||||
|         m_writer = std::make_unique<DdsWriter>(); | ||||
|         break; | ||||
|     case ObjWriting::Configuration_t::ImageOutputFormat_e::IWI: | ||||
|         m_writer = std::make_unique<iwi8::IwiWriter>(); | ||||
|         break; | ||||
|     default: | ||||
|         assert(false); | ||||
|         m_writer = nullptr; | ||||
|         break; | ||||
|         switch (ObjWriting::Configuration.ImageOutputFormat) | ||||
|         { | ||||
|         case ObjWriting::Configuration_t::ImageOutputFormat_e::DDS: | ||||
|             m_writer = std::make_unique<DdsWriter>(); | ||||
|             break; | ||||
|         case ObjWriting::Configuration_t::ImageOutputFormat_e::IWI: | ||||
|             m_writer = std::make_unique<iwi8::IwiWriter>(); | ||||
|             break; | ||||
|         default: | ||||
|             assert(false); | ||||
|             m_writer = nullptr; | ||||
|             break; | ||||
|         } | ||||
|     } | ||||
| } | ||||
| 
 | ||||
| bool AssetDumperGfxImage::ShouldDump(XAssetInfo<GfxImage>* asset) | ||||
| { | ||||
|     return true; | ||||
| } | ||||
|     bool Dumper::ShouldDump(XAssetInfo<GfxImage>* asset) | ||||
|     { | ||||
|         return true; | ||||
|     } | ||||
| 
 | ||||
| std::string AssetDumperGfxImage::GetAssetFileName(const XAssetInfo<GfxImage>& asset) const | ||||
| { | ||||
|     auto cleanAssetName = asset.m_name; | ||||
|     std::ranges::replace(cleanAssetName, '*', '_'); | ||||
|     void Dumper::DumpAsset(AssetDumpingContext& context, XAssetInfo<GfxImage>* asset) | ||||
|     { | ||||
|         const auto* image = asset->Asset(); | ||||
|         const auto texture = LoadImageData(context.m_obj_search_path, *image); | ||||
|         if (!texture) | ||||
|             return; | ||||
| 
 | ||||
|     return std::format("images/{}{}", cleanAssetName, m_writer->GetFileExtension()); | ||||
| } | ||||
|         const auto assetFile = context.OpenAssetFile(GetFileNameForAsset(asset->m_name, m_writer->GetFileExtension())); | ||||
| 
 | ||||
| void AssetDumperGfxImage::DumpAsset(AssetDumpingContext& context, XAssetInfo<GfxImage>* asset) | ||||
| { | ||||
|     const auto* image = asset->Asset(); | ||||
|     const auto texture = LoadImageData(context.m_obj_search_path, *image); | ||||
|     if (!texture) | ||||
|         return; | ||||
|         if (!assetFile) | ||||
|             return; | ||||
| 
 | ||||
|     const auto assetFile = context.OpenAssetFile(GetAssetFileName(*asset)); | ||||
| 
 | ||||
|     if (!assetFile) | ||||
|         return; | ||||
| 
 | ||||
|     auto& stream = *assetFile; | ||||
|     m_writer->DumpImage(stream, texture.get()); | ||||
| } | ||||
|         auto& stream = *assetFile; | ||||
|         m_writer->DumpImage(stream, texture.get()); | ||||
|     } | ||||
| } // namespace IW4::image
 | ||||
| @@ -6,19 +6,18 @@ | ||||
| 
 | ||||
| #include <memory> | ||||
| 
 | ||||
| namespace IW4 | ||||
| namespace IW4::image | ||||
| { | ||||
|     class AssetDumperGfxImage final : public AbstractAssetDumper<GfxImage> | ||||
|     class Dumper final : public AbstractAssetDumper<GfxImage> | ||||
|     { | ||||
|         std::unique_ptr<IImageWriter> m_writer; | ||||
| 
 | ||||
|         [[nodiscard]] std::string GetAssetFileName(const XAssetInfo<GfxImage>& asset) const; | ||||
|     public: | ||||
|         Dumper(); | ||||
| 
 | ||||
|     protected: | ||||
|         bool ShouldDump(XAssetInfo<GfxImage>* asset) override; | ||||
|         void DumpAsset(AssetDumpingContext& context, XAssetInfo<GfxImage>* asset) override; | ||||
| 
 | ||||
|     public: | ||||
|         AssetDumperGfxImage(); | ||||
|     private: | ||||
|         std::unique_ptr<IImageWriter> m_writer; | ||||
|     }; | ||||
| } // namespace IW4
 | ||||
| } // namespace IW4::image
 | ||||
| @@ -2,7 +2,7 @@ | ||||
|  | ||||
| #include "Game/IW4/GameAssetPoolIW4.h" | ||||
| #include "Game/IW4/XModel/XModelDumperIW4.h" | ||||
| #include "Image/AssetDumperGfxImage.h" | ||||
| #include "Image/ImageDumperIW4.h" | ||||
| #include "Leaderboard/LeaderboardJsonDumperIW4.h" | ||||
| #include "LightDef/LightDefDumperIW4.h" | ||||
| #include "Localize/AssetDumperLocalizeEntry.h" | ||||
| @@ -46,7 +46,7 @@ bool ObjWriter::DumpZone(AssetDumpingContext& context) const | ||||
|     DUMP_ASSET_POOL(AssetDumperPixelShader, m_material_pixel_shader, ASSET_TYPE_PIXELSHADER) | ||||
|     DUMP_ASSET_POOL(AssetDumperVertexShader, m_material_vertex_shader, ASSET_TYPE_VERTEXSHADER) | ||||
|     DUMP_ASSET_POOL(AssetDumperTechniqueSet, m_technique_set, ASSET_TYPE_TECHNIQUE_SET) | ||||
|     DUMP_ASSET_POOL(AssetDumperGfxImage, m_image, ASSET_TYPE_IMAGE) | ||||
|     DUMP_ASSET_POOL(image::Dumper, m_image, ASSET_TYPE_IMAGE) | ||||
|     // DUMP_ASSET_POOL(AssetDumpersnd_alias_list_t, m_sound, ASSET_TYPE_SOUND) | ||||
|     DUMP_ASSET_POOL(AssetDumperSndCurve, m_sound_curve, ASSET_TYPE_SOUND_CURVE) | ||||
|     DUMP_ASSET_POOL(AssetDumperLoadedSound, m_loaded_sound, ASSET_TYPE_LOADED_SOUND) | ||||
|   | ||||
| @@ -1,7 +1,8 @@ | ||||
| #include "AssetDumperGfxImage.h" | ||||
| #include "ImageDumperIW5.h" | ||||
| 
 | ||||
| #include "Image/DdsWriter.h" | ||||
| #include "Image/Dx9TextureLoader.h" | ||||
| #include "Image/ImageCommon.h" | ||||
| #include "Image/IwiLoader.h" | ||||
| #include "Image/IwiWriter8.h" | ||||
| #include "ObjWriting.h" | ||||
| @@ -10,7 +11,9 @@ | ||||
| #include <cassert> | ||||
| #include <format> | ||||
| 
 | ||||
| 
 | ||||
| using namespace IW5; | ||||
| using namespace ::image; | ||||
| 
 | ||||
| namespace | ||||
| { | ||||
| @@ -56,48 +59,43 @@ namespace | ||||
|     } | ||||
| } // namespace
 | ||||
| 
 | ||||
| AssetDumperGfxImage::AssetDumperGfxImage() | ||||
| namespace IW5::image | ||||
| { | ||||
|     switch (ObjWriting::Configuration.ImageOutputFormat) | ||||
|     Dumper::Dumper() | ||||
|     { | ||||
|     case ObjWriting::Configuration_t::ImageOutputFormat_e::DDS: | ||||
|         m_writer = std::make_unique<DdsWriter>(); | ||||
|         break; | ||||
|     case ObjWriting::Configuration_t::ImageOutputFormat_e::IWI: | ||||
|         m_writer = std::make_unique<iwi8::IwiWriter>(); | ||||
|         break; | ||||
|     default: | ||||
|         assert(false); | ||||
|         m_writer = nullptr; | ||||
|         break; | ||||
|         switch (ObjWriting::Configuration.ImageOutputFormat) | ||||
|         { | ||||
|         case ObjWriting::Configuration_t::ImageOutputFormat_e::DDS: | ||||
|             m_writer = std::make_unique<DdsWriter>(); | ||||
|             break; | ||||
|         case ObjWriting::Configuration_t::ImageOutputFormat_e::IWI: | ||||
|             m_writer = std::make_unique<iwi8::IwiWriter>(); | ||||
|             break; | ||||
|         default: | ||||
|             assert(false); | ||||
|             m_writer = nullptr; | ||||
|             break; | ||||
|         } | ||||
|     } | ||||
| } | ||||
| 
 | ||||
| bool AssetDumperGfxImage::ShouldDump(XAssetInfo<GfxImage>* asset) | ||||
| { | ||||
|     return true; | ||||
| } | ||||
|     bool Dumper::ShouldDump(XAssetInfo<GfxImage>* asset) | ||||
|     { | ||||
|         return true; | ||||
|     } | ||||
| 
 | ||||
| std::string AssetDumperGfxImage::GetAssetFileName(const XAssetInfo<GfxImage>& asset) const | ||||
| { | ||||
|     auto cleanAssetName = asset.m_name; | ||||
|     std::ranges::replace(cleanAssetName, '*', '_'); | ||||
|     void Dumper::DumpAsset(AssetDumpingContext& context, XAssetInfo<GfxImage>* asset) | ||||
|     { | ||||
|         const auto* image = asset->Asset(); | ||||
|         const auto texture = LoadImageData(context.m_obj_search_path, *image); | ||||
|         if (!texture) | ||||
|             return; | ||||
| 
 | ||||
|     return std::format("images/{}{}", cleanAssetName, m_writer->GetFileExtension()); | ||||
| } | ||||
|         const auto assetFile = context.OpenAssetFile(GetFileNameForAsset(asset->m_name, m_writer->GetFileExtension())); | ||||
| 
 | ||||
| void AssetDumperGfxImage::DumpAsset(AssetDumpingContext& context, XAssetInfo<GfxImage>* asset) | ||||
| { | ||||
|     const auto* image = asset->Asset(); | ||||
|     const auto texture = LoadImageData(context.m_obj_search_path, *image); | ||||
|     if (!texture) | ||||
|         return; | ||||
|         if (!assetFile) | ||||
|             return; | ||||
| 
 | ||||
|     const auto assetFile = context.OpenAssetFile(GetAssetFileName(*asset)); | ||||
| 
 | ||||
|     if (!assetFile) | ||||
|         return; | ||||
| 
 | ||||
|     auto& stream = *assetFile; | ||||
|     m_writer->DumpImage(stream, texture.get()); | ||||
| } | ||||
|         auto& stream = *assetFile; | ||||
|         m_writer->DumpImage(stream, texture.get()); | ||||
|     } | ||||
| } // namespace IW5::image
 | ||||
| @@ -6,19 +6,18 @@ | ||||
| 
 | ||||
| #include <memory> | ||||
| 
 | ||||
| namespace IW5 | ||||
| namespace IW5::image | ||||
| { | ||||
|     class AssetDumperGfxImage final : public AbstractAssetDumper<GfxImage> | ||||
|     class Dumper final : public AbstractAssetDumper<GfxImage> | ||||
|     { | ||||
|         std::unique_ptr<IImageWriter> m_writer; | ||||
| 
 | ||||
|         [[nodiscard]] std::string GetAssetFileName(const XAssetInfo<GfxImage>& asset) const; | ||||
|     public: | ||||
|         Dumper(); | ||||
| 
 | ||||
|     protected: | ||||
|         bool ShouldDump(XAssetInfo<GfxImage>* asset) override; | ||||
|         void DumpAsset(AssetDumpingContext& context, XAssetInfo<GfxImage>* asset) override; | ||||
| 
 | ||||
|     public: | ||||
|         AssetDumperGfxImage(); | ||||
|     private: | ||||
|         std::unique_ptr<IImageWriter> m_writer; | ||||
|     }; | ||||
| } // namespace IW5
 | ||||
| } // namespace IW5::image
 | ||||
| @@ -2,7 +2,7 @@ | ||||
|  | ||||
| #include "Game/IW5/GameAssetPoolIW5.h" | ||||
| #include "Game/IW5/XModel/XModelDumperIW5.h" | ||||
| #include "Image/AssetDumperGfxImage.h" | ||||
| #include "Image/ImageDumperIW5.h" | ||||
| #include "Leaderboard/LeaderboardJsonDumperIW5.h" | ||||
| #include "Localize/AssetDumperLocalizeEntry.h" | ||||
| #include "Maps/AssetDumperAddonMapEnts.h" | ||||
| @@ -39,7 +39,7 @@ bool ObjWriter::DumpZone(AssetDumpingContext& context) const | ||||
|     // DUMP_ASSET_POOL(AssetDumperMaterialVertexShader, m_material_vertex_shader, ASSET_TYPE_VERTEXSHADER) | ||||
|     // DUMP_ASSET_POOL(AssetDumperMaterialVertexDeclaration, m_material_vertex_decl, ASSET_TYPE_VERTEXDECL) | ||||
|     // DUMP_ASSET_POOL(AssetDumperMaterialTechniqueSet, m_technique_set, ASSET_TYPE_TECHNIQUE_SET) | ||||
|     DUMP_ASSET_POOL(AssetDumperGfxImage, m_image, ASSET_TYPE_IMAGE) | ||||
|     DUMP_ASSET_POOL(image::Dumper, m_image, ASSET_TYPE_IMAGE) | ||||
|     // DUMP_ASSET_POOL(AssetDumpersnd_alias_list_t, m_sound, ASSET_TYPE_SOUND) | ||||
|     // DUMP_ASSET_POOL(AssetDumperSndCurve, m_sound_curve, ASSET_TYPE_SOUND_CURVE) | ||||
|     DUMP_ASSET_POOL(AssetDumperLoadedSound, m_loaded_sound, ASSET_TYPE_LOADED_SOUND) | ||||
|   | ||||
| @@ -1,7 +1,8 @@ | ||||
| #include "AssetDumperGfxImage.h" | ||||
| #include "ImageDumperT5.h" | ||||
| 
 | ||||
| #include "Image/DdsWriter.h" | ||||
| #include "Image/Dx9TextureLoader.h" | ||||
| #include "Image/ImageCommon.h" | ||||
| #include "Image/IwiLoader.h" | ||||
| #include "Image/IwiWriter13.h" | ||||
| #include "ObjWriting.h" | ||||
| @@ -11,6 +12,7 @@ | ||||
| #include <format> | ||||
| 
 | ||||
| using namespace T5; | ||||
| using namespace ::image; | ||||
| 
 | ||||
| namespace | ||||
| { | ||||
| @@ -55,48 +57,43 @@ namespace | ||||
|     } | ||||
| } // namespace
 | ||||
| 
 | ||||
| AssetDumperGfxImage::AssetDumperGfxImage() | ||||
| namespace T5::image | ||||
| { | ||||
|     switch (ObjWriting::Configuration.ImageOutputFormat) | ||||
|     Dumper::Dumper() | ||||
|     { | ||||
|     case ObjWriting::Configuration_t::ImageOutputFormat_e::DDS: | ||||
|         m_writer = std::make_unique<DdsWriter>(); | ||||
|         break; | ||||
|     case ObjWriting::Configuration_t::ImageOutputFormat_e::IWI: | ||||
|         m_writer = std::make_unique<iwi13::IwiWriter>(); | ||||
|         break; | ||||
|     default: | ||||
|         assert(false); | ||||
|         m_writer = nullptr; | ||||
|         break; | ||||
|         switch (ObjWriting::Configuration.ImageOutputFormat) | ||||
|         { | ||||
|         case ObjWriting::Configuration_t::ImageOutputFormat_e::DDS: | ||||
|             m_writer = std::make_unique<DdsWriter>(); | ||||
|             break; | ||||
|         case ObjWriting::Configuration_t::ImageOutputFormat_e::IWI: | ||||
|             m_writer = std::make_unique<iwi13::IwiWriter>(); | ||||
|             break; | ||||
|         default: | ||||
|             assert(false); | ||||
|             m_writer = nullptr; | ||||
|             break; | ||||
|         } | ||||
|     } | ||||
| } | ||||
| 
 | ||||
| bool AssetDumperGfxImage::ShouldDump(XAssetInfo<GfxImage>* asset) | ||||
| { | ||||
|     return true; | ||||
| } | ||||
|     bool Dumper::ShouldDump(XAssetInfo<GfxImage>* asset) | ||||
|     { | ||||
|         return true; | ||||
|     } | ||||
| 
 | ||||
| std::string AssetDumperGfxImage::GetAssetFileName(const XAssetInfo<GfxImage>& asset) const | ||||
| { | ||||
|     auto cleanAssetName = asset.m_name; | ||||
|     std::ranges::replace(cleanAssetName, '*', '_'); | ||||
|     void Dumper::DumpAsset(AssetDumpingContext& context, XAssetInfo<GfxImage>* asset) | ||||
|     { | ||||
|         const auto* image = asset->Asset(); | ||||
|         const auto texture = LoadImageData(context.m_obj_search_path, *image); | ||||
|         if (!texture) | ||||
|             return; | ||||
| 
 | ||||
|     return std::format("images/{}{}", cleanAssetName, m_writer->GetFileExtension()); | ||||
| } | ||||
|         const auto assetFile = context.OpenAssetFile(GetFileNameForAsset(asset->m_name, m_writer->GetFileExtension())); | ||||
| 
 | ||||
| void AssetDumperGfxImage::DumpAsset(AssetDumpingContext& context, XAssetInfo<GfxImage>* asset) | ||||
| { | ||||
|     const auto* image = asset->Asset(); | ||||
|     const auto texture = LoadImageData(context.m_obj_search_path, *image); | ||||
|     if (!texture) | ||||
|         return; | ||||
|         if (!assetFile) | ||||
|             return; | ||||
| 
 | ||||
|     const auto assetFile = context.OpenAssetFile(GetAssetFileName(*asset)); | ||||
| 
 | ||||
|     if (!assetFile) | ||||
|         return; | ||||
| 
 | ||||
|     auto& stream = *assetFile; | ||||
|     m_writer->DumpImage(stream, texture.get()); | ||||
| } | ||||
|         auto& stream = *assetFile; | ||||
|         m_writer->DumpImage(stream, texture.get()); | ||||
|     } | ||||
| } // namespace T5::image
 | ||||
| @@ -6,19 +6,18 @@ | ||||
| 
 | ||||
| #include <memory> | ||||
| 
 | ||||
| namespace T5 | ||||
| namespace T5::image | ||||
| { | ||||
|     class AssetDumperGfxImage final : public AbstractAssetDumper<GfxImage> | ||||
|     class Dumper final : public AbstractAssetDumper<GfxImage> | ||||
|     { | ||||
|         std::unique_ptr<IImageWriter> m_writer; | ||||
| 
 | ||||
|         [[nodiscard]] std::string GetAssetFileName(const XAssetInfo<GfxImage>& asset) const; | ||||
|     public: | ||||
|         Dumper(); | ||||
| 
 | ||||
|     protected: | ||||
|         bool ShouldDump(XAssetInfo<GfxImage>* asset) override; | ||||
|         void DumpAsset(AssetDumpingContext& context, XAssetInfo<GfxImage>* asset) override; | ||||
| 
 | ||||
|     public: | ||||
|         AssetDumperGfxImage(); | ||||
|     private: | ||||
|         std::unique_ptr<IImageWriter> m_writer; | ||||
|     }; | ||||
| } // namespace T5
 | ||||
| } // namespace T5::image
 | ||||
| @@ -2,7 +2,7 @@ | ||||
|  | ||||
| #include "Game/T5/GameAssetPoolT5.h" | ||||
| #include "Game/T5/XModel/XModelDumperT5.h" | ||||
| #include "Image/AssetDumperGfxImage.h" | ||||
| #include "Image/ImageDumperT5.h" | ||||
| #include "Localize/AssetDumperLocalizeEntry.h" | ||||
| #include "Material/DumperMaterialT5.h" | ||||
| #include "ObjWriting.h" | ||||
| @@ -33,7 +33,7 @@ bool ObjWriter::DumpZone(AssetDumpingContext& context) const | ||||
|     DUMP_ASSET_POOL(AssetDumperXModel, m_xmodel, ASSET_TYPE_XMODEL) | ||||
|     DUMP_ASSET_POOL(AssetDumperMaterial, m_material, ASSET_TYPE_MATERIAL) | ||||
|     // DUMP_ASSET_POOL(AssetDumperTechniqueSet, m_technique_set, ASSET_TYPE_TECHNIQUE_SET) | ||||
|     DUMP_ASSET_POOL(AssetDumperGfxImage, m_image, ASSET_TYPE_IMAGE) | ||||
|     DUMP_ASSET_POOL(image::Dumper, m_image, ASSET_TYPE_IMAGE) | ||||
|     // DUMP_ASSET_POOL(AssetDumperSndBank, m_sound_bank, ASSET_TYPE_SOUND) | ||||
|     // DUMP_ASSET_POOL(AssetDumperSndPatch, m_sound_patch, ASSET_TYPE_SOUND_PATCH) | ||||
|     // DUMP_ASSET_POOL(AssetDumperClipMap, m_clip_map, ASSET_TYPE_CLIPMAP_PVS) | ||||
|   | ||||
| @@ -1,7 +1,8 @@ | ||||
| #include "AssetDumperGfxImage.h" | ||||
| #include "ImageDumperT6.h" | ||||
| 
 | ||||
| #include "Image/DdsWriter.h" | ||||
| #include "Image/Dx12TextureLoader.h" | ||||
| #include "Image/ImageCommon.h" | ||||
| #include "Image/IwiLoader.h" | ||||
| #include "Image/IwiWriter27.h" | ||||
| #include "ObjContainer/IPak/IPak.h" | ||||
| @@ -12,6 +13,7 @@ | ||||
| #include <format> | ||||
| 
 | ||||
| using namespace T6; | ||||
| using namespace ::image; | ||||
| 
 | ||||
| namespace | ||||
| { | ||||
| @@ -73,48 +75,43 @@ namespace | ||||
|     } | ||||
| } // namespace
 | ||||
| 
 | ||||
| AssetDumperGfxImage::AssetDumperGfxImage() | ||||
| namespace T6::image | ||||
| { | ||||
|     switch (ObjWriting::Configuration.ImageOutputFormat) | ||||
|     Dumper::Dumper() | ||||
|     { | ||||
|     case ObjWriting::Configuration_t::ImageOutputFormat_e::DDS: | ||||
|         m_writer = std::make_unique<DdsWriter>(); | ||||
|         break; | ||||
|     case ObjWriting::Configuration_t::ImageOutputFormat_e::IWI: | ||||
|         m_writer = std::make_unique<iwi27::IwiWriter>(); | ||||
|         break; | ||||
|     default: | ||||
|         assert(false); | ||||
|         m_writer = nullptr; | ||||
|         break; | ||||
|         switch (ObjWriting::Configuration.ImageOutputFormat) | ||||
|         { | ||||
|         case ObjWriting::Configuration_t::ImageOutputFormat_e::DDS: | ||||
|             m_writer = std::make_unique<DdsWriter>(); | ||||
|             break; | ||||
|         case ObjWriting::Configuration_t::ImageOutputFormat_e::IWI: | ||||
|             m_writer = std::make_unique<iwi27::IwiWriter>(); | ||||
|             break; | ||||
|         default: | ||||
|             assert(false); | ||||
|             m_writer = nullptr; | ||||
|             break; | ||||
|         } | ||||
|     } | ||||
| } | ||||
| 
 | ||||
| bool AssetDumperGfxImage::ShouldDump(XAssetInfo<GfxImage>* asset) | ||||
| { | ||||
|     return true; | ||||
| } | ||||
|     bool Dumper::ShouldDump(XAssetInfo<GfxImage>* asset) | ||||
|     { | ||||
|         return true; | ||||
|     } | ||||
| 
 | ||||
| std::string AssetDumperGfxImage::GetAssetFileName(const XAssetInfo<GfxImage>& asset) const | ||||
| { | ||||
|     auto cleanAssetName = asset.m_name; | ||||
|     std::ranges::replace(cleanAssetName, '*', '_'); | ||||
|     void Dumper::DumpAsset(AssetDumpingContext& context, XAssetInfo<GfxImage>* asset) | ||||
|     { | ||||
|         const auto* image = asset->Asset(); | ||||
|         const auto texture = LoadImageData(context.m_obj_search_path, *image); | ||||
|         if (!texture) | ||||
|             return; | ||||
| 
 | ||||
|     return std::format("images/{}{}", cleanAssetName, m_writer->GetFileExtension()); | ||||
| } | ||||
|         const auto assetFile = context.OpenAssetFile(GetFileNameForAsset(asset->m_name, m_writer->GetFileExtension())); | ||||
| 
 | ||||
| void AssetDumperGfxImage::DumpAsset(AssetDumpingContext& context, XAssetInfo<GfxImage>* asset) | ||||
| { | ||||
|     const auto* image = asset->Asset(); | ||||
|     const auto texture = LoadImageData(context.m_obj_search_path, *image); | ||||
|     if (!texture) | ||||
|         return; | ||||
|         if (!assetFile) | ||||
|             return; | ||||
| 
 | ||||
|     const auto assetFile = context.OpenAssetFile(GetAssetFileName(*asset)); | ||||
| 
 | ||||
|     if (!assetFile) | ||||
|         return; | ||||
| 
 | ||||
|     auto& stream = *assetFile; | ||||
|     m_writer->DumpImage(stream, texture.get()); | ||||
| } | ||||
|         auto& stream = *assetFile; | ||||
|         m_writer->DumpImage(stream, texture.get()); | ||||
|     } | ||||
| } // namespace T6::image
 | ||||
| @@ -6,19 +6,18 @@ | ||||
| 
 | ||||
| #include <memory> | ||||
| 
 | ||||
| namespace T6 | ||||
| namespace T6::image | ||||
| { | ||||
|     class AssetDumperGfxImage final : public AbstractAssetDumper<GfxImage> | ||||
|     class Dumper final : public AbstractAssetDumper<GfxImage> | ||||
|     { | ||||
|         std::unique_ptr<IImageWriter> m_writer; | ||||
| 
 | ||||
|         std::string GetAssetFileName(const XAssetInfo<GfxImage>& asset) const; | ||||
|     public: | ||||
|         Dumper(); | ||||
| 
 | ||||
|     protected: | ||||
|         bool ShouldDump(XAssetInfo<GfxImage>* asset) override; | ||||
|         void DumpAsset(AssetDumpingContext& context, XAssetInfo<GfxImage>* asset) override; | ||||
| 
 | ||||
|     public: | ||||
|         AssetDumperGfxImage(); | ||||
|     private: | ||||
|         std::unique_ptr<IImageWriter> m_writer; | ||||
|     }; | ||||
| } // namespace T6
 | ||||
| } // namespace T6::image
 | ||||
| @@ -3,7 +3,7 @@ | ||||
| #include "FontIcon/FontIconDumperT6.h" | ||||
| #include "Game/T6/GameAssetPoolT6.h" | ||||
| #include "Game/T6/XModel/XModelDumperT6.h" | ||||
| #include "Image/AssetDumperGfxImage.h" | ||||
| #include "Image/ImageDumperT6.h" | ||||
| #include "Leaderboard/LeaderboardJsonDumperT6.h" | ||||
| #include "Localize/AssetDumperLocalizeEntry.h" | ||||
| #include "Maps/AssetDumperMapEnts.h" | ||||
| @@ -53,7 +53,7 @@ bool ObjWriter::DumpZone(AssetDumpingContext& context) const | ||||
|     DUMP_ASSET_POOL(AssetDumperXModel, m_xmodel, ASSET_TYPE_XMODEL) | ||||
|     DUMP_ASSET_POOL(AssetDumperMaterial, m_material, ASSET_TYPE_MATERIAL) | ||||
|     DUMP_ASSET_POOL(AssetDumperTechniqueSet, m_technique_set, ASSET_TYPE_TECHNIQUE_SET) | ||||
|     DUMP_ASSET_POOL(AssetDumperGfxImage, m_image, ASSET_TYPE_IMAGE) | ||||
|     DUMP_ASSET_POOL(image::Dumper, m_image, ASSET_TYPE_IMAGE) | ||||
|     DUMP_ASSET_POOL(AssetDumperSndBank, m_sound_bank, ASSET_TYPE_SOUND) | ||||
|     // DUMP_ASSET_POOL(AssetDumperSndPatch, m_sound_patch, ASSET_TYPE_SOUND_PATCH) | ||||
|     // DUMP_ASSET_POOL(AssetDumperClipMap, m_clip_map, ASSET_TYPE_CLIPMAP_PVS) | ||||
|   | ||||
		Reference in New Issue
	
	Block a user