Add support to load JPEG files along with PNGs.

This commit is contained in:
Godzil
2020-03-05 15:14:31 +00:00
parent 317148a37d
commit 30db4d7ca1
2 changed files with 85 additions and 8 deletions

View File

@@ -9,6 +9,16 @@
#include <canvas.h> #include <canvas.h>
#include <lodepng.h> #include <lodepng.h>
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
/* NanoJPEG is a bit interesting to include as a header */
extern "C" {
#define _NJ_INCLUDE_HEADER_ONLY
#include <nanojpeg.c>
#undef _NJ_INCLUDE_HEADER_ONLY
}
#define BPP (24) #define BPP (24)
#define BytePP (BPP / 8) #define BytePP (BPP / 8)
@@ -40,6 +50,80 @@ Canvas::Canvas(const Canvas *b)
memcpy(this->bitmap, b->bitmap, 4 * b->width * b->height); memcpy(this->bitmap, b->bitmap, 4 * b->width * b->height);
} }
Canvas::Canvas(const char *imgfile)
{
/* Try to determine the file type in a really lazy way */
const char *fileExt = strrchr(imgfile, '.');
this->bitmap = NULL;
if (fileExt == NULL)
{
printf("ERROR: Invalid file name '%s' - Can't determine the file format\n", imgfile);
}
else if (strncasecmp(fileExt, ".png", sizeof(fileExt)) == 0)
{
uint32_t ret = lodepng_decode24_file(&this->bitmap, &this->width, &this->height, imgfile);
if (ret)
{
printf("ERROR: %s\n", lodepng_error_text(ret));
}
}
else if ( (strncasecmp(fileExt, ".jpg", sizeof(fileExt)) == 0) || (strncasecmp(fileExt, ".jpeg", sizeof(fileExt)) == 0) )
{
FILE *fp;
char *fileBuff;
size_t fileSize;
fp = fopen(imgfile, "rb");
if (fp)
{
fseek(fp, 0, SEEK_END);
fileSize = ftell(fp);
fileBuff = (char *)calloc(fileSize, 1);
fseek(fp, 0, SEEK_SET);
fileSize = fread(fileBuff, 1, fileSize, fp);
fclose(fp);
njInit();
if (!njDecode(fileBuff, fileSize))
{
this->width = njGetWidth();
this->height = njGetHeight();
/* Need to do a local copy */
this->bitmap = (uint8_t *)calloc(1, njGetImageSize());
memcpy(this->bitmap, njGetImage(), njGetImageSize());
}
else
{
printf("ERROR: Error while decoding the file '%s'\n", imgfile);
}
free(fileBuff);
njDone();
}
else
{
printf("ERROR: Can't opening the file '%s'.\n", imgfile);
}
}
else
{
printf("ERROR: File extention '%s' is not a recognized one.\n", fileExt);
}
if (this->bitmap == NULL)
{
printf("ABORT: Opening image file '%s' failed\n", imgfile);
exit(-1);
}
this->stride = BytePP * width;
}
Canvas::~Canvas() Canvas::~Canvas()
{ {
if (this->bitmap != nullptr) if (this->bitmap != nullptr)
@@ -67,11 +151,4 @@ bool Canvas::SaveAsPNG(const char *filename)
uint32_t ret = lodepng_encode24_file(filename, this->bitmap, this->width, this->height); uint32_t ret = lodepng_encode24_file(filename, this->bitmap, this->width, this->height);
return ret == 0; return ret == 0;
}
Canvas::Canvas(const char *pngfile)
{
uint32_t ret = lodepng_decode24_file(&this->bitmap, &this->width, &this->height, pngfile);
if(ret){ printf("error %u: %s\n", ret, lodepng_error_text(ret));}
printf("%p - %d - %d\n", this->bitmap, this->width, this->height);
} }

View File

@@ -23,7 +23,7 @@ public:
Canvas(uint32_t width, uint32_t height); Canvas(uint32_t width, uint32_t height);
Canvas(const Canvas *c); Canvas(const Canvas *c);
Canvas(const Canvas &c); Canvas(const Canvas &c);
Canvas(const char *pngfile); Canvas(const char *imgfile);
~Canvas(); ~Canvas();