ES-DE/es-core/src/resources/TextureResource.h

72 lines
2.3 KiB
C
Raw Normal View History

//
// TextureResource.h
//
// Handles OpenGL textures.
//
#pragma once
#ifndef ES_CORE_RESOURCES_TEXTURE_RESOURCE_H
#define ES_CORE_RESOURCES_TEXTURE_RESOURCE_H
#include "math/Vector2i.h"
#include "math/Vector2f.h"
2017-11-01 22:21:10 +00:00
#include "resources/ResourceManager.h"
#include "resources/TextureDataManager.h"
#include <set>
#include <string>
class TextureData;
2014-01-24 22:21:10 +00:00
// An OpenGL texture.
// Automatically recreates the texture with renderer deinit/reinit.
class TextureResource : public IReloadable
{
public:
static std::shared_ptr<TextureResource> get(const std::string& path, bool tile = false,
bool forceLoad = false, bool dynamic = true);
void initFromPixels(const unsigned char* dataRGBA, size_t width, size_t height);
2020-09-04 17:05:48 +00:00
virtual void initFromMemory(const char* data, size_t length);
// For scalable source images in textures we want to set the resolution to rasterize at.
void rasterizeAt(size_t width, size_t height);
Vector2f getSourceImageSize() const;
virtual ~TextureResource();
bool isInitialized() const;
bool isTiled() const;
const Vector2i getSize() const;
bool bind();
// Returns an approximation of total VRAM used by textures (in bytes).
static size_t getTotalMemUsage();
// Returns the number of bytes that would be used if all textures were in memory.
static size_t getTotalTextureSize();
protected:
TextureResource(const std::string& path, bool tile, bool dynamic);
virtual void unload(std::shared_ptr<ResourceManager>& rm);
virtual void reload(std::shared_ptr<ResourceManager>& rm);
private:
// mTextureData is used for textures that are not loaded from a file - these ones
// are permanently allocated and cannot be loaded and unloaded based on resources.
std::shared_ptr<TextureData> mTextureData;
// The texture data manager manages loading and unloading of filesystem based textures.
static TextureDataManager sTextureDataManager;
Vector2i mSize;
Vector2f mSourceSize;
bool mForceLoad;
typedef std::pair<std::string, bool> TextureKeyType;
// Map of textures, used to prevent duplicate textures.
static std::map< TextureKeyType, std::weak_ptr<TextureResource> > sTextureMap;
// Set of all textures, used for memory management.
static std::set<TextureResource*> sAllTextures;
};
#endif // ES_CORE_RESOURCES_TEXTURE_RESOURCE_H