mirror of
https://github.com/RetroDECK/ES-DE.git
synced 2025-01-23 17:15:38 +00:00
105 lines
3.1 KiB
C++
105 lines
3.1 KiB
C++
// SPDX-License-Identifier: MIT
|
|
//
|
|
// EmulationStation Desktop Edition
|
|
// TextureData.h
|
|
//
|
|
// Low-level texture data functions.
|
|
//
|
|
|
|
#ifndef ES_CORE_RESOURCES_TEXTURE_DATA_H
|
|
#define ES_CORE_RESOURCES_TEXTURE_DATA_H
|
|
|
|
#include "renderers/Renderer.h"
|
|
#include "utils/MathUtil.h"
|
|
|
|
#include <atomic>
|
|
#include <cmath>
|
|
#include <mutex>
|
|
#include <string>
|
|
#include <vector>
|
|
|
|
class TextureResource;
|
|
|
|
class TextureData
|
|
{
|
|
public:
|
|
TextureData(bool tile);
|
|
~TextureData();
|
|
|
|
// These functions populate mDataRGBA but do not upload the texture to VRAM.
|
|
|
|
// Needs to be canonical path. Caller should check for duplicates before calling this.
|
|
void initFromPath(const std::string& path);
|
|
bool initSVGFromMemory(const std::string& fileData);
|
|
bool initImageFromMemory(const unsigned char* fileData, size_t length);
|
|
bool initFromRGBA(const unsigned char* dataRGBA, size_t width, size_t height);
|
|
|
|
// Read the data into memory if necessary.
|
|
bool load();
|
|
|
|
bool isLoaded();
|
|
|
|
// Upload the texture to VRAM if necessary and bind.
|
|
// Returns true if bound correctly.
|
|
bool uploadAndBind();
|
|
|
|
// Release the texture from VRAM.
|
|
void releaseVRAM();
|
|
|
|
// Release the texture from conventional RAM.
|
|
void releaseRAM();
|
|
|
|
// Get the amount of VRAM currenty used by this texture.
|
|
size_t getVRAMUsage();
|
|
|
|
size_t width();
|
|
size_t height();
|
|
float sourceWidth();
|
|
float sourceHeight();
|
|
void setSourceSize(float width, float height);
|
|
void setTileSize(float tileWidth, float tileHeight)
|
|
{
|
|
mTileWidth = tileWidth;
|
|
mTileHeight = tileHeight;
|
|
}
|
|
glm::vec2 getSize() { return glm::vec2 {static_cast<int>(mWidth), static_cast<int>(mHeight)}; }
|
|
|
|
// Whether to stretch or squash SVG images if the size property has been used to override
|
|
// the aspect ratio (accomplished by rasterizing at a lower resolution and letting the GPU
|
|
// scale the texture).
|
|
void setScalableNonAspect(bool state) { mScalableNonAspect = state; }
|
|
// Whether to use linear filtering when magnifying the texture.
|
|
void setLinearMagnify(bool state) { mLinearMagnify = state; }
|
|
|
|
// Has the image been loaded but not yet been rasterized as the size was not known?
|
|
const bool getPendingRasterization() { return mPendingRasterization; }
|
|
|
|
const bool getScalable() { return mScalable; }
|
|
std::vector<unsigned char>& getRawRGBAData() { return mDataRGBA; }
|
|
std::string getTextureFilePath() { return mPath; }
|
|
bool tiled() { return mTile; }
|
|
|
|
private:
|
|
Renderer* mRenderer;
|
|
std::mutex mMutex;
|
|
|
|
bool mTile;
|
|
std::string mPath;
|
|
std::atomic<unsigned int> mTextureID;
|
|
std::vector<unsigned char> mDataRGBA;
|
|
std::atomic<int> mWidth;
|
|
std::atomic<int> mHeight;
|
|
std::atomic<float> mTileWidth;
|
|
std::atomic<float> mTileHeight;
|
|
std::atomic<float> mSourceWidth;
|
|
std::atomic<float> mSourceHeight;
|
|
std::atomic<bool> mScalable;
|
|
std::atomic<bool> mScalableNonAspect;
|
|
std::atomic<bool> mHasRGBAData;
|
|
std::atomic<bool> mPendingRasterization;
|
|
bool mLinearMagnify;
|
|
bool mReloadable;
|
|
};
|
|
|
|
#endif // ES_CORE_RESOURCES_TEXTURE_DATA_H
|