From b691c43c44ff180d10e7d4a9afc83b98551ff586 Mon Sep 17 00:00:00 2001 From: daoge_cmd <3523206925@qq.com> Date: Sun, 1 Mar 2026 12:16:08 +0800 Subject: Initial commit --- Minecraft.Client/TextureManager.h | 41 +++++++++++++++++++++++++++++++++++++++ 1 file changed, 41 insertions(+) create mode 100644 Minecraft.Client/TextureManager.h (limited to 'Minecraft.Client/TextureManager.h') diff --git a/Minecraft.Client/TextureManager.h b/Minecraft.Client/TextureManager.h new file mode 100644 index 00000000..b1d71d2d --- /dev/null +++ b/Minecraft.Client/TextureManager.h @@ -0,0 +1,41 @@ +#pragma once + +class Texture; +class Stitcher; +class TexturePack; + +class TextureManager +{ +private: + static TextureManager *instance; + + int nextID; + typedef unordered_map stringIntMap; + typedef unordered_map intTextureMap; + intTextureMap idToTextureMap; + stringIntMap stringToIDMap; + +public: + static void createInstance(); + static TextureManager *getInstance(); + +private: + TextureManager(); + +public: + int createTextureID(); + Texture *getTexture(const wstring &name); + void registerName(const wstring &name, Texture *texture); + void registerTexture(Texture *texture); + void unregisterTexture(const wstring &name, Texture *texture); + Stitcher *createStitcher(const wstring &name); + vector *createTextures(const wstring &filename, bool mipmap); // 4J added mipmap param + +private: + wstring getTextureNameFromPath(const wstring &filename); + bool isAnimation(const wstring &filename, TexturePack *texturePack); + +public: + Texture *createTexture(const wstring &name, int mode, int width, int height, int wrap, int format, int minFilter, int magFilter, bool mipmap, BufferedImage *image); + Texture *createTexture(const wstring &name, int mode, int width, int height, int format, bool mipmap); // 4J Added mipmap param +}; \ No newline at end of file -- cgit v1.2.3