diff options
| author | Dan Goodliffe <dan@randomdan.homeip.net> | 2023-04-10 18:36:53 +0100 | 
|---|---|---|
| committer | Dan Goodliffe <dan@randomdan.homeip.net> | 2023-04-10 18:36:53 +0100 | 
| commit | 9aa09c55b0af4b8c4c14a4ac50fcb21f7eba492d (patch) | |
| tree | 401ca6f622182b26bfffe4114ced625a431d5fc0 | |
| parent | Plants are world objects (diff) | |
| download | ilt-9aa09c55b0af4b8c4c14a4ac50fcb21f7eba492d.tar.bz2 ilt-9aa09c55b0af4b8c4c14a4ac50fcb21f7eba492d.tar.xz ilt-9aa09c55b0af4b8c4c14a4ac50fcb21f7eba492d.zip | |
Support loading textures from an in memory buffer
| -rw-r--r-- | gfx/image.cpp | 16 | ||||
| -rw-r--r-- | gfx/image.h | 1 | 
2 files changed, 17 insertions, 0 deletions
| diff --git a/gfx/image.cpp b/gfx/image.cpp index e3e3b01..fb86cb6 100644 --- a/gfx/image.cpp +++ b/gfx/image.cpp @@ -19,6 +19,22 @@ Image::Image(const char * fileName, int flags) : width {}, height {}, numCompone  	data = {bytes, static_cast<size_t>(width * height * numComponents)};  } +Image::Image(std::span<unsigned char> buffer, int flags) +{ +	stbi_set_flip_vertically_on_load(1); +	int w, h, nc; +	unsigned char * bytes = stbi_load_from_memory(buffer.data(), static_cast<int>(buffer.size()), &w, &h, &nc, flags); +	width = static_cast<unsigned int>(w); +	height = static_cast<unsigned int>(h); +	numComponents = static_cast<unsigned int>(nc); + +	if (!bytes) { +		throw std::runtime_error {"Unable to load image from memory buffer "}; +	} + +	data = {bytes, static_cast<size_t>(width * height * numComponents)}; +} +  Image::~Image()  {  	stbi_image_free(data.data()); diff --git a/gfx/image.h b/gfx/image.h index 47437ca..97c2731 100644 --- a/gfx/image.h +++ b/gfx/image.h @@ -8,6 +8,7 @@ class Image {  public:  	Image(const char * fileName, int flags);  	Image(const std::string & fileName, int flags) : Image(fileName.c_str(), flags) { } +	Image(std::span<unsigned char> data, int flags);  	~Image();  	NO_COPY(Image); | 
