OpenMiner/source/client/graphics/TextureAtlas.hpp

78 lines
2.3 KiB
C++
Raw Permalink Normal View History

2020-01-29 17:19:26 +09:00
/*
* =====================================================================================
*
* OpenMiner
*
* Copyright (C) 2018-2020 Unarelith, Quentin Bazin <openminer@unarelith.net>
* Copyright (C) 2019-2020 the OpenMiner contributors (see CONTRIBUTORS.md)
*
* This file is part of OpenMiner.
2020-01-29 17:19:26 +09:00
*
* OpenMiner is free software; you can redistribute it and/or
* modify it under the terms of the GNU Lesser General Public
* License as published by the Free Software Foundation; either
* version 2.1 of the License, or (at your option) any later version.
2020-01-29 17:19:26 +09:00
*
* OpenMiner is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
* Lesser General Public License for more details.
2020-01-29 17:19:26 +09:00
*
* You should have received a copy of the GNU Lesser General Public License
* along with OpenMiner; if not, write to the Free Software Foundation, Inc.,
* 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
2020-01-29 17:19:26 +09:00
*
* =====================================================================================
*/
#ifndef TEXTUREATLAS_HPP_
#define TEXTUREATLAS_HPP_
#include <memory>
#include <string>
#include <unordered_map>
#include <vector>
2020-01-29 17:19:26 +09:00
#include <gk/core/IntTypes.hpp>
#include <gk/core/Rect.hpp>
2020-07-07 19:33:01 +02:00
#include <gk/gl/Texture.hpp>
2020-01-29 17:19:26 +09:00
class TextureAtlas {
public:
TextureAtlas() = default;
2020-07-14 23:14:41 +02:00
void clear();
void loadFromRegistry(const std::string &texturePack = "");
2020-01-29 17:19:26 +09:00
gk::FloatRect getTexCoords(const std::string &filename, bool normalized = true) const;
2020-07-07 19:33:01 +02:00
const gk::Texture &texture() const { return m_texture; }
bool isReady() const { return m_isReady; }
2020-01-29 17:19:26 +09:00
private:
void addFile(const std::string &path, const std::string &filename);
u16 getTextureID(const std::string &filename) const;
void packTextures();
2020-01-29 17:19:26 +09:00
// Expected texture size
u16 m_tileSize = 0;
2020-01-29 17:19:26 +09:00
// Mapping between filename and internal texture ID
std::unordered_map<std::string, u16> m_textureMap;
2020-07-07 19:48:11 +02:00
// Textures to pack together
using SurfacePtr = std::unique_ptr<SDL_Surface, decltype(&SDL_FreeSurface)>;
std::vector<SurfacePtr> m_textures;
2020-01-29 17:19:26 +09:00
// Packed texture
2020-07-07 19:33:01 +02:00
gk::Texture m_texture;
// Is the texture atlas ready to use?
bool m_isReady = false;
2020-01-29 17:19:26 +09:00
};
#endif // TEXTUREATLAS_HPP_