Merge branch '16bit-tga' of https://github.com/DanielGibson/stb into working
This commit is contained in:
commit
32d5e7ca7f
@ -11,14 +11,15 @@ free to tell me about their quality.) _Newest additions are in italics._
|
||||
- **images** [tiny_jpeg.h](https://github.com/serge-rgb/TinyJPEG/blob/master/tiny_jpeg.h): JPEG encoder (public domain)
|
||||
- **images** [miniexr](https://github.com/aras-p/miniexr): OpenEXR writer (public domain)
|
||||
- **geometry** [nv_voronoi.h](http://www.icculus.org/~mordred/nvlib/): find voronoi regions on lattice w/ integer inputs (public domain)
|
||||
- _**geometry** [sobol.h](https://github.com/Marc-B-Reynolds/Stand-alone-junk/blob/master/src/SFH/Sobol.h): sobol & stratified sampling sequences (public domain)_
|
||||
- **geometry** [sobol.h](https://github.com/Marc-B-Reynolds/Stand-alone-junk/blob/master/src/SFH/Sobol.h): sobol & stratified sampling sequences (public domain)
|
||||
- **network** [zed_net](https://github.com/ZedZull/zed_net): cross-platform socket wrapper (public domain)
|
||||
- **strings**; **files & filenames** [DG_misc.h](https://github.com/DanielGibson/Snippets/): Daniel Gibson's stb.h-esque cross-platform helpers: path/file, strings (public domain)
|
||||
- **strings** [utf8](https://github.com/sheredom/utf8.h): utf8 string library (public domain)
|
||||
- _**strings** [strpool.h](https://github.com/mattiasgustavsson/libs): string interning (public domain/MIT)_
|
||||
- **misc** [MakeID.h](http://www.humus.name/3D/MakeID.h): allocate/deallocate small integer IDs efficiently (public domain)
|
||||
- **misc** [gb_string.h](https://github.com/gingerBill/gb): dynamic strings for C (public domain)
|
||||
- _**misc** [loguru](https://github.com/emilk/loguru): flexible logging for C++ (public domain)_
|
||||
- _**hardware** [EasyTab](https://github.com/ApoorvaJ/EasyTab): multi-platform tablet input (public domain)_
|
||||
- **misc** [loguru](https://github.com/emilk/loguru): flexible logging for C++ (public domain)
|
||||
- **hardware** [EasyTab](https://github.com/ApoorvaJ/EasyTab): multi-platform tablet input (public domain)
|
||||
|
||||
Not public domain:
|
||||
|
||||
@ -27,19 +28,21 @@ Not public domain:
|
||||
- **images** [nanoSVG](https://github.com/memononen/nanosvg): 1-file SVG parser; 1-file SVG rasterizer (zlib license)
|
||||
- **3D** [tinyobjloader](https://github.com/syoyo/tinyobjloader): wavefront OBJ file loader (BSD license)
|
||||
- **2D** [blendish](https://bitbucket.org/duangle/oui-blendish/src): blender-style widget rendering (MIT license)
|
||||
- _**math** [mm_vec.h](https://github.com/vurtun/mmx): vector math (BSD license)_
|
||||
- **geometry** [sdf.h](https://github.com/memononen/SDF): compute signed-distance field from antialiased image (MIT license)
|
||||
- **geometry** [nanoflann](https://github.com/jlblancoc/nanoflann): build KD trees for point clouds (BSD license)
|
||||
- **geometry** [jc_voronoi](https://github.com/JCash/voronoi): find voronoi regions on float/double data (MIT license)
|
||||
- _**network** [wby](https://github.com/vurtun/wby): lightweight webserver, fork of webby (BSD license)_
|
||||
- **network** [mm_web.h](https://github.com/vurtun/mmx): lightweight webserver, fork of webby (BSD license)
|
||||
- **audio** [aw_ima.h](https://github.com/afterwise/aw-ima/blob/master/aw-ima.h): IMA-ADPCM audio decoder (MIT license)
|
||||
- **multithreading** [mts](https://github.com/vurtun/mts): cross-platform multithreaded task scheduler (zlib license)
|
||||
- **multithreading** [mm_sched.h](https://github.com/vurtun/mts): cross-platform multithreaded task scheduler (zlib license)
|
||||
- **parsing** [SLRE](https://github.com/cesanta/slre): regular expression matcher (GPL v2)
|
||||
- **parsing** [PicoJSON](https://github.com/kazuho/picojson): JSON parse/serializer for C++ (BSD license)
|
||||
- _**parsing** [zange](https://github.com/vurtun/zange): JSON parser (MIT license)_
|
||||
- _**parsing** [mm_json.h](https://github.com/vurtun/mmx): JSON parser (zlib license)_
|
||||
- _**parsing** [mm_lexer.h](https://github.com/vurtun/mmx): C-esque language lexer (zlib license)_
|
||||
- **tests** [utest](https://github.com/evolutional/utest): unit testing (MIT license)
|
||||
- **tests** [catch](https://github.com/philsquared/Catch): unit testing (Boost license)
|
||||
- **tests** [SPUT](http://www.lingua-systems.com/unit-testing/): unit testing (BSD license)
|
||||
- _**misc** [lualite](https://github.com/janezz55/lualite/): generate lua bindings in C++ (MIT license)_
|
||||
- **misc** [lualite](https://github.com/janezz55/lualite/): generate lua bindings in C++ (MIT license)
|
||||
|
||||
There are some that have a source file and require a separate header file (which they may
|
||||
not even supply). That's twice as many files, and we at nothings/stb cannot condone
|
||||
@ -52,11 +55,11 @@ this! But you might like them anyway:
|
||||
- **2D** [noc_turtle](https://github.com/guillaumechereau/noc): procedural graphics generator (public domain)
|
||||
- **geometry** [Tomas Akenine-Moller snippets](http://fileadmin.cs.lth.se/cs/Personal/Tomas_Akenine-Moller/code/): various 3D intersection calculations, not lib-ified (public domain)
|
||||
- **geometry** [Clipper](http://www.angusj.com/delphi/clipper.php): line & polygon clipping & offsetting (Boost license)
|
||||
- _**geometry** [PolyPartition](https://github.com/ivanfratric/polypartition): polygon triangulation, partitioning (MIT license)_
|
||||
- **geometry** [PolyPartition](https://github.com/ivanfratric/polypartition): polygon triangulation, partitioning (MIT license)
|
||||
- **network** [yocto](https://github.com/tom-seddon/yhs): non-production-use http server (public domain)
|
||||
- **network** [happyhttp](http://scumways.com/happyhttp/happyhttp.html): http client requests (zlib license)
|
||||
- **network** [mongoose](https://github.com/cesanta/mongoose): http server (GPL v2)
|
||||
- _**crypto** [TweetNaCl](http://tweetnacl.cr.yp.to/software.html): high-quality tiny cryptography library (public domain)_
|
||||
- **crypto** [TweetNaCl](http://tweetnacl.cr.yp.to/software.html): high-quality tiny cryptography library (public domain)
|
||||
- **AI** [micropather](http://www.grinninglizard.com/MicroPather/): pathfinding with A* (zlib license)
|
||||
- **compression** [miniz.c](https://github.com/richgel999/miniz): zlib compression,decompression, zip file, png writing (public domain)
|
||||
- **compression** [lz4](https://github.com/Cyan4973/lz4): fast but larger LZ compression (BSD license)
|
||||
@ -65,16 +68,16 @@ this! But you might like them anyway:
|
||||
- **profiling** [Remotery](https://github.com/Celtoys/Remotery): CPU/GPU profiler Win/Mac/Linux, using web browser for viewer (Apache 2.0 license)
|
||||
- **profiling** [MicroProfile](https://bitbucket.org/jonasmeyer/microprofile): CPU (and GPU?) profiler, 1-3 header files (unlicense) *uses miniz internally*
|
||||
- **parsing** [json.h](https://github.com/sheredom/json.h): JSON parser (public domain)
|
||||
- _**parsing** [jzon.h](https://github.com/Zguy/Jzon): JSON parser, C++ (MIT license)_
|
||||
- **parsing** [jzon.h](https://github.com/Zguy/Jzon): JSON parser, C++ (MIT license)
|
||||
- **strings** [dfa](http://bjoern.hoehrmann.de/utf-8/decoder/dfa/): fast utf8 decoder (MIT license)
|
||||
- **data structures** [klib](http://attractivechaos.github.io/klib/): many 2-file libs: hash, sort, b-tree, etc (MIT license)
|
||||
- _**data structures** [uthash](https://github.com/troydhanson/uthash): several 1-header, 1-license-file libs: generic hash, list, etc (BSD license)_
|
||||
- _**data structures** [PackedArray](https://github.com/gpakosz/PackedArray): memory-efficient array of elements with non-pow2 bitcount (WTFPL v2 license)_
|
||||
- **data structures** [uthash](https://github.com/troydhanson/uthash): several 1-header, 1-license-file libs: generic hash, list, etc (BSD license)
|
||||
- **data structures** [PackedArray](https://github.com/gpakosz/PackedArray): memory-efficient array of elements with non-pow2 bitcount (WTFPL v2 license)
|
||||
- **data structures**; **algorithms** [minilibs](https://github.com/ccxvii/minilibs): two-file regex, binary tree (public domain)
|
||||
- **files & filenames** [whereami](https://github.com/gpakosz/whereami): get path/filename of executable or module (WTFPL v2 license)
|
||||
- **misc** [dbgtools](https://github.com/wc-duck/dbgtools): cross-platform debug util libraries (zlib license)
|
||||
- _**misc** [stmr](https://github.com/wooorm/stmr.c): extract English word stems (MIT license)_
|
||||
- _**misc** [levenshtein](https://github.com/wooorm/levenshtein.c): compute edit distance between two strings (MIT license)_
|
||||
- **misc** [stmr](https://github.com/wooorm/stmr.c): extract English word stems (MIT license)
|
||||
- **misc** [levenshtein](https://github.com/wooorm/levenshtein.c): compute edit distance between two strings (MIT license)
|
||||
- **tests** [pempek_assert.cpp](https://github.com/gpakosz/Assert/tree/master/src): flexible assertions in C++ (WTFPL v2 license)
|
||||
|
||||
There is also these XML libraries, but if you're using XML, shame on you:
|
||||
|
203
stb_image.h
203
stb_image.h
@ -4836,20 +4836,55 @@ static stbi_uc *stbi__bmp_load(stbi__context *s, int *x, int *y, int *comp, int
|
||||
// Targa Truevision - TGA
|
||||
// by Jonathan Dummer
|
||||
#ifndef STBI_NO_TGA
|
||||
// returns STBI_rgb or whatever, 0 on error
|
||||
static int stbi__tga_get_comp(int bits_per_pixel, int is_grey, int* is_rgb16)
|
||||
{
|
||||
// only RGB or RGBA (incl. 16bit) or grey allowed
|
||||
if(is_rgb16) *is_rgb16 = 0;
|
||||
switch(bits_per_pixel) {
|
||||
case 8: return STBI_grey;
|
||||
case 16: if(is_grey) return STBI_grey_alpha;
|
||||
// else: fall-through
|
||||
case 15: if(is_rgb16) *is_rgb16 = 1;
|
||||
return STBI_rgb;
|
||||
case 24: // fall-through
|
||||
case 32: return bits_per_pixel/8;
|
||||
default: return 0;
|
||||
}
|
||||
}
|
||||
|
||||
static int stbi__tga_info(stbi__context *s, int *x, int *y, int *comp)
|
||||
{
|
||||
int tga_w, tga_h, tga_comp;
|
||||
int sz;
|
||||
int tga_w, tga_h, tga_comp, tga_image_type, tga_bits_per_pixel, tga_colormap_bpp;
|
||||
int sz, tga_colormap_type;
|
||||
stbi__get8(s); // discard Offset
|
||||
sz = stbi__get8(s); // color type
|
||||
if( sz > 1 ) {
|
||||
tga_colormap_type = stbi__get8(s); // colormap type
|
||||
if( tga_colormap_type > 1 ) {
|
||||
stbi__rewind(s);
|
||||
return 0; // only RGB or indexed allowed
|
||||
}
|
||||
sz = stbi__get8(s); // image type
|
||||
// only RGB or grey allowed, +/- RLE
|
||||
if ((sz != 1) && (sz != 2) && (sz != 3) && (sz != 9) && (sz != 10) && (sz != 11)) return 0;
|
||||
stbi__skip(s,9);
|
||||
tga_image_type = stbi__get8(s); // image type
|
||||
if ( tga_colormap_type == 1 ) { // colormapped (paletted) image
|
||||
if (tga_image_type != 1 && tga_image_type != 9) {
|
||||
stbi__rewind(s);
|
||||
return 0;
|
||||
}
|
||||
stbi__skip(s,4); // skip index of first colormap entry and number of entries
|
||||
sz = stbi__get8(s); // check bits per palette color entry
|
||||
if ( (sz != 8) && (sz != 15) && (sz != 16) && (sz != 24) && (sz != 32) ) {
|
||||
stbi__rewind(s);
|
||||
return 0;
|
||||
}
|
||||
stbi__skip(s,4); // skip image x and y origin
|
||||
tga_colormap_bpp = sz;
|
||||
} else { // "normal" image w/o colormap - only RGB or grey allowed, +/- RLE
|
||||
if ( (tga_image_type != 2) && (tga_image_type != 3) && (tga_image_type != 10) && (tga_image_type != 11) ) {
|
||||
stbi__rewind(s);
|
||||
return 0; // only RGB or grey allowed, +/- RLE
|
||||
}
|
||||
stbi__skip(s,9); // skip colormap specification and image x/y origin
|
||||
tga_colormap_bpp = 0;
|
||||
}
|
||||
tga_w = stbi__get16le(s);
|
||||
if( tga_w < 1 ) {
|
||||
stbi__rewind(s);
|
||||
@ -4860,44 +4895,80 @@ static int stbi__tga_info(stbi__context *s, int *x, int *y, int *comp)
|
||||
stbi__rewind(s);
|
||||
return 0; // test height
|
||||
}
|
||||
sz = stbi__get8(s); // bits per pixel
|
||||
// only RGB or RGBA or grey allowed
|
||||
if ((sz != 8) && (sz != 16) && (sz != 24) && (sz != 32)) {
|
||||
stbi__rewind(s);
|
||||
return 0;
|
||||
tga_bits_per_pixel = stbi__get8(s); // bits per pixel
|
||||
stbi__get8(s); // ignore alpha bits
|
||||
if (tga_colormap_bpp != 0) {
|
||||
if((tga_bits_per_pixel != 8) && (tga_bits_per_pixel != 16)) {
|
||||
// when using a colormap, tga_bits_per_pixel is the size of the indexes
|
||||
// I don't think anything but 8 or 16bit indexes makes sense
|
||||
stbi__rewind(s);
|
||||
return 0;
|
||||
}
|
||||
tga_comp = stbi__tga_get_comp(tga_colormap_bpp, 0, NULL);
|
||||
} else {
|
||||
tga_comp = stbi__tga_get_comp(tga_bits_per_pixel, (tga_image_type == 3) || (tga_image_type == 11), NULL);
|
||||
}
|
||||
if(!tga_comp) {
|
||||
stbi__rewind(s);
|
||||
return 0;
|
||||
}
|
||||
tga_comp = sz;
|
||||
if (x) *x = tga_w;
|
||||
if (y) *y = tga_h;
|
||||
if (comp) *comp = tga_comp / 8;
|
||||
if (comp) *comp = tga_comp;
|
||||
return 1; // seems to have passed everything
|
||||
}
|
||||
|
||||
static int stbi__tga_test(stbi__context *s)
|
||||
{
|
||||
int res;
|
||||
int sz;
|
||||
int res = 0;
|
||||
int sz, tga_color_type;
|
||||
stbi__get8(s); // discard Offset
|
||||
sz = stbi__get8(s); // color type
|
||||
if ( sz > 1 ) return 0; // only RGB or indexed allowed
|
||||
tga_color_type = stbi__get8(s); // color type
|
||||
if ( tga_color_type > 1 ) goto errorEnd; // only RGB or indexed allowed
|
||||
sz = stbi__get8(s); // image type
|
||||
if ( (sz != 1) && (sz != 2) && (sz != 3) && (sz != 9) && (sz != 10) && (sz != 11) ) return 0; // only RGB or grey allowed, +/- RLE
|
||||
stbi__get16be(s); // discard palette start
|
||||
stbi__get16be(s); // discard palette length
|
||||
stbi__get8(s); // discard bits per palette color entry
|
||||
stbi__get16be(s); // discard x origin
|
||||
stbi__get16be(s); // discard y origin
|
||||
if ( stbi__get16be(s) < 1 ) return 0; // test width
|
||||
if ( stbi__get16be(s) < 1 ) return 0; // test height
|
||||
if ( tga_color_type == 1 ) { // colormapped (paletted) image
|
||||
if (sz != 1 && sz != 9) goto errorEnd; // colortype 1 demands image type 1 or 9
|
||||
stbi__skip(s,4); // skip index of first colormap entry and number of entries
|
||||
sz = stbi__get8(s); // check bits per palette color entry
|
||||
if ( (sz != 8) && (sz != 15) && (sz != 16) && (sz != 24) && (sz != 32) ) goto errorEnd;
|
||||
stbi__skip(s,4); // skip image x and y origin
|
||||
} else { // "normal" image w/o colormap
|
||||
if ( (sz != 2) && (sz != 3) && (sz != 10) && (sz != 11) ) goto errorEnd; // only RGB or grey allowed, +/- RLE
|
||||
stbi__skip(s,9); // skip colormap specification and image x/y origin
|
||||
}
|
||||
if ( stbi__get16le(s) < 1 ) goto errorEnd; // test width
|
||||
if ( stbi__get16le(s) < 1 ) goto errorEnd; // test height
|
||||
sz = stbi__get8(s); // bits per pixel
|
||||
if ( (sz != 8) && (sz != 16) && (sz != 24) && (sz != 32) )
|
||||
res = 0;
|
||||
else
|
||||
res = 1;
|
||||
if ( (tga_color_type == 1) && (sz != 8) && (sz != 16) ) goto errorEnd; // for colormapped images, bpp is size of an index
|
||||
if ( (sz != 8) && (sz != 15) && (sz != 16) && (sz != 24) && (sz != 32) ) goto errorEnd;
|
||||
|
||||
res = 1; // if we got this far, everything's good and we can return 1 instead of 0
|
||||
|
||||
errorEnd:
|
||||
stbi__rewind(s);
|
||||
return res;
|
||||
}
|
||||
|
||||
// read 16bit value and convert to 24bit RGB
|
||||
void stbi__tga_read_rgb16(stbi__context *s, stbi_uc* out)
|
||||
{
|
||||
stbi__uint16 px = stbi__get16le(s);
|
||||
stbi__uint16 fiveBitMask = 31;
|
||||
// we have 3 channels with 5bits each
|
||||
int r = (px >> 10) & fiveBitMask;
|
||||
int g = (px >> 5) & fiveBitMask;
|
||||
int b = px & fiveBitMask;
|
||||
// Note that this saves the data in RGB(A) order, so it doesn't need to be swapped later
|
||||
out[0] = (r * 255)/31;
|
||||
out[1] = (g * 255)/31;
|
||||
out[2] = (b * 255)/31;
|
||||
|
||||
// some people claim that the most significant bit might be used for alpha
|
||||
// (possibly if an alpha-bit is set in the "image descriptor byte")
|
||||
// but that only made 16bit test images completely translucent..
|
||||
// so let's treat all 15 and 16bit TGAs as RGB with no alpha.
|
||||
}
|
||||
|
||||
static stbi_uc *stbi__tga_load(stbi__context *s, int *x, int *y, int *comp, int req_comp)
|
||||
{
|
||||
// read in the TGA header stuff
|
||||
@ -4913,8 +4984,9 @@ static stbi_uc *stbi__tga_load(stbi__context *s, int *x, int *y, int *comp, int
|
||||
int tga_width = stbi__get16le(s);
|
||||
int tga_height = stbi__get16le(s);
|
||||
int tga_bits_per_pixel = stbi__get8(s);
|
||||
int tga_comp = tga_bits_per_pixel / 8;
|
||||
int tga_comp, tga_rgb16=0;
|
||||
int tga_inverted = stbi__get8(s);
|
||||
// int tga_alpha_bits = tga_inverted & 15; // the 4 lowest bits - unused (useless?)
|
||||
// image data
|
||||
unsigned char *tga_data;
|
||||
unsigned char *tga_palette = NULL;
|
||||
@ -4930,25 +5002,14 @@ static stbi_uc *stbi__tga_load(stbi__context *s, int *x, int *y, int *comp, int
|
||||
tga_image_type -= 8;
|
||||
tga_is_RLE = 1;
|
||||
}
|
||||
/* int tga_alpha_bits = tga_inverted & 15; */
|
||||
tga_inverted = 1 - ((tga_inverted >> 5) & 1);
|
||||
|
||||
// error check
|
||||
if ( //(tga_indexed) ||
|
||||
(tga_width < 1) || (tga_height < 1) ||
|
||||
(tga_image_type < 1) || (tga_image_type > 3) ||
|
||||
((tga_bits_per_pixel != 8) && (tga_bits_per_pixel != 16) &&
|
||||
(tga_bits_per_pixel != 24) && (tga_bits_per_pixel != 32))
|
||||
)
|
||||
{
|
||||
return NULL; // we don't report this as a bad TGA because we don't even know if it's TGA
|
||||
}
|
||||
|
||||
// If I'm paletted, then I'll use the number of bits from the palette
|
||||
if ( tga_indexed )
|
||||
{
|
||||
tga_comp = tga_palette_bits / 8;
|
||||
}
|
||||
if ( tga_indexed ) tga_comp = stbi__tga_get_comp(tga_palette_bits, 0, &tga_rgb16);
|
||||
else tga_comp = stbi__tga_get_comp(tga_bits_per_pixel, (tga_image_type == 3), &tga_rgb16);
|
||||
|
||||
if(!tga_comp) // shouldn't really happen, stbi__tga_test() should have ensured basic consistency
|
||||
return stbi__errpuc("bad format", "Can't find out TGA pixelformat");
|
||||
|
||||
// tga info
|
||||
*x = tga_width;
|
||||
@ -4961,7 +5022,7 @@ static stbi_uc *stbi__tga_load(stbi__context *s, int *x, int *y, int *comp, int
|
||||
// skip to the data's starting position (offset usually = 0)
|
||||
stbi__skip(s, tga_offset );
|
||||
|
||||
if ( !tga_indexed && !tga_is_RLE) {
|
||||
if ( !tga_indexed && !tga_is_RLE && !tga_rgb16 ) {
|
||||
for (i=0; i < tga_height; ++i) {
|
||||
int row = tga_inverted ? tga_height -i - 1 : i;
|
||||
stbi_uc *tga_row = tga_data + row*tga_width*tga_comp;
|
||||
@ -4974,15 +5035,22 @@ static stbi_uc *stbi__tga_load(stbi__context *s, int *x, int *y, int *comp, int
|
||||
// any data to skip? (offset usually = 0)
|
||||
stbi__skip(s, tga_palette_start );
|
||||
// load the palette
|
||||
tga_palette = (unsigned char*)stbi__malloc( tga_palette_len * tga_palette_bits / 8 );
|
||||
tga_palette = (unsigned char*)stbi__malloc( tga_palette_len * tga_comp );
|
||||
if (!tga_palette) {
|
||||
STBI_FREE(tga_data);
|
||||
return stbi__errpuc("outofmem", "Out of memory");
|
||||
}
|
||||
if (!stbi__getn(s, tga_palette, tga_palette_len * tga_palette_bits / 8 )) {
|
||||
STBI_FREE(tga_data);
|
||||
STBI_FREE(tga_palette);
|
||||
return stbi__errpuc("bad palette", "Corrupt TGA");
|
||||
if (tga_rgb16) {
|
||||
stbi_uc *pal_entry = tga_palette;
|
||||
STBI_ASSERT(tga_comp == STBI_rgb);
|
||||
for (i=0; i < tga_palette_len; ++i) {
|
||||
stbi__tga_read_rgb16(s, pal_entry);
|
||||
pal_entry += tga_comp;
|
||||
}
|
||||
} else if (!stbi__getn(s, tga_palette, tga_palette_len * tga_comp)) {
|
||||
STBI_FREE(tga_data);
|
||||
STBI_FREE(tga_palette);
|
||||
return stbi__errpuc("bad palette", "Corrupt TGA");
|
||||
}
|
||||
}
|
||||
// load the data
|
||||
@ -5012,23 +5080,22 @@ static stbi_uc *stbi__tga_load(stbi__context *s, int *x, int *y, int *comp, int
|
||||
// load however much data we did have
|
||||
if ( tga_indexed )
|
||||
{
|
||||
// read in 1 byte, then perform the lookup
|
||||
int pal_idx = stbi__get8(s);
|
||||
if ( pal_idx >= tga_palette_len )
|
||||
{
|
||||
// invalid index
|
||||
// read in index, then perform the lookup
|
||||
int pal_idx = (tga_bits_per_pixel == 8) ? stbi__get8(s) : stbi__get16le(s);
|
||||
if ( pal_idx >= tga_palette_len ) {
|
||||
// invalid index
|
||||
pal_idx = 0;
|
||||
}
|
||||
pal_idx *= tga_bits_per_pixel / 8;
|
||||
for (j = 0; j*8 < tga_bits_per_pixel; ++j)
|
||||
{
|
||||
pal_idx *= tga_comp;
|
||||
for (j = 0; j < tga_comp; ++j) {
|
||||
raw_data[j] = tga_palette[pal_idx+j];
|
||||
}
|
||||
} else
|
||||
{
|
||||
} else if(tga_rgb16) {
|
||||
STBI_ASSERT(tga_comp == STBI_rgb);
|
||||
stbi__tga_read_rgb16(s, raw_data);
|
||||
} else {
|
||||
// read in the data raw
|
||||
for (j = 0; j*8 < tga_bits_per_pixel; ++j)
|
||||
{
|
||||
for (j = 0; j < tga_comp; ++j) {
|
||||
raw_data[j] = stbi__get8(s);
|
||||
}
|
||||
}
|
||||
@ -5067,8 +5134,8 @@ static stbi_uc *stbi__tga_load(stbi__context *s, int *x, int *y, int *comp, int
|
||||
}
|
||||
}
|
||||
|
||||
// swap RGB
|
||||
if (tga_comp >= 3)
|
||||
// swap RGB - if the source data was RGB16, it already is in the right order
|
||||
if (tga_comp >= 3 && !tga_rgb16)
|
||||
{
|
||||
unsigned char* tga_pixel = tga_data;
|
||||
for (i=0; i < tga_width * tga_height; ++i)
|
||||
|
Loading…
Reference in New Issue
Block a user