2
0
mirror of https://github.com/Laupetin/OpenAssetTools.git synced 2025-08-30 21:53:15 +00:00

refactor: restructure image dumper

This commit is contained in:
Jan Laupetin
2025-07-28 23:15:45 +01:00
parent 9a6f0c8919
commit 22dbf57269
17 changed files with 245 additions and 240 deletions

View File

@@ -0,0 +1,15 @@
#include "ImageCommon.h"
#include <algorithm>
#include <format>
namespace image
{
std::string GetFileNameForAsset(std::string assetName, const std::string& extension)
{
std::string cleanAssetName(std::move(assetName));
std::ranges::replace(cleanAssetName, '*', '_');
return std::format("images/{}{}", cleanAssetName, extension);
}
} // namespace image

View File

@@ -0,0 +1,8 @@
#pragma once
#include <string>
namespace image
{
std::string GetFileNameForAsset(std::string assetName, const std::string& extension);
}

View File

@@ -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

View File

@@ -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

View File

@@ -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)

View File

@@ -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

View File

@@ -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

View File

@@ -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)

View File

@@ -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

View File

@@ -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

View File

@@ -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)

View File

@@ -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

View File

@@ -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

View File

@@ -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)

View File

@@ -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

View File

@@ -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

View File

@@ -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)