aboutsummaryrefslogtreecommitdiff
path: root/mwe/resource-manager/TextureMap.cpp
blob: d82975ca5fbe24e7585ea7b88ee9dfe9259f751d (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
#include "TextureMap.h"

#define STB_IMAGE_IMPLEMENTATION
#include "stb_image.h"

#include <cstdint>
#include <iostream>

TextureMap::TextureMap() : m_texture(nullptr) {}

TextureMap::~TextureMap() {
	if (m_texture) {
		SDL_DestroyTexture(m_texture);
	}
}

//public
bool TextureMap::loadFromFile(const std::string & path,
							  SDL_Renderer * renderer) {
	assert(renderer != nullptr);
	assert(!path.empty());

	std::int32_t x = 0;
	std::int32_t y = 0;
	std::int32_t c = 0;
	unsigned char * data = stbi_load(path.c_str(), &x, &y, &c, 0);

	if (data) {
		std::int32_t pitch = x * c;
		pitch = (pitch + 3) & ~3;

		constexpr std::int32_t rmask = 0x000000ff;
		constexpr std::int32_t gmask = 0x0000ff00;
		constexpr std::int32_t bmask = 0x00ff0000;
		const std::int32_t amask = c == 4 ? 0xff000000 : 0;

		auto * surface = SDL_CreateRGBSurfaceFrom(data, x, y, c * 8, pitch,
												  rmask, gmask, bmask, amask);

		if (!surface) {
			std::cerr << "Unable to create texture surface: " << SDL_GetError()
					  << "\n";
			stbi_image_free(data);
			return false;
		}

		m_texture = SDL_CreateTextureFromSurface(renderer, surface);

		SDL_FreeSurface(surface);
		stbi_image_free(data);

		if (!m_texture) {
			std::cerr << "Failed to create texture for " << path << "\n";
			return false;
		}

		//sets alpha blending
		//SDL_SetTextureBlendMode(m_texture, SDL_BLENDMODE_BLEND);
		m_size.x = x;
		m_size.y = y;

		return true;
	}

	return false;
}