i would like for this program to be comprehensible
This commit is contained in:
parent
4b410a3511
commit
57ad9fd139
11 changed files with 2 additions and 395 deletions
88
img.c
88
img.c
|
@ -1,88 +0,0 @@
|
|||
#define STB_IMAGE_IMPLEMENTATION
|
||||
#define STBI_MALLOC(sz) SDL_malloc(sz)
|
||||
#define STBI_REALLOC(p,newsz) SDL_realloc(p,newsz)
|
||||
#define STBI_FREE(p) SDL_free(p)
|
||||
#include <SDL3/SDL.h>
|
||||
#include "stb_image.h"
|
||||
|
||||
#include "dat.h"
|
||||
#include "fns.h"
|
||||
|
||||
void
|
||||
free_image(Image *i)
|
||||
{
|
||||
if (i) {
|
||||
if (i->tex) {
|
||||
babble("free img %s texture...", i->name);
|
||||
SDL_DestroyTexture(i->tex);
|
||||
}
|
||||
if (i->sur) {
|
||||
babble("destroy image %s surface...", i->name);
|
||||
SDL_DestroySurface(i->sur);
|
||||
}
|
||||
if (i->data) {
|
||||
babble("free img %s data...", i->name);
|
||||
stbi_image_free(i->data);
|
||||
}
|
||||
if (i->name) {
|
||||
babble("free img %s name...", i->name);
|
||||
SDL_free(i->name);
|
||||
}
|
||||
babble("free aforementioned img...");
|
||||
SDL_free(i);
|
||||
}
|
||||
}
|
||||
|
||||
Image *
|
||||
load_image(SDL_Renderer *ren, char *path)
|
||||
{
|
||||
Image *i;
|
||||
|
||||
babble("create image %s...", path);
|
||||
|
||||
babble("alloc image...", path);
|
||||
i = SDL_calloc(1, sizeof(Image));
|
||||
if (!i) {
|
||||
shit("mem alloc fail: %s", SDL_GetError());
|
||||
return NULL;
|
||||
}
|
||||
|
||||
babble("alloc image %s name...", path);
|
||||
i->name = SDL_strdup(path);
|
||||
if (!i->name) {
|
||||
shit("strdup fail: %s", SDL_GetError());
|
||||
free_image(i);
|
||||
return NULL;
|
||||
}
|
||||
|
||||
babble("alloc image %s data...", i->name);
|
||||
i->data = stbi_load(path, &i->w, &i->h,
|
||||
&i->bpp, 4);
|
||||
if (!i->data) {
|
||||
shit("img load fail: %s", stbi_failure_reason());
|
||||
free_image(i);
|
||||
return NULL;
|
||||
}
|
||||
|
||||
babble("alloc image %s surface...", i->name);
|
||||
i->sur = SDL_CreateSurfaceFrom(i->w, i->h,
|
||||
SDL_PIXELFORMAT_RGBA32, i->data,
|
||||
i->w * 4);
|
||||
if (!i->sur) {
|
||||
shit("surface creation fail: %s", SDL_GetError());
|
||||
free_image(i);
|
||||
return NULL;
|
||||
}
|
||||
|
||||
babble("alloc image %s texture...", i->name);
|
||||
i->tex = SDL_CreateTextureFromSurface(ren, i->sur);
|
||||
if (!i->tex) {
|
||||
shit("surface creation fail: %s", SDL_GetError());
|
||||
SDL_DestroySurface(i->sur);
|
||||
free_image(i);
|
||||
return NULL;
|
||||
}
|
||||
|
||||
babble("image %s created", path);
|
||||
return i;
|
||||
}
|
Loading…
Add table
Add a link
Reference in a new issue