You can not select more than 25 topics Topics must start with a chinese character,a letter or number, can include dashes ('-') and can be up to 35 characters long.

stb_image_write.h 83 kB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904905906907908909910911912913914915916917918919920921922923924925926927928929930931932933934935936937938939940941942943944945946947948949950951952953954955956957958959960961962963964965966967968969970971972973974975976977978979980981982983984985986987988989990991992993994995996997998999100010011002100310041005100610071008100910101011101210131014101510161017101810191020102110221023102410251026102710281029103010311032103310341035103610371038103910401041104210431044104510461047104810491050105110521053105410551056105710581059106010611062106310641065106610671068106910701071107210731074107510761077107810791080108110821083108410851086108710881089109010911092109310941095109610971098109911001101110211031104110511061107110811091110111111121113111411151116111711181119112011211122112311241125112611271128112911301131113211331134113511361137113811391140114111421143114411451146114711481149115011511152115311541155115611571158115911601161116211631164116511661167116811691170117111721173117411751176117711781179118011811182118311841185118611871188118911901191119211931194119511961197119811991200120112021203120412051206120712081209121012111212121312141215121612171218121912201221122212231224122512261227122812291230123112321233123412351236123712381239124012411242124312441245124612471248124912501251125212531254125512561257125812591260126112621263126412651266126712681269127012711272127312741275127612771278127912801281128212831284128512861287128812891290129112921293129412951296129712981299130013011302130313041305130613071308130913101311131213131314131513161317131813191320132113221323132413251326132713281329133013311332133313341335133613371338133913401341134213431344134513461347134813491350135113521353135413551356135713581359136013611362136313641365136613671368136913701371137213731374137513761377137813791380138113821383138413851386138713881389139013911392139313941395139613971398139914001401140214031404140514061407140814091410141114121413141414151416141714181419142014211422142314241425142614271428142914301431143214331434143514361437143814391440144114421443144414451446144714481449145014511452145314541455145614571458145914601461146214631464146514661467146814691470147114721473147414751476147714781479148014811482148314841485148614871488148914901491149214931494149514961497149814991500150115021503150415051506150715081509151015111512151315141515151615171518151915201521152215231524152515261527152815291530153115321533153415351536153715381539154015411542154315441545154615471548154915501551155215531554155515561557155815591560156115621563156415651566156715681569157015711572157315741575157615771578157915801581158215831584158515861587158815891590159115921593159415951596159715981599160016011602160316041605160616071608160916101611161216131614161516161617161816191620162116221623162416251626162716281629163016311632163316341635163616371638163916401641164216431644164516461647164816491650165116521653165416551656165716581659166016611662166316641665166616671668166916701671167216731674167516761677167816791680168116821683168416851686168716881689169016911692169316941695169616971698169917001701170217031704170517061707170817091710171117121713171417151716171717181719172017211722172317241725172617271728172917301731173217331734173517361737173817391740174117421743174417451746174717481749175017511752175317541755175617571758175917601761176217631764176517661767176817691770177117721773177417751776177717781779178017811782178317841785178617871788178917901791179217931794179517961797179817991800180118021803180418051806180718081809181018111812181318141815181618171818181918201821182218231824182518261827182818291830183118321833183418351836183718381839184018411842184318441845184618471848184918501851185218531854185518561857185818591860186118621863186418651866186718681869187018711872187318741875187618771878187918801881188218831884188518861887188818891890189118921893189418951896189718981899190019011902190319041905190619071908190919101911191219131914191519161917191819191920192119221923192419251926192719281929193019311932193319341935193619371938193919401941194219431944194519461947194819491950195119521953195419551956195719581959196019611962196319641965196619671968196919701971197219731974197519761977197819791980198119821983198419851986198719881989199019911992199319941995199619971998199920002001200220032004200520062007200820092010201120122013201420152016201720182019202020212022202320242025202620272028202920302031203220332034203520362037203820392040204120422043204420452046204720482049205020512052205320542055205620572058205920602061206220632064206520662067
  1. /* stb_image_write - v1.16 - public domain - http://nothings.org/stb
  2. writes out PNG/BMP/TGA/JPEG/HDR images to C stdio - Sean Barrett 2010-2015
  3. no warranty implied; use at your own risk
  4. Before #including,
  5. #define STB_IMAGE_WRITE_IMPLEMENTATION
  6. in the file that you want to have the implementation.
  7. Will probably not work correctly with strict-aliasing optimizations.
  8. ABOUT:
  9. This header file is a library for writing images to C stdio or a callback.
  10. The PNG output is not optimal; it is 20-50% larger than the file
  11. written by a decent optimizing implementation; though providing a custom
  12. zlib compress function (see STBIW_ZLIB_COMPRESS) can mitigate that.
  13. This library is designed for source code compactness and simplicity,
  14. not optimal image file size or run-time performance.
  15. BUILDING:
  16. You can #define STBIW_ASSERT(x) before the #include to avoid using assert.h.
  17. You can #define STBIW_MALLOC(), STBIW_REALLOC(), and STBIW_FREE() to replace
  18. malloc,realloc,free.
  19. You can #define STBIW_MEMMOVE() to replace memmove()
  20. You can #define STBIW_ZLIB_COMPRESS to use a custom zlib-style compress function
  21. for PNG compression (instead of the builtin one), it must have the following
  22. signature: unsigned char * my_compress(unsigned char *data, int data_len, int *out_len,
  23. int quality); The returned data will be freed with STBIW_FREE() (free() by default), so
  24. it must be heap allocated with STBIW_MALLOC() (malloc() by default),
  25. UNICODE:
  26. If compiling for Windows and you wish to use Unicode filenames, compile
  27. with
  28. #define STBIW_WINDOWS_UTF8
  29. and pass utf8-encoded filenames. Call stbiw_convert_wchar_to_utf8 to convert
  30. Windows wchar_t filenames to utf8.
  31. USAGE:
  32. There are five functions, one for each image file format:
  33. int stbi_write_png(char const *filename, int w, int h, int comp, const void *data,
  34. int stride_in_bytes); int stbi_write_bmp(char const *filename, int w, int h, int comp,
  35. const void *data); int stbi_write_tga(char const *filename, int w, int h, int comp,
  36. const void *data); int stbi_write_jpg(char const *filename, int w, int h, int comp,
  37. const void *data, int quality); int stbi_write_hdr(char const *filename, int w, int h,
  38. int comp, const float *data);
  39. void stbi_flip_vertically_on_write(int flag); // flag is non-zero to flip data
  40. vertically
  41. There are also five equivalent functions that use an arbitrary write function. You
  42. are expected to open/close your file-equivalent before and after calling these:
  43. int stbi_write_png_to_func(stbi_write_func *func, void *context, int w, int h, int
  44. comp, const void *data, int stride_in_bytes); int
  45. stbi_write_bmp_to_func(stbi_write_func *func, void *context, int w, int h, int comp,
  46. const void *data); int stbi_write_tga_to_func(stbi_write_func *func, void *context, int
  47. w, int h, int comp, const void *data); int stbi_write_hdr_to_func(stbi_write_func
  48. *func, void *context, int w, int h, int comp, const float *data); int
  49. stbi_write_jpg_to_func(stbi_write_func *func, void *context, int x, int y, int comp,
  50. const void *data, int quality);
  51. where the callback is:
  52. void stbi_write_func(void *context, void *data, int size);
  53. You can configure it with these global variables:
  54. int stbi_write_tga_with_rle; // defaults to true; set to 0 to disable
  55. RLE int stbi_write_png_compression_level; // defaults to 8; set to higher for more
  56. compression int stbi_write_force_png_filter; // defaults to -1; set to 0..5 to
  57. force a filter mode
  58. You can define STBI_WRITE_NO_STDIO to disable the file variant of these
  59. functions, so the library will not use stdio.h at all. However, this will
  60. also disable HDR writing, because it requires stdio for formatted output.
  61. Each function returns 0 on failure and non-0 on success.
  62. The functions create an image file defined by the parameters. The image
  63. is a rectangle of pixels stored from left-to-right, top-to-bottom.
  64. Each pixel contains 'comp' channels of data stored interleaved with 8-bits
  65. per channel, in the following order: 1=Y, 2=YA, 3=RGB, 4=RGBA. (Y is
  66. monochrome color.) The rectangle is 'w' pixels wide and 'h' pixels tall.
  67. The *data pointer points to the first byte of the top-left-most pixel.
  68. For PNG, "stride_in_bytes" is the distance in bytes from the first byte of
  69. a row of pixels to the first byte of the next row of pixels.
  70. PNG creates output files with the same number of components as the input.
  71. The BMP format expands Y to RGB in the file format and does not
  72. output alpha.
  73. PNG supports writing rectangles of data even when the bytes storing rows of
  74. data are not consecutive in memory (e.g. sub-rectangles of a larger image),
  75. by supplying the stride between the beginning of adjacent rows. The other
  76. formats do not. (Thus you cannot write a native-format BMP through the BMP
  77. writer, both because it is in BGR order and because it may have padding
  78. at the end of the line.)
  79. PNG allows you to set the deflate compression level by setting the global
  80. variable 'stbi_write_png_compression_level' (it defaults to 8).
  81. HDR expects linear float data. Since the format is always 32-bit rgb(e)
  82. data, alpha (if provided) is discarded, and for monochrome data it is
  83. replicated across all three channels.
  84. TGA supports RLE or non-RLE compressed data. To use non-RLE-compressed
  85. data, set the global variable 'stbi_write_tga_with_rle' to 0.
  86. JPEG does ignore alpha channels in input data; quality is between 1 and 100.
  87. Higher quality looks better but results in a bigger image.
  88. JPEG baseline (no JPEG progressive).
  89. CREDITS:
  90. Sean Barrett - PNG/BMP/TGA
  91. Baldur Karlsson - HDR
  92. Jean-Sebastien Guay - TGA monochrome
  93. Tim Kelsey - misc enhancements
  94. Alan Hickman - TGA RLE
  95. Emmanuel Julien - initial file IO callback implementation
  96. Jon Olick - original jo_jpeg.cpp code
  97. Daniel Gibson - integrate JPEG, allow external zlib
  98. Aarni Koskela - allow choosing PNG filter
  99. bugfixes:
  100. github:Chribba
  101. Guillaume Chereau
  102. github:jry2
  103. github:romigrou
  104. Sergio Gonzalez
  105. Jonas Karlsson
  106. Filip Wasil
  107. Thatcher Ulrich
  108. github:poppolopoppo
  109. Patrick Boettcher
  110. github:xeekworx
  111. Cap Petschulat
  112. Simon Rodriguez
  113. Ivan Tikhonov
  114. github:ignotion
  115. Adam Schackart
  116. Andrew Kensler
  117. LICENSE
  118. See end of file for license information.
  119. */
  120. #ifndef INCLUDE_STB_IMAGE_WRITE_H
  121. #define INCLUDE_STB_IMAGE_WRITE_H
  122. #include <stdlib.h>
  123. // if STB_IMAGE_WRITE_STATIC causes problems, try defining STBIWDEF to 'inline' or
  124. // 'static inline'
  125. #ifndef STBIWDEF
  126. #ifdef STB_IMAGE_WRITE_STATIC
  127. #define STBIWDEF static
  128. #else
  129. #ifdef __cplusplus
  130. #define STBIWDEF extern "C"
  131. #else
  132. #define STBIWDEF extern
  133. #endif
  134. #endif
  135. #endif
  136. #ifndef STB_IMAGE_WRITE_STATIC // C++ forbids static forward declarations
  137. STBIWDEF int stbi_write_tga_with_rle;
  138. STBIWDEF int stbi_write_png_compression_level;
  139. STBIWDEF int stbi_write_force_png_filter;
  140. #endif
  141. #ifndef STBI_WRITE_NO_STDIO
  142. STBIWDEF int stbi_write_png(
  143. char const* filename, int w, int h, int comp, const void* data,
  144. int stride_in_bytes);
  145. STBIWDEF int stbi_write_bmp(
  146. char const* filename, int w, int h, int comp, const void* data);
  147. STBIWDEF int stbi_write_tga(
  148. char const* filename, int w, int h, int comp, const void* data);
  149. STBIWDEF int stbi_write_hdr(
  150. char const* filename, int w, int h, int comp, const float* data);
  151. STBIWDEF int stbi_write_jpg(
  152. char const* filename, int x, int y, int comp, const void* data, int quality);
  153. #ifdef STBIW_WINDOWS_UTF8
  154. STBIWDEF int stbiw_convert_wchar_to_utf8(
  155. char* buffer, size_t bufferlen, const wchar_t* input);
  156. #endif
  157. #endif
  158. typedef void stbi_write_func(void* context, void* data, int size);
  159. STBIWDEF int stbi_write_png_to_func(
  160. stbi_write_func* func, void* context, int w, int h, int comp, const void* data,
  161. int stride_in_bytes);
  162. STBIWDEF int stbi_write_bmp_to_func(
  163. stbi_write_func* func, void* context, int w, int h, int comp, const void* data);
  164. STBIWDEF int stbi_write_tga_to_func(
  165. stbi_write_func* func, void* context, int w, int h, int comp, const void* data);
  166. STBIWDEF int stbi_write_hdr_to_func(
  167. stbi_write_func* func, void* context, int w, int h, int comp,
  168. const float* data);
  169. STBIWDEF int stbi_write_jpg_to_func(
  170. stbi_write_func* func, void* context, int x, int y, int comp, const void* data,
  171. int quality);
  172. STBIWDEF void stbi_flip_vertically_on_write(int flip_boolean);
  173. #endif // INCLUDE_STB_IMAGE_WRITE_H
  174. #ifdef STB_IMAGE_WRITE_IMPLEMENTATION
  175. #ifdef _WIN32
  176. #ifndef _CRT_SECURE_NO_WARNINGS
  177. #define _CRT_SECURE_NO_WARNINGS
  178. #endif
  179. #ifndef _CRT_NONSTDC_NO_DEPRECATE
  180. #define _CRT_NONSTDC_NO_DEPRECATE
  181. #endif
  182. #endif
  183. #ifndef STBI_WRITE_NO_STDIO
  184. #include <stdio.h>
  185. #endif // STBI_WRITE_NO_STDIO
  186. #include <math.h>
  187. #include <stdarg.h>
  188. #include <stdlib.h>
  189. #include <string.h>
  190. #if defined(STBIW_MALLOC) && defined(STBIW_FREE) && \
  191. (defined(STBIW_REALLOC) || defined(STBIW_REALLOC_SIZED))
  192. // ok
  193. #elif !defined(STBIW_MALLOC) && !defined(STBIW_FREE) && !defined(STBIW_REALLOC) && \
  194. !defined(STBIW_REALLOC_SIZED)
  195. // ok
  196. #else
  197. #error "Must define all or none of STBIW_MALLOC, STBIW_FREE, and STBIW_REALLOC (or STBIW_REALLOC_SIZED)."
  198. #endif
  199. #ifndef STBIW_MALLOC
  200. #define STBIW_MALLOC(sz) malloc(sz)
  201. #define STBIW_REALLOC(p, newsz) realloc(p, newsz)
  202. #define STBIW_FREE(p) free(p)
  203. #endif
  204. #ifndef STBIW_REALLOC_SIZED
  205. #define STBIW_REALLOC_SIZED(p, oldsz, newsz) STBIW_REALLOC(p, newsz)
  206. #endif
  207. #ifndef STBIW_MEMMOVE
  208. #define STBIW_MEMMOVE(a, b, sz) memmove(a, b, sz)
  209. #endif
  210. #ifndef STBIW_ASSERT
  211. #include <assert.h>
  212. #define STBIW_ASSERT(x) assert(x)
  213. #endif
  214. #define STBIW_UCHAR(x) (unsigned char)((x)&0xff)
  215. #ifdef STB_IMAGE_WRITE_STATIC
  216. static int stbi_write_png_compression_level = 8;
  217. static int stbi_write_tga_with_rle = 1;
  218. static int stbi_write_force_png_filter = -1;
  219. #else
  220. int stbi_write_png_compression_level = 8;
  221. int stbi_write_tga_with_rle = 1;
  222. int stbi_write_force_png_filter = -1;
  223. #endif
  224. static int stbi__flip_vertically_on_write = 0;
  225. STBIWDEF void stbi_flip_vertically_on_write(int flag) {
  226. stbi__flip_vertically_on_write = flag;
  227. }
  228. typedef struct {
  229. stbi_write_func* func;
  230. void* context;
  231. unsigned char buffer[64];
  232. int buf_used;
  233. } stbi__write_context;
  234. // initialize a callback-based context
  235. static void stbi__start_write_callbacks(
  236. stbi__write_context* s, stbi_write_func* c, void* context) {
  237. s->func = c;
  238. s->context = context;
  239. }
  240. #ifndef STBI_WRITE_NO_STDIO
  241. static void stbi__stdio_write(void* context, void* data, int size) {
  242. fwrite(data, 1, size, (FILE*)context);
  243. }
  244. #if defined(_WIN32) && defined(STBIW_WINDOWS_UTF8)
  245. #ifdef __cplusplus
  246. #define STBIW_EXTERN extern "C"
  247. #else
  248. #define STBIW_EXTERN extern
  249. #endif
  250. STBIW_EXTERN __declspec(dllimport) int __stdcall MultiByteToWideChar(
  251. unsigned int cp, unsigned long flags, const char* str, int cbmb,
  252. wchar_t* widestr, int cchwide);
  253. STBIW_EXTERN __declspec(dllimport) int __stdcall WideCharToMultiByte(
  254. unsigned int cp, unsigned long flags, const wchar_t* widestr, int cchwide,
  255. char* str, int cbmb, const char* defchar, int* used_default);
  256. STBIWDEF int stbiw_convert_wchar_to_utf8(
  257. char* buffer, size_t bufferlen, const wchar_t* input) {
  258. return WideCharToMultiByte(
  259. 65001 /* UTF8 */, 0, input, -1, buffer, (int)bufferlen, NULL, NULL);
  260. }
  261. #endif
  262. static FILE* stbiw__fopen(char const* filename, char const* mode) {
  263. FILE* f;
  264. #if defined(_WIN32) && defined(STBIW_WINDOWS_UTF8)
  265. wchar_t wMode[64];
  266. wchar_t wFilename[1024];
  267. if (0 == MultiByteToWideChar(
  268. 65001 /* UTF8 */, 0, filename, -1, wFilename,
  269. sizeof(wFilename) / sizeof(*wFilename)))
  270. return 0;
  271. if (0 ==
  272. MultiByteToWideChar(
  273. 65001 /* UTF8 */, 0, mode, -1, wMode, sizeof(wMode) / sizeof(*wMode)))
  274. return 0;
  275. #if defined(_MSC_VER) && _MSC_VER >= 1400
  276. if (0 != _wfopen_s(&f, wFilename, wMode))
  277. f = 0;
  278. #else
  279. f = _wfopen(wFilename, wMode);
  280. #endif
  281. #elif defined(_MSC_VER) && _MSC_VER >= 1400
  282. if (0 != fopen_s(&f, filename, mode))
  283. f = 0;
  284. #else
  285. f = fopen(filename, mode);
  286. #endif
  287. return f;
  288. }
  289. static int stbi__start_write_file(stbi__write_context* s, const char* filename) {
  290. FILE* f = stbiw__fopen(filename, "wb");
  291. stbi__start_write_callbacks(s, stbi__stdio_write, (void*)f);
  292. return f != NULL;
  293. }
  294. static void stbi__end_write_file(stbi__write_context* s) {
  295. fclose((FILE*)s->context);
  296. }
  297. #endif // !STBI_WRITE_NO_STDIO
  298. typedef unsigned int stbiw_uint32;
  299. typedef int stb_image_write_test[sizeof(stbiw_uint32) == 4 ? 1 : -1];
  300. static void stbiw__writefv(stbi__write_context* s, const char* fmt, va_list v) {
  301. while (*fmt) {
  302. switch (*fmt++) {
  303. case ' ':
  304. break;
  305. case '1': {
  306. unsigned char x = STBIW_UCHAR(va_arg(v, int));
  307. s->func(s->context, &x, 1);
  308. break;
  309. }
  310. case '2': {
  311. int x = va_arg(v, int);
  312. unsigned char b[2];
  313. b[0] = STBIW_UCHAR(x);
  314. b[1] = STBIW_UCHAR(x >> 8);
  315. s->func(s->context, b, 2);
  316. break;
  317. }
  318. case '4': {
  319. stbiw_uint32 x = va_arg(v, int);
  320. unsigned char b[4];
  321. b[0] = STBIW_UCHAR(x);
  322. b[1] = STBIW_UCHAR(x >> 8);
  323. b[2] = STBIW_UCHAR(x >> 16);
  324. b[3] = STBIW_UCHAR(x >> 24);
  325. s->func(s->context, b, 4);
  326. break;
  327. }
  328. default:
  329. STBIW_ASSERT(0);
  330. return;
  331. }
  332. }
  333. }
  334. static void stbiw__writef(stbi__write_context* s, const char* fmt, ...) {
  335. va_list v;
  336. va_start(v, fmt);
  337. stbiw__writefv(s, fmt, v);
  338. va_end(v);
  339. }
  340. static void stbiw__write_flush(stbi__write_context* s) {
  341. if (s->buf_used) {
  342. s->func(s->context, &s->buffer, s->buf_used);
  343. s->buf_used = 0;
  344. }
  345. }
  346. static void stbiw__putc(stbi__write_context* s, unsigned char c) {
  347. s->func(s->context, &c, 1);
  348. }
  349. static void stbiw__write1(stbi__write_context* s, unsigned char a) {
  350. if ((size_t)s->buf_used + 1 > sizeof(s->buffer))
  351. stbiw__write_flush(s);
  352. s->buffer[s->buf_used++] = a;
  353. }
  354. static void stbiw__write3(
  355. stbi__write_context* s, unsigned char a, unsigned char b, unsigned char c) {
  356. int n;
  357. if ((size_t)s->buf_used + 3 > sizeof(s->buffer))
  358. stbiw__write_flush(s);
  359. n = s->buf_used;
  360. s->buf_used = n + 3;
  361. s->buffer[n + 0] = a;
  362. s->buffer[n + 1] = b;
  363. s->buffer[n + 2] = c;
  364. }
  365. static void stbiw__write_pixel(
  366. stbi__write_context* s, int rgb_dir, int comp, int write_alpha, int expand_mono,
  367. unsigned char* d) {
  368. unsigned char bg[3] = {255, 0, 255}, px[3];
  369. int k;
  370. if (write_alpha < 0)
  371. stbiw__write1(s, d[comp - 1]);
  372. switch (comp) {
  373. case 2: // 2 pixels = mono + alpha, alpha is written separately, so same as
  374. // 1-channel case
  375. case 1:
  376. if (expand_mono)
  377. stbiw__write3(s, d[0], d[0], d[0]); // monochrome bmp
  378. else
  379. stbiw__write1(s, d[0]); // monochrome TGA
  380. break;
  381. case 4:
  382. if (!write_alpha) {
  383. // composite against pink background
  384. for (k = 0; k < 3; ++k)
  385. px[k] = bg[k] + ((d[k] - bg[k]) * d[3]) / 255;
  386. stbiw__write3(s, px[1 - rgb_dir], px[1], px[1 + rgb_dir]);
  387. break;
  388. }
  389. /* FALLTHROUGH */
  390. case 3:
  391. stbiw__write3(s, d[1 - rgb_dir], d[1], d[1 + rgb_dir]);
  392. break;
  393. }
  394. if (write_alpha > 0)
  395. stbiw__write1(s, d[comp - 1]);
  396. }
  397. static void stbiw__write_pixels(
  398. stbi__write_context* s, int rgb_dir, int vdir, int x, int y, int comp,
  399. void* data, int write_alpha, int scanline_pad, int expand_mono) {
  400. stbiw_uint32 zero = 0;
  401. int i, j, j_end;
  402. if (y <= 0)
  403. return;
  404. if (stbi__flip_vertically_on_write)
  405. vdir *= -1;
  406. if (vdir < 0) {
  407. j_end = -1;
  408. j = y - 1;
  409. } else {
  410. j_end = y;
  411. j = 0;
  412. }
  413. for (; j != j_end; j += vdir) {
  414. for (i = 0; i < x; ++i) {
  415. unsigned char* d = (unsigned char*)data + (j * x + i) * comp;
  416. stbiw__write_pixel(s, rgb_dir, comp, write_alpha, expand_mono, d);
  417. }
  418. stbiw__write_flush(s);
  419. s->func(s->context, &zero, scanline_pad);
  420. }
  421. }
  422. static int stbiw__outfile(
  423. stbi__write_context* s, int rgb_dir, int vdir, int x, int y, int comp,
  424. int expand_mono, void* data, int alpha, int pad, const char* fmt, ...) {
  425. if (y < 0 || x < 0) {
  426. return 0;
  427. } else {
  428. va_list v;
  429. va_start(v, fmt);
  430. stbiw__writefv(s, fmt, v);
  431. va_end(v);
  432. stbiw__write_pixels(
  433. s, rgb_dir, vdir, x, y, comp, data, alpha, pad, expand_mono);
  434. return 1;
  435. }
  436. }
  437. static int stbi_write_bmp_core(
  438. stbi__write_context* s, int x, int y, int comp, const void* data) {
  439. if (comp != 4) {
  440. // write RGB bitmap
  441. int pad = (-x * 3) & 3;
  442. return stbiw__outfile(
  443. s, -1, -1, x, y, comp, 1, (void*)data, 0, pad,
  444. "11 4 22 4"
  445. "4 44 22 444444",
  446. 'B', 'M', 14 + 40 + (x * 3 + pad) * y, 0, 0, 14 + 40, // file header
  447. 40, x, y, 1, 24, 0, 0, 0, 0, 0, 0); // bitmap header
  448. } else {
  449. // RGBA bitmaps need a v4 header
  450. // use BI_BITFIELDS mode with 32bpp and alpha mask
  451. // (straight BI_RGB with alpha mask doesn't work in most readers)
  452. return stbiw__outfile(
  453. s, -1, -1, x, y, comp, 1, (void*)data, 1, 0,
  454. "11 4 22 4"
  455. "4 44 22 444444 4444 4 444 444 444 444",
  456. 'B', 'M', 14 + 108 + x * y * 4, 0, 0, 14 + 108, // file header
  457. 108, x, y, 1, 32, 3, 0, 0, 0, 0, 0, 0xff0000, 0xff00, 0xff, 0xff000000u,
  458. 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0); // bitmap V4 header
  459. }
  460. }
  461. STBIWDEF int stbi_write_bmp_to_func(
  462. stbi_write_func* func, void* context, int x, int y, int comp,
  463. const void* data) {
  464. stbi__write_context s = {0};
  465. stbi__start_write_callbacks(&s, func, context);
  466. return stbi_write_bmp_core(&s, x, y, comp, data);
  467. }
  468. #ifndef STBI_WRITE_NO_STDIO
  469. STBIWDEF int stbi_write_bmp(
  470. char const* filename, int x, int y, int comp, const void* data) {
  471. stbi__write_context s = {0};
  472. if (stbi__start_write_file(&s, filename)) {
  473. int r = stbi_write_bmp_core(&s, x, y, comp, data);
  474. stbi__end_write_file(&s);
  475. return r;
  476. } else
  477. return 0;
  478. }
  479. #endif //! STBI_WRITE_NO_STDIO
  480. static int stbi_write_tga_core(
  481. stbi__write_context* s, int x, int y, int comp, void* data) {
  482. int has_alpha = (comp == 2 || comp == 4);
  483. int colorbytes = has_alpha ? comp - 1 : comp;
  484. int format =
  485. colorbytes < 2
  486. ? 3
  487. : 2; // 3 color channels (RGB/RGBA) = 2, 1 color channel (Y/YA) = 3
  488. if (y < 0 || x < 0)
  489. return 0;
  490. if (!stbi_write_tga_with_rle) {
  491. return stbiw__outfile(
  492. s, -1, -1, x, y, comp, 0, (void*)data, has_alpha, 0, "111 221 2222 11",
  493. 0, 0, format, 0, 0, 0, 0, 0, x, y, (colorbytes + has_alpha) * 8,
  494. has_alpha * 8);
  495. } else {
  496. int i, j, k;
  497. int jend, jdir;
  498. stbiw__writef(
  499. s, "111 221 2222 11", 0, 0, format + 8, 0, 0, 0, 0, 0, x, y,
  500. (colorbytes + has_alpha) * 8, has_alpha * 8);
  501. if (stbi__flip_vertically_on_write) {
  502. j = 0;
  503. jend = y;
  504. jdir = 1;
  505. } else {
  506. j = y - 1;
  507. jend = -1;
  508. jdir = -1;
  509. }
  510. for (; j != jend; j += jdir) {
  511. unsigned char* row = (unsigned char*)data + j * x * comp;
  512. int len;
  513. for (i = 0; i < x; i += len) {
  514. unsigned char* begin = row + i * comp;
  515. int diff = 1;
  516. len = 1;
  517. if (i < x - 1) {
  518. ++len;
  519. diff = memcmp(begin, row + (i + 1) * comp, comp);
  520. if (diff) {
  521. const unsigned char* prev = begin;
  522. for (k = i + 2; k < x && len < 128; ++k) {
  523. if (memcmp(prev, row + k * comp, comp)) {
  524. prev += comp;
  525. ++len;
  526. } else {
  527. --len;
  528. break;
  529. }
  530. }
  531. } else {
  532. for (k = i + 2; k < x && len < 128; ++k) {
  533. if (!memcmp(begin, row + k * comp, comp)) {
  534. ++len;
  535. } else {
  536. break;
  537. }
  538. }
  539. }
  540. }
  541. if (diff) {
  542. unsigned char header = STBIW_UCHAR(len - 1);
  543. stbiw__write1(s, header);
  544. for (k = 0; k < len; ++k) {
  545. stbiw__write_pixel(s, -1, comp, has_alpha, 0, begin + k * comp);
  546. }
  547. } else {
  548. unsigned char header = STBIW_UCHAR(len - 129);
  549. stbiw__write1(s, header);
  550. stbiw__write_pixel(s, -1, comp, has_alpha, 0, begin);
  551. }
  552. }
  553. }
  554. stbiw__write_flush(s);
  555. }
  556. return 1;
  557. }
  558. STBIWDEF int stbi_write_tga_to_func(
  559. stbi_write_func* func, void* context, int x, int y, int comp,
  560. const void* data) {
  561. stbi__write_context s = {0};
  562. stbi__start_write_callbacks(&s, func, context);
  563. return stbi_write_tga_core(&s, x, y, comp, (void*)data);
  564. }
  565. #ifndef STBI_WRITE_NO_STDIO
  566. STBIWDEF int stbi_write_tga(
  567. char const* filename, int x, int y, int comp, const void* data) {
  568. stbi__write_context s = {0};
  569. if (stbi__start_write_file(&s, filename)) {
  570. int r = stbi_write_tga_core(&s, x, y, comp, (void*)data);
  571. stbi__end_write_file(&s);
  572. return r;
  573. } else
  574. return 0;
  575. }
  576. #endif
  577. // *************************************************************************************************
  578. // Radiance RGBE HDR writer
  579. // by Baldur Karlsson
  580. #define stbiw__max(a, b) ((a) > (b) ? (a) : (b))
  581. #ifndef STBI_WRITE_NO_STDIO
  582. static void stbiw__linear_to_rgbe(unsigned char* rgbe, float* linear) {
  583. int exponent;
  584. float maxcomp = stbiw__max(linear[0], stbiw__max(linear[1], linear[2]));
  585. if (maxcomp < 1e-32f) {
  586. rgbe[0] = rgbe[1] = rgbe[2] = rgbe[3] = 0;
  587. } else {
  588. float normalize = (float)frexp(maxcomp, &exponent) * 256.0f / maxcomp;
  589. rgbe[0] = (unsigned char)(linear[0] * normalize);
  590. rgbe[1] = (unsigned char)(linear[1] * normalize);
  591. rgbe[2] = (unsigned char)(linear[2] * normalize);
  592. rgbe[3] = (unsigned char)(exponent + 128);
  593. }
  594. }
  595. static void stbiw__write_run_data(
  596. stbi__write_context* s, int length, unsigned char databyte) {
  597. unsigned char lengthbyte = STBIW_UCHAR(length + 128);
  598. STBIW_ASSERT(length + 128 <= 255);
  599. s->func(s->context, &lengthbyte, 1);
  600. s->func(s->context, &databyte, 1);
  601. }
  602. static void stbiw__write_dump_data(
  603. stbi__write_context* s, int length, unsigned char* data) {
  604. unsigned char lengthbyte = STBIW_UCHAR(length);
  605. STBIW_ASSERT(
  606. length <= 128); // inconsistent with spec but consistent with official code
  607. s->func(s->context, &lengthbyte, 1);
  608. s->func(s->context, data, length);
  609. }
  610. static void stbiw__write_hdr_scanline(
  611. stbi__write_context* s, int width, int ncomp, unsigned char* scratch,
  612. float* scanline) {
  613. unsigned char scanlineheader[4] = {2, 2, 0, 0};
  614. unsigned char rgbe[4];
  615. float linear[3];
  616. int x;
  617. scanlineheader[2] = (width & 0xff00) >> 8;
  618. scanlineheader[3] = (width & 0x00ff);
  619. /* skip RLE for images too small or large */
  620. if (width < 8 || width >= 32768) {
  621. for (x = 0; x < width; x++) {
  622. switch (ncomp) {
  623. case 4: /* fallthrough */
  624. case 3:
  625. linear[2] = scanline[x * ncomp + 2];
  626. linear[1] = scanline[x * ncomp + 1];
  627. linear[0] = scanline[x * ncomp + 0];
  628. break;
  629. default:
  630. linear[0] = linear[1] = linear[2] = scanline[x * ncomp + 0];
  631. break;
  632. }
  633. stbiw__linear_to_rgbe(rgbe, linear);
  634. s->func(s->context, rgbe, 4);
  635. }
  636. } else {
  637. int c, r;
  638. /* encode into scratch buffer */
  639. for (x = 0; x < width; x++) {
  640. switch (ncomp) {
  641. case 4: /* fallthrough */
  642. case 3:
  643. linear[2] = scanline[x * ncomp + 2];
  644. linear[1] = scanline[x * ncomp + 1];
  645. linear[0] = scanline[x * ncomp + 0];
  646. break;
  647. default:
  648. linear[0] = linear[1] = linear[2] = scanline[x * ncomp + 0];
  649. break;
  650. }
  651. stbiw__linear_to_rgbe(rgbe, linear);
  652. scratch[x + width * 0] = rgbe[0];
  653. scratch[x + width * 1] = rgbe[1];
  654. scratch[x + width * 2] = rgbe[2];
  655. scratch[x + width * 3] = rgbe[3];
  656. }
  657. s->func(s->context, scanlineheader, 4);
  658. /* RLE each component separately */
  659. for (c = 0; c < 4; c++) {
  660. unsigned char* comp = &scratch[width * c];
  661. x = 0;
  662. while (x < width) {
  663. // find first run
  664. r = x;
  665. while (r + 2 < width) {
  666. if (comp[r] == comp[r + 1] && comp[r] == comp[r + 2])
  667. break;
  668. ++r;
  669. }
  670. if (r + 2 >= width)
  671. r = width;
  672. // dump up to first run
  673. while (x < r) {
  674. int len = r - x;
  675. if (len > 128)
  676. len = 128;
  677. stbiw__write_dump_data(s, len, &comp[x]);
  678. x += len;
  679. }
  680. // if there's a run, output it
  681. if (r + 2 < width) { // same test as what we break out of in search
  682. // loop, so only true if we break'd
  683. // find next byte after run
  684. while (r < width && comp[r] == comp[x])
  685. ++r;
  686. // output run up to r
  687. while (x < r) {
  688. int len = r - x;
  689. if (len > 127)
  690. len = 127;
  691. stbiw__write_run_data(s, len, comp[x]);
  692. x += len;
  693. }
  694. }
  695. }
  696. }
  697. }
  698. }
  699. static int stbi_write_hdr_core(
  700. stbi__write_context* s, int x, int y, int comp, float* data) {
  701. if (y <= 0 || x <= 0 || data == NULL)
  702. return 0;
  703. else {
  704. // Each component is stored separately. Allocate scratch space for full output
  705. // scanline.
  706. unsigned char* scratch = (unsigned char*)STBIW_MALLOC(x * 4);
  707. int i, len;
  708. char buffer[128];
  709. char header[] =
  710. "#?RADIANCE\n# Written by stb_image_write.h\nFORMAT=32-bit_rle_rgbe\n";
  711. s->func(s->context, header, sizeof(header) - 1);
  712. #ifdef __STDC_LIB_EXT1__
  713. len = sprintf_s(
  714. buffer, sizeof(buffer),
  715. "EXPOSURE= 1.0000000000000\n\n-Y %d +X %d\n", y, x);
  716. #else
  717. len = sprintf(
  718. buffer, "EXPOSURE= 1.0000000000000\n\n-Y %d +X %d\n", y, x);
  719. #endif
  720. s->func(s->context, buffer, len);
  721. for (i = 0; i < y; i++)
  722. stbiw__write_hdr_scanline(
  723. s, x, comp, scratch,
  724. data + comp * x * (stbi__flip_vertically_on_write ? y - 1 - i : i));
  725. STBIW_FREE(scratch);
  726. return 1;
  727. }
  728. }
  729. STBIWDEF int stbi_write_hdr_to_func(
  730. stbi_write_func* func, void* context, int x, int y, int comp,
  731. const float* data) {
  732. stbi__write_context s = {0};
  733. stbi__start_write_callbacks(&s, func, context);
  734. return stbi_write_hdr_core(&s, x, y, comp, (float*)data);
  735. }
  736. STBIWDEF int stbi_write_hdr(
  737. char const* filename, int x, int y, int comp, const float* data) {
  738. stbi__write_context s = {0};
  739. if (stbi__start_write_file(&s, filename)) {
  740. int r = stbi_write_hdr_core(&s, x, y, comp, (float*)data);
  741. stbi__end_write_file(&s);
  742. return r;
  743. } else
  744. return 0;
  745. }
  746. #endif // STBI_WRITE_NO_STDIO
  747. //////////////////////////////////////////////////////////////////////////////
  748. //
  749. // PNG writer
  750. //
  751. #ifndef STBIW_ZLIB_COMPRESS
  752. // stretchy buffer; stbiw__sbpush() == vector<>::push_back() -- stbiw__sbcount() ==
  753. // vector<>::size()
  754. #define stbiw__sbraw(a) ((int*)(void*)(a)-2)
  755. #define stbiw__sbm(a) stbiw__sbraw(a)[0]
  756. #define stbiw__sbn(a) stbiw__sbraw(a)[1]
  757. #define stbiw__sbneedgrow(a, n) ((a) == 0 || stbiw__sbn(a) + n >= stbiw__sbm(a))
  758. #define stbiw__sbmaybegrow(a, n) (stbiw__sbneedgrow(a, (n)) ? stbiw__sbgrow(a, n) : 0)
  759. #define stbiw__sbgrow(a, n) stbiw__sbgrowf((void**)&(a), (n), sizeof(*(a)))
  760. #define stbiw__sbpush(a, v) (stbiw__sbmaybegrow(a, 1), (a)[stbiw__sbn(a)++] = (v))
  761. #define stbiw__sbcount(a) ((a) ? stbiw__sbn(a) : 0)
  762. #define stbiw__sbfree(a) ((a) ? STBIW_FREE(stbiw__sbraw(a)), 0 : 0)
  763. static void* stbiw__sbgrowf(void** arr, int increment, int itemsize) {
  764. int m = *arr ? 2 * stbiw__sbm(*arr) + increment : increment + 1;
  765. void* p = STBIW_REALLOC_SIZED(
  766. *arr ? stbiw__sbraw(*arr) : 0,
  767. *arr ? (stbiw__sbm(*arr) * itemsize + sizeof(int) * 2) : 0,
  768. itemsize * m + sizeof(int) * 2);
  769. STBIW_ASSERT(p);
  770. if (p) {
  771. if (!*arr)
  772. ((int*)p)[1] = 0;
  773. *arr = (void*)((int*)p + 2);
  774. stbiw__sbm(*arr) = m;
  775. }
  776. return *arr;
  777. }
  778. static unsigned char* stbiw__zlib_flushf(
  779. unsigned char* data, unsigned int* bitbuffer, int* bitcount) {
  780. while (*bitcount >= 8) {
  781. stbiw__sbpush(data, STBIW_UCHAR(*bitbuffer));
  782. *bitbuffer >>= 8;
  783. *bitcount -= 8;
  784. }
  785. return data;
  786. }
  787. static int stbiw__zlib_bitrev(int code, int codebits) {
  788. int res = 0;
  789. while (codebits--) {
  790. res = (res << 1) | (code & 1);
  791. code >>= 1;
  792. }
  793. return res;
  794. }
  795. static unsigned int stbiw__zlib_countm(unsigned char* a, unsigned char* b, int limit) {
  796. int i;
  797. for (i = 0; i < limit && i < 258; ++i)
  798. if (a[i] != b[i])
  799. break;
  800. return i;
  801. }
  802. static unsigned int stbiw__zhash(unsigned char* data) {
  803. stbiw_uint32 hash = data[0] + (data[1] << 8) + (data[2] << 16);
  804. hash ^= hash << 3;
  805. hash += hash >> 5;
  806. hash ^= hash << 4;
  807. hash += hash >> 17;
  808. hash ^= hash << 25;
  809. hash += hash >> 6;
  810. return hash;
  811. }
  812. #define stbiw__zlib_flush() (out = stbiw__zlib_flushf(out, &bitbuf, &bitcount))
  813. #define stbiw__zlib_add(code, codebits) \
  814. (bitbuf |= (code) << bitcount, bitcount += (codebits), stbiw__zlib_flush())
  815. #define stbiw__zlib_huffa(b, c) stbiw__zlib_add(stbiw__zlib_bitrev(b, c), c)
  816. // default huffman tables
  817. #define stbiw__zlib_huff1(n) stbiw__zlib_huffa(0x30 + (n), 8)
  818. #define stbiw__zlib_huff2(n) stbiw__zlib_huffa(0x190 + (n)-144, 9)
  819. #define stbiw__zlib_huff3(n) stbiw__zlib_huffa(0 + (n)-256, 7)
  820. #define stbiw__zlib_huff4(n) stbiw__zlib_huffa(0xc0 + (n)-280, 8)
  821. #define stbiw__zlib_huff(n) \
  822. ((n) <= 143 ? stbiw__zlib_huff1(n) \
  823. : (n) <= 255 ? stbiw__zlib_huff2(n) \
  824. : (n) <= 279 ? stbiw__zlib_huff3(n) \
  825. : stbiw__zlib_huff4(n))
  826. #define stbiw__zlib_huffb(n) ((n) <= 143 ? stbiw__zlib_huff1(n) : stbiw__zlib_huff2(n))
  827. #define stbiw__ZHASH 16384
  828. #endif // STBIW_ZLIB_COMPRESS
  829. STBIWDEF unsigned char* stbi_zlib_compress(
  830. unsigned char* data, int data_len, int* out_len, int quality) {
  831. #ifdef STBIW_ZLIB_COMPRESS
  832. // user provided a zlib compress implementation, use that
  833. return STBIW_ZLIB_COMPRESS(data, data_len, out_len, quality);
  834. #else // use builtin
  835. static unsigned short lengthc[] = {3, 4, 5, 6, 7, 8, 9, 10, 11, 13,
  836. 15, 17, 19, 23, 27, 31, 35, 43, 51, 59,
  837. 67, 83, 99, 115, 131, 163, 195, 227, 258, 259};
  838. static unsigned char lengtheb[] = {0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 2, 2, 2,
  839. 2, 3, 3, 3, 3, 4, 4, 4, 4, 5, 5, 5, 5, 0};
  840. static unsigned short distc[] = {1, 2, 3, 4, 5, 7, 9, 13,
  841. 17, 25, 33, 49, 65, 97, 129, 193,
  842. 257, 385, 513, 769, 1025, 1537, 2049, 3073,
  843. 4097, 6145, 8193, 12289, 16385, 24577, 32768};
  844. static unsigned char disteb[] = {0, 0, 0, 0, 1, 1, 2, 2, 3, 3,
  845. 4, 4, 5, 5, 6, 6, 7, 7, 8, 8,
  846. 9, 9, 10, 10, 11, 11, 12, 12, 13, 13};
  847. unsigned int bitbuf = 0;
  848. int i, j, bitcount = 0;
  849. unsigned char* out = NULL;
  850. unsigned char*** hash_table =
  851. (unsigned char***)STBIW_MALLOC(stbiw__ZHASH * sizeof(unsigned char**));
  852. if (hash_table == NULL)
  853. return NULL;
  854. if (quality < 5)
  855. quality = 5;
  856. stbiw__sbpush(out, 0x78); // DEFLATE 32K window
  857. stbiw__sbpush(out, 0x5e); // FLEVEL = 1
  858. stbiw__zlib_add(1, 1); // BFINAL = 1
  859. stbiw__zlib_add(1, 2); // BTYPE = 1 -- fixed huffman
  860. for (i = 0; i < stbiw__ZHASH; ++i)
  861. hash_table[i] = NULL;
  862. i = 0;
  863. while (i < data_len - 3) {
  864. // hash next 3 bytes of data to be compressed
  865. int h = stbiw__zhash(data + i) & (stbiw__ZHASH - 1), best = 3;
  866. unsigned char* bestloc = 0;
  867. unsigned char** hlist = hash_table[h];
  868. int n = stbiw__sbcount(hlist);
  869. for (j = 0; j < n; ++j) {
  870. if (hlist[j] - data > i - 32768) { // if entry lies within window
  871. int d = stbiw__zlib_countm(hlist[j], data + i, data_len - i);
  872. if (d >= best) {
  873. best = d;
  874. bestloc = hlist[j];
  875. }
  876. }
  877. }
  878. // when hash table entry is too long, delete half the entries
  879. if (hash_table[h] && stbiw__sbn(hash_table[h]) == 2 * quality) {
  880. STBIW_MEMMOVE(
  881. hash_table[h], hash_table[h] + quality,
  882. sizeof(hash_table[h][0]) * quality);
  883. stbiw__sbn(hash_table[h]) = quality;
  884. }
  885. stbiw__sbpush(hash_table[h], data + i);
  886. if (bestloc) {
  887. // "lazy matching" - check match at *next* byte, and if it's better, do cur
  888. // byte as literal
  889. h = stbiw__zhash(data + i + 1) & (stbiw__ZHASH - 1);
  890. hlist = hash_table[h];
  891. n = stbiw__sbcount(hlist);
  892. for (j = 0; j < n; ++j) {
  893. if (hlist[j] - data > i - 32767) {
  894. int e = stbiw__zlib_countm(
  895. hlist[j], data + i + 1, data_len - i - 1);
  896. if (e > best) { // if next match is better, bail on current match
  897. bestloc = NULL;
  898. break;
  899. }
  900. }
  901. }
  902. }
  903. if (bestloc) {
  904. int d = (int)(data + i - bestloc); // distance back
  905. STBIW_ASSERT(d <= 32767 && best <= 258);
  906. for (j = 0; best > lengthc[j + 1] - 1; ++j)
  907. ;
  908. stbiw__zlib_huff(j + 257);
  909. if (lengtheb[j])
  910. stbiw__zlib_add(best - lengthc[j], lengtheb[j]);
  911. for (j = 0; d > distc[j + 1] - 1; ++j)
  912. ;
  913. stbiw__zlib_add(stbiw__zlib_bitrev(j, 5), 5);
  914. if (disteb[j])
  915. stbiw__zlib_add(d - distc[j], disteb[j]);
  916. i += best;
  917. } else {
  918. stbiw__zlib_huffb(data[i]);
  919. ++i;
  920. }
  921. }
  922. // write out final bytes
  923. for (; i < data_len; ++i)
  924. stbiw__zlib_huffb(data[i]);
  925. stbiw__zlib_huff(256); // end of block
  926. // pad with 0 bits to byte boundary
  927. while (bitcount)
  928. stbiw__zlib_add(0, 1);
  929. for (i = 0; i < stbiw__ZHASH; ++i)
  930. (void)stbiw__sbfree(hash_table[i]);
  931. STBIW_FREE(hash_table);
  932. // store uncompressed instead if compression was worse
  933. if (stbiw__sbn(out) > data_len + 2 + ((data_len + 32766) / 32767) * 5) {
  934. stbiw__sbn(out) = 2; // truncate to DEFLATE 32K window and FLEVEL = 1
  935. for (j = 0; j < data_len;) {
  936. int blocklen = data_len - j;
  937. if (blocklen > 32767)
  938. blocklen = 32767;
  939. stbiw__sbpush(
  940. out, data_len - j ==
  941. blocklen); // BFINAL = ?, BTYPE = 0 -- no compression
  942. stbiw__sbpush(out, STBIW_UCHAR(blocklen)); // LEN
  943. stbiw__sbpush(out, STBIW_UCHAR(blocklen >> 8));
  944. stbiw__sbpush(out, STBIW_UCHAR(~blocklen)); // NLEN
  945. stbiw__sbpush(out, STBIW_UCHAR(~blocklen >> 8));
  946. memcpy(out + stbiw__sbn(out), data + j, blocklen);
  947. stbiw__sbn(out) += blocklen;
  948. j += blocklen;
  949. }
  950. }
  951. {
  952. // compute adler32 on input
  953. unsigned int s1 = 1, s2 = 0;
  954. int blocklen = (int)(data_len % 5552);
  955. j = 0;
  956. while (j < data_len) {
  957. for (i = 0; i < blocklen; ++i) {
  958. s1 += data[j + i];
  959. s2 += s1;
  960. }
  961. s1 %= 65521;
  962. s2 %= 65521;
  963. j += blocklen;
  964. blocklen = 5552;
  965. }
  966. stbiw__sbpush(out, STBIW_UCHAR(s2 >> 8));
  967. stbiw__sbpush(out, STBIW_UCHAR(s2));
  968. stbiw__sbpush(out, STBIW_UCHAR(s1 >> 8));
  969. stbiw__sbpush(out, STBIW_UCHAR(s1));
  970. }
  971. *out_len = stbiw__sbn(out);
  972. // make returned pointer freeable
  973. STBIW_MEMMOVE(stbiw__sbraw(out), out, *out_len);
  974. return (unsigned char*)stbiw__sbraw(out);
  975. #endif // STBIW_ZLIB_COMPRESS
  976. }
  977. static unsigned int stbiw__crc32(unsigned char* buffer, int len) {
  978. #ifdef STBIW_CRC32
  979. return STBIW_CRC32(buffer, len);
  980. #else
  981. static unsigned int crc_table[256] = {
  982. 0x00000000, 0x77073096, 0xEE0E612C, 0x990951BA, 0x076DC419, 0x706AF48F,
  983. 0xE963A535, 0x9E6495A3, 0x0eDB8832, 0x79DCB8A4, 0xE0D5E91E, 0x97D2D988,
  984. 0x09B64C2B, 0x7EB17CBD, 0xE7B82D07, 0x90BF1D91, 0x1DB71064, 0x6AB020F2,
  985. 0xF3B97148, 0x84BE41DE, 0x1ADAD47D, 0x6DDDE4EB, 0xF4D4B551, 0x83D385C7,
  986. 0x136C9856, 0x646BA8C0, 0xFD62F97A, 0x8A65C9EC, 0x14015C4F, 0x63066CD9,
  987. 0xFA0F3D63, 0x8D080DF5, 0x3B6E20C8, 0x4C69105E, 0xD56041E4, 0xA2677172,
  988. 0x3C03E4D1, 0x4B04D447, 0xD20D85FD, 0xA50AB56B, 0x35B5A8FA, 0x42B2986C,
  989. 0xDBBBC9D6, 0xACBCF940, 0x32D86CE3, 0x45DF5C75, 0xDCD60DCF, 0xABD13D59,
  990. 0x26D930AC, 0x51DE003A, 0xC8D75180, 0xBFD06116, 0x21B4F4B5, 0x56B3C423,
  991. 0xCFBA9599, 0xB8BDA50F, 0x2802B89E, 0x5F058808, 0xC60CD9B2, 0xB10BE924,
  992. 0x2F6F7C87, 0x58684C11, 0xC1611DAB, 0xB6662D3D, 0x76DC4190, 0x01DB7106,
  993. 0x98D220BC, 0xEFD5102A, 0x71B18589, 0x06B6B51F, 0x9FBFE4A5, 0xE8B8D433,
  994. 0x7807C9A2, 0x0F00F934, 0x9609A88E, 0xE10E9818, 0x7F6A0DBB, 0x086D3D2D,
  995. 0x91646C97, 0xE6635C01, 0x6B6B51F4, 0x1C6C6162, 0x856530D8, 0xF262004E,
  996. 0x6C0695ED, 0x1B01A57B, 0x8208F4C1, 0xF50FC457, 0x65B0D9C6, 0x12B7E950,
  997. 0x8BBEB8EA, 0xFCB9887C, 0x62DD1DDF, 0x15DA2D49, 0x8CD37CF3, 0xFBD44C65,
  998. 0x4DB26158, 0x3AB551CE, 0xA3BC0074, 0xD4BB30E2, 0x4ADFA541, 0x3DD895D7,
  999. 0xA4D1C46D, 0xD3D6F4FB, 0x4369E96A, 0x346ED9FC, 0xAD678846, 0xDA60B8D0,
  1000. 0x44042D73, 0x33031DE5, 0xAA0A4C5F, 0xDD0D7CC9, 0x5005713C, 0x270241AA,
  1001. 0xBE0B1010, 0xC90C2086, 0x5768B525, 0x206F85B3, 0xB966D409, 0xCE61E49F,
  1002. 0x5EDEF90E, 0x29D9C998, 0xB0D09822, 0xC7D7A8B4, 0x59B33D17, 0x2EB40D81,
  1003. 0xB7BD5C3B, 0xC0BA6CAD, 0xEDB88320, 0x9ABFB3B6, 0x03B6E20C, 0x74B1D29A,
  1004. 0xEAD54739, 0x9DD277AF, 0x04DB2615, 0x73DC1683, 0xE3630B12, 0x94643B84,
  1005. 0x0D6D6A3E, 0x7A6A5AA8, 0xE40ECF0B, 0x9309FF9D, 0x0A00AE27, 0x7D079EB1,
  1006. 0xF00F9344, 0x8708A3D2, 0x1E01F268, 0x6906C2FE, 0xF762575D, 0x806567CB,
  1007. 0x196C3671, 0x6E6B06E7, 0xFED41B76, 0x89D32BE0, 0x10DA7A5A, 0x67DD4ACC,
  1008. 0xF9B9DF6F, 0x8EBEEFF9, 0x17B7BE43, 0x60B08ED5, 0xD6D6A3E8, 0xA1D1937E,
  1009. 0x38D8C2C4, 0x4FDFF252, 0xD1BB67F1, 0xA6BC5767, 0x3FB506DD, 0x48B2364B,
  1010. 0xD80D2BDA, 0xAF0A1B4C, 0x36034AF6, 0x41047A60, 0xDF60EFC3, 0xA867DF55,
  1011. 0x316E8EEF, 0x4669BE79, 0xCB61B38C, 0xBC66831A, 0x256FD2A0, 0x5268E236,
  1012. 0xCC0C7795, 0xBB0B4703, 0x220216B9, 0x5505262F, 0xC5BA3BBE, 0xB2BD0B28,
  1013. 0x2BB45A92, 0x5CB36A04, 0xC2D7FFA7, 0xB5D0CF31, 0x2CD99E8B, 0x5BDEAE1D,
  1014. 0x9B64C2B0, 0xEC63F226, 0x756AA39C, 0x026D930A, 0x9C0906A9, 0xEB0E363F,
  1015. 0x72076785, 0x05005713, 0x95BF4A82, 0xE2B87A14, 0x7BB12BAE, 0x0CB61B38,
  1016. 0x92D28E9B, 0xE5D5BE0D, 0x7CDCEFB7, 0x0BDBDF21, 0x86D3D2D4, 0xF1D4E242,
  1017. 0x68DDB3F8, 0x1FDA836E, 0x81BE16CD, 0xF6B9265B, 0x6FB077E1, 0x18B74777,
  1018. 0x88085AE6, 0xFF0F6A70, 0x66063BCA, 0x11010B5C, 0x8F659EFF, 0xF862AE69,
  1019. 0x616BFFD3, 0x166CCF45, 0xA00AE278, 0xD70DD2EE, 0x4E048354, 0x3903B3C2,
  1020. 0xA7672661, 0xD06016F7, 0x4969474D, 0x3E6E77DB, 0xAED16A4A, 0xD9D65ADC,
  1021. 0x40DF0B66, 0x37D83BF0, 0xA9BCAE53, 0xDEBB9EC5, 0x47B2CF7F, 0x30B5FFE9,
  1022. 0xBDBDF21C, 0xCABAC28A, 0x53B39330, 0x24B4A3A6, 0xBAD03605, 0xCDD70693,
  1023. 0x54DE5729, 0x23D967BF, 0xB3667A2E, 0xC4614AB8, 0x5D681B02, 0x2A6F2B94,
  1024. 0xB40BBE37, 0xC30C8EA1, 0x5A05DF1B, 0x2D02EF8D};
  1025. unsigned int crc = ~0u;
  1026. int i;
  1027. for (i = 0; i < len; ++i)
  1028. crc = (crc >> 8) ^ crc_table[buffer[i] ^ (crc & 0xff)];
  1029. return ~crc;
  1030. #endif
  1031. }
  1032. #define stbiw__wpng4(o, a, b, c, d) \
  1033. ((o)[0] = STBIW_UCHAR(a), (o)[1] = STBIW_UCHAR(b), (o)[2] = STBIW_UCHAR(c), \
  1034. (o)[3] = STBIW_UCHAR(d), (o) += 4)
  1035. #define stbiw__wp32(data, v) stbiw__wpng4(data, (v) >> 24, (v) >> 16, (v) >> 8, (v));
  1036. #define stbiw__wptag(data, s) stbiw__wpng4(data, s[0], s[1], s[2], s[3])
  1037. static void stbiw__wpcrc(unsigned char** data, int len) {
  1038. unsigned int crc = stbiw__crc32(*data - len - 4, len + 4);
  1039. stbiw__wp32(*data, crc);
  1040. }
  1041. static unsigned char stbiw__paeth(int a, int b, int c) {
  1042. int p = a + b - c, pa = abs(p - a), pb = abs(p - b), pc = abs(p - c);
  1043. if (pa <= pb && pa <= pc)
  1044. return STBIW_UCHAR(a);
  1045. if (pb <= pc)
  1046. return STBIW_UCHAR(b);
  1047. return STBIW_UCHAR(c);
  1048. }
  1049. // @OPTIMIZE: provide an option that always forces left-predict or paeth predict
  1050. static void stbiw__encode_png_line(
  1051. unsigned char* pixels, int stride_bytes, int width, int height, int y, int n,
  1052. int filter_type, signed char* line_buffer) {
  1053. static int mapping[] = {0, 1, 2, 3, 4};
  1054. static int firstmap[] = {0, 1, 0, 5, 6};
  1055. int* mymap = (y != 0) ? mapping : firstmap;
  1056. int i;
  1057. int type = mymap[filter_type];
  1058. unsigned char* z =
  1059. pixels +
  1060. stride_bytes * (stbi__flip_vertically_on_write ? height - 1 - y : y);
  1061. int signed_stride = stbi__flip_vertically_on_write ? -stride_bytes : stride_bytes;
  1062. if (type == 0) {
  1063. memcpy(line_buffer, z, width * n);
  1064. return;
  1065. }
  1066. // first loop isn't optimized since it's just one pixel
  1067. for (i = 0; i < n; ++i) {
  1068. switch (type) {
  1069. case 1:
  1070. line_buffer[i] = z[i];
  1071. break;
  1072. case 2:
  1073. line_buffer[i] = z[i] - z[i - signed_stride];
  1074. break;
  1075. case 3:
  1076. line_buffer[i] = z[i] - (z[i - signed_stride] >> 1);
  1077. break;
  1078. case 4:
  1079. line_buffer[i] =
  1080. (signed char)(z[i] - stbiw__paeth(0, z[i - signed_stride], 0));
  1081. break;
  1082. case 5:
  1083. line_buffer[i] = z[i];
  1084. break;
  1085. case 6:
  1086. line_buffer[i] = z[i];
  1087. break;
  1088. }
  1089. }
  1090. switch (type) {
  1091. case 1:
  1092. for (i = n; i < width * n; ++i)
  1093. line_buffer[i] = z[i] - z[i - n];
  1094. break;
  1095. case 2:
  1096. for (i = n; i < width * n; ++i)
  1097. line_buffer[i] = z[i] - z[i - signed_stride];
  1098. break;
  1099. case 3:
  1100. for (i = n; i < width * n; ++i)
  1101. line_buffer[i] = z[i] - ((z[i - n] + z[i - signed_stride]) >> 1);
  1102. break;
  1103. case 4:
  1104. for (i = n; i < width * n; ++i)
  1105. line_buffer[i] = z[i] - stbiw__paeth(
  1106. z[i - n], z[i - signed_stride],
  1107. z[i - signed_stride - n]);
  1108. break;
  1109. case 5:
  1110. for (i = n; i < width * n; ++i)
  1111. line_buffer[i] = z[i] - (z[i - n] >> 1);
  1112. break;
  1113. case 6:
  1114. for (i = n; i < width * n; ++i)
  1115. line_buffer[i] = z[i] - stbiw__paeth(z[i - n], 0, 0);
  1116. break;
  1117. }
  1118. }
  1119. STBIWDEF unsigned char* stbi_write_png_to_mem(
  1120. const unsigned char* pixels, int stride_bytes, int x, int y, int n,
  1121. int* out_len) {
  1122. int force_filter = stbi_write_force_png_filter;
  1123. int ctype[5] = {-1, 0, 4, 2, 6};
  1124. unsigned char sig[8] = {137, 80, 78, 71, 13, 10, 26, 10};
  1125. unsigned char *out, *o, *filt, *zlib;
  1126. signed char* line_buffer;
  1127. int j, zlen;
  1128. if (stride_bytes == 0)
  1129. stride_bytes = x * n;
  1130. if (force_filter >= 5) {
  1131. force_filter = -1;
  1132. }
  1133. filt = (unsigned char*)STBIW_MALLOC((x * n + 1) * y);
  1134. if (!filt)
  1135. return 0;
  1136. line_buffer = (signed char*)STBIW_MALLOC(x * n);
  1137. if (!line_buffer) {
  1138. STBIW_FREE(filt);
  1139. return 0;
  1140. }
  1141. for (j = 0; j < y; ++j) {
  1142. int filter_type;
  1143. if (force_filter > -1) {
  1144. filter_type = force_filter;
  1145. stbiw__encode_png_line(
  1146. (unsigned char*)(pixels), stride_bytes, x, y, j, n, force_filter,
  1147. line_buffer);
  1148. } else { // Estimate the best filter by running through all of them:
  1149. int best_filter = 0, best_filter_val = 0x7fffffff, est, i;
  1150. for (filter_type = 0; filter_type < 5; filter_type++) {
  1151. stbiw__encode_png_line(
  1152. (unsigned char*)(pixels), stride_bytes, x, y, j, n, filter_type,
  1153. line_buffer);
  1154. // Estimate the entropy of the line using this filter; the less, the
  1155. // better.
  1156. est = 0;
  1157. for (i = 0; i < x * n; ++i) {
  1158. est += abs((signed char)line_buffer[i]);
  1159. }
  1160. if (est < best_filter_val) {
  1161. best_filter_val = est;
  1162. best_filter = filter_type;
  1163. }
  1164. }
  1165. if (filter_type != best_filter) { // If the last iteration already got us
  1166. // the best filter, don't redo it
  1167. stbiw__encode_png_line(
  1168. (unsigned char*)(pixels), stride_bytes, x, y, j, n, best_filter,
  1169. line_buffer);
  1170. filter_type = best_filter;
  1171. }
  1172. }
  1173. // when we get here, filter_type contains the filter type, and line_buffer
  1174. // contains the data
  1175. filt[j * (x * n + 1)] = (unsigned char)filter_type;
  1176. STBIW_MEMMOVE(filt + j * (x * n + 1) + 1, line_buffer, x * n);
  1177. }
  1178. STBIW_FREE(line_buffer);
  1179. zlib = stbi_zlib_compress(
  1180. filt, y * (x * n + 1), &zlen, stbi_write_png_compression_level);
  1181. STBIW_FREE(filt);
  1182. if (!zlib)
  1183. return 0;
  1184. // each tag requires 12 bytes of overhead
  1185. out = (unsigned char*)STBIW_MALLOC(8 + 12 + 13 + 12 + zlen + 12);
  1186. if (!out)
  1187. return 0;
  1188. *out_len = 8 + 12 + 13 + 12 + zlen + 12;
  1189. o = out;
  1190. STBIW_MEMMOVE(o, sig, 8);
  1191. o += 8;
  1192. stbiw__wp32(o, 13); // header length
  1193. stbiw__wptag(o, "IHDR");
  1194. stbiw__wp32(o, x);
  1195. stbiw__wp32(o, y);
  1196. *o++ = 8;
  1197. *o++ = STBIW_UCHAR(ctype[n]);
  1198. *o++ = 0;
  1199. *o++ = 0;
  1200. *o++ = 0;
  1201. stbiw__wpcrc(&o, 13);
  1202. stbiw__wp32(o, zlen);
  1203. stbiw__wptag(o, "IDAT");
  1204. STBIW_MEMMOVE(o, zlib, zlen);
  1205. o += zlen;
  1206. STBIW_FREE(zlib);
  1207. stbiw__wpcrc(&o, zlen);
  1208. stbiw__wp32(o, 0);
  1209. stbiw__wptag(o, "IEND");
  1210. stbiw__wpcrc(&o, 0);
  1211. STBIW_ASSERT(o == out + *out_len);
  1212. return out;
  1213. }
  1214. #ifndef STBI_WRITE_NO_STDIO
  1215. STBIWDEF int stbi_write_png(
  1216. char const* filename, int x, int y, int comp, const void* data,
  1217. int stride_bytes) {
  1218. FILE* f;
  1219. int len;
  1220. unsigned char* png = stbi_write_png_to_mem(
  1221. (const unsigned char*)data, stride_bytes, x, y, comp, &len);
  1222. if (png == NULL)
  1223. return 0;
  1224. f = stbiw__fopen(filename, "wb");
  1225. if (!f) {
  1226. STBIW_FREE(png);
  1227. return 0;
  1228. }
  1229. fwrite(png, 1, len, f);
  1230. fclose(f);
  1231. STBIW_FREE(png);
  1232. return 1;
  1233. }
  1234. #endif
  1235. STBIWDEF int stbi_write_png_to_func(
  1236. stbi_write_func* func, void* context, int x, int y, int comp, const void* data,
  1237. int stride_bytes) {
  1238. int len;
  1239. unsigned char* png = stbi_write_png_to_mem(
  1240. (const unsigned char*)data, stride_bytes, x, y, comp, &len);
  1241. if (png == NULL)
  1242. return 0;
  1243. func(context, png, len);
  1244. STBIW_FREE(png);
  1245. return 1;
  1246. }
  1247. /* ***************************************************************************
  1248. *
  1249. * JPEG writer
  1250. *
  1251. * This is based on Jon Olick's jo_jpeg.cpp:
  1252. * public domain Simple, Minimalistic JPEG writer - http://www.jonolick.com/code.html
  1253. */
  1254. static const unsigned char stbiw__jpg_ZigZag[] = {
  1255. 0, 1, 5, 6, 14, 15, 27, 28, 2, 4, 7, 13, 16, 26, 29, 42,
  1256. 3, 8, 12, 17, 25, 30, 41, 43, 9, 11, 18, 24, 31, 40, 44, 53,
  1257. 10, 19, 23, 32, 39, 45, 52, 54, 20, 22, 33, 38, 46, 51, 55, 60,
  1258. 21, 34, 37, 47, 50, 56, 59, 61, 35, 36, 48, 49, 57, 58, 62, 63};
  1259. static void stbiw__jpg_writeBits(
  1260. stbi__write_context* s, int* bitBufP, int* bitCntP, const unsigned short* bs) {
  1261. int bitBuf = *bitBufP, bitCnt = *bitCntP;
  1262. bitCnt += bs[1];
  1263. bitBuf |= bs[0] << (24 - bitCnt);
  1264. while (bitCnt >= 8) {
  1265. unsigned char c = (bitBuf >> 16) & 255;
  1266. stbiw__putc(s, c);
  1267. if (c == 255) {
  1268. stbiw__putc(s, 0);
  1269. }
  1270. bitBuf <<= 8;
  1271. bitCnt -= 8;
  1272. }
  1273. *bitBufP = bitBuf;
  1274. *bitCntP = bitCnt;
  1275. }
  1276. static void stbiw__jpg_DCT(
  1277. float* d0p, float* d1p, float* d2p, float* d3p, float* d4p, float* d5p,
  1278. float* d6p, float* d7p) {
  1279. float d0 = *d0p, d1 = *d1p, d2 = *d2p, d3 = *d3p, d4 = *d4p, d5 = *d5p, d6 = *d6p,
  1280. d7 = *d7p;
  1281. float z1, z2, z3, z4, z5, z11, z13;
  1282. float tmp0 = d0 + d7;
  1283. float tmp7 = d0 - d7;
  1284. float tmp1 = d1 + d6;
  1285. float tmp6 = d1 - d6;
  1286. float tmp2 = d2 + d5;
  1287. float tmp5 = d2 - d5;
  1288. float tmp3 = d3 + d4;
  1289. float tmp4 = d3 - d4;
  1290. // Even part
  1291. float tmp10 = tmp0 + tmp3; // phase 2
  1292. float tmp13 = tmp0 - tmp3;
  1293. float tmp11 = tmp1 + tmp2;
  1294. float tmp12 = tmp1 - tmp2;
  1295. d0 = tmp10 + tmp11; // phase 3
  1296. d4 = tmp10 - tmp11;
  1297. z1 = (tmp12 + tmp13) * 0.707106781f; // c4
  1298. d2 = tmp13 + z1; // phase 5
  1299. d6 = tmp13 - z1;
  1300. // Odd part
  1301. tmp10 = tmp4 + tmp5; // phase 2
  1302. tmp11 = tmp5 + tmp6;
  1303. tmp12 = tmp6 + tmp7;
  1304. // The rotator is modified from fig 4-8 to avoid extra negations.
  1305. z5 = (tmp10 - tmp12) * 0.382683433f; // c6
  1306. z2 = tmp10 * 0.541196100f + z5; // c2-c6
  1307. z4 = tmp12 * 1.306562965f + z5; // c2+c6
  1308. z3 = tmp11 * 0.707106781f; // c4
  1309. z11 = tmp7 + z3; // phase 5
  1310. z13 = tmp7 - z3;
  1311. *d5p = z13 + z2; // phase 6
  1312. *d3p = z13 - z2;
  1313. *d1p = z11 + z4;
  1314. *d7p = z11 - z4;
  1315. *d0p = d0;
  1316. *d2p = d2;
  1317. *d4p = d4;
  1318. *d6p = d6;
  1319. }
  1320. static void stbiw__jpg_calcBits(int val, unsigned short bits[2]) {
  1321. int tmp1 = val < 0 ? -val : val;
  1322. val = val < 0 ? val - 1 : val;
  1323. bits[1] = 1;
  1324. while (tmp1 >>= 1) {
  1325. ++bits[1];
  1326. }
  1327. bits[0] = val & ((1 << bits[1]) - 1);
  1328. }
  1329. static int stbiw__jpg_processDU(
  1330. stbi__write_context* s, int* bitBuf, int* bitCnt, float* CDU, int du_stride,
  1331. float* fdtbl, int DC, const unsigned short HTDC[256][2],
  1332. const unsigned short HTAC[256][2]) {
  1333. const unsigned short EOB[2] = {HTAC[0x00][0], HTAC[0x00][1]};
  1334. const unsigned short M16zeroes[2] = {HTAC[0xF0][0], HTAC[0xF0][1]};
  1335. int dataOff, i, j, n, diff, end0pos, x, y;
  1336. int DU[64];
  1337. // DCT rows
  1338. for (dataOff = 0, n = du_stride * 8; dataOff < n; dataOff += du_stride) {
  1339. stbiw__jpg_DCT(
  1340. &CDU[dataOff], &CDU[dataOff + 1], &CDU[dataOff + 2], &CDU[dataOff + 3],
  1341. &CDU[dataOff + 4], &CDU[dataOff + 5], &CDU[dataOff + 6],
  1342. &CDU[dataOff + 7]);
  1343. }
  1344. // DCT columns
  1345. for (dataOff = 0; dataOff < 8; ++dataOff) {
  1346. stbiw__jpg_DCT(
  1347. &CDU[dataOff], &CDU[dataOff + du_stride], &CDU[dataOff + du_stride * 2],
  1348. &CDU[dataOff + du_stride * 3], &CDU[dataOff + du_stride * 4],
  1349. &CDU[dataOff + du_stride * 5], &CDU[dataOff + du_stride * 6],
  1350. &CDU[dataOff + du_stride * 7]);
  1351. }
  1352. // Quantize/descale/zigzag the coefficients
  1353. for (y = 0, j = 0; y < 8; ++y) {
  1354. for (x = 0; x < 8; ++x, ++j) {
  1355. float v;
  1356. i = y * du_stride + x;
  1357. v = CDU[i] * fdtbl[j];
  1358. // DU[stbiw__jpg_ZigZag[j]] = (int)(v < 0 ? ceilf(v - 0.5f) : floorf(v +
  1359. // 0.5f)); ceilf() and floorf() are C99, not C89, but I /think/ they're not
  1360. // needed here anyway?
  1361. DU[stbiw__jpg_ZigZag[j]] = (int)(v < 0 ? v - 0.5f : v + 0.5f);
  1362. }
  1363. }
  1364. // Encode DC
  1365. diff = DU[0] - DC;
  1366. if (diff == 0) {
  1367. stbiw__jpg_writeBits(s, bitBuf, bitCnt, HTDC[0]);
  1368. } else {
  1369. unsigned short bits[2];
  1370. stbiw__jpg_calcBits(diff, bits);
  1371. stbiw__jpg_writeBits(s, bitBuf, bitCnt, HTDC[bits[1]]);
  1372. stbiw__jpg_writeBits(s, bitBuf, bitCnt, bits);
  1373. }
  1374. // Encode ACs
  1375. end0pos = 63;
  1376. for (; (end0pos > 0) && (DU[end0pos] == 0); --end0pos) {
  1377. }
  1378. // end0pos = first element in reverse order !=0
  1379. if (end0pos == 0) {
  1380. stbiw__jpg_writeBits(s, bitBuf, bitCnt, EOB);
  1381. return DU[0];
  1382. }
  1383. for (i = 1; i <= end0pos; ++i) {
  1384. int startpos = i;
  1385. int nrzeroes;
  1386. unsigned short bits[2];
  1387. for (; DU[i] == 0 && i <= end0pos; ++i) {
  1388. }
  1389. nrzeroes = i - startpos;
  1390. if (nrzeroes >= 16) {
  1391. int lng = nrzeroes >> 4;
  1392. int nrmarker;
  1393. for (nrmarker = 1; nrmarker <= lng; ++nrmarker)
  1394. stbiw__jpg_writeBits(s, bitBuf, bitCnt, M16zeroes);
  1395. nrzeroes &= 15;
  1396. }
  1397. stbiw__jpg_calcBits(DU[i], bits);
  1398. stbiw__jpg_writeBits(s, bitBuf, bitCnt, HTAC[(nrzeroes << 4) + bits[1]]);
  1399. stbiw__jpg_writeBits(s, bitBuf, bitCnt, bits);
  1400. }
  1401. if (end0pos != 63) {
  1402. stbiw__jpg_writeBits(s, bitBuf, bitCnt, EOB);
  1403. }
  1404. return DU[0];
  1405. }
  1406. static int stbi_write_jpg_core(
  1407. stbi__write_context* s, int width, int height, int comp, const void* data,
  1408. int quality) {
  1409. // Constants that don't pollute global namespace
  1410. static const unsigned char std_dc_luminance_nrcodes[] = {0, 0, 1, 5, 1, 1, 1, 1, 1,
  1411. 1, 0, 0, 0, 0, 0, 0, 0};
  1412. static const unsigned char std_dc_luminance_values[] = {0, 1, 2, 3, 4, 5,
  1413. 6, 7, 8, 9, 10, 11};
  1414. static const unsigned char std_ac_luminance_nrcodes[] = {
  1415. 0, 0, 2, 1, 3, 3, 2, 4, 3, 5, 5, 4, 4, 0, 0, 1, 0x7d};
  1416. static const unsigned char std_ac_luminance_values[] = {
  1417. 0x01, 0x02, 0x03, 0x00, 0x04, 0x11, 0x05, 0x12, 0x21, 0x31, 0x41, 0x06,
  1418. 0x13, 0x51, 0x61, 0x07, 0x22, 0x71, 0x14, 0x32, 0x81, 0x91, 0xa1, 0x08,
  1419. 0x23, 0x42, 0xb1, 0xc1, 0x15, 0x52, 0xd1, 0xf0, 0x24, 0x33, 0x62, 0x72,
  1420. 0x82, 0x09, 0x0a, 0x16, 0x17, 0x18, 0x19, 0x1a, 0x25, 0x26, 0x27, 0x28,
  1421. 0x29, 0x2a, 0x34, 0x35, 0x36, 0x37, 0x38, 0x39, 0x3a, 0x43, 0x44, 0x45,
  1422. 0x46, 0x47, 0x48, 0x49, 0x4a, 0x53, 0x54, 0x55, 0x56, 0x57, 0x58, 0x59,
  1423. 0x5a, 0x63, 0x64, 0x65, 0x66, 0x67, 0x68, 0x69, 0x6a, 0x73, 0x74, 0x75,
  1424. 0x76, 0x77, 0x78, 0x79, 0x7a, 0x83, 0x84, 0x85, 0x86, 0x87, 0x88, 0x89,
  1425. 0x8a, 0x92, 0x93, 0x94, 0x95, 0x96, 0x97, 0x98, 0x99, 0x9a, 0xa2, 0xa3,
  1426. 0xa4, 0xa5, 0xa6, 0xa7, 0xa8, 0xa9, 0xaa, 0xb2, 0xb3, 0xb4, 0xb5, 0xb6,
  1427. 0xb7, 0xb8, 0xb9, 0xba, 0xc2, 0xc3, 0xc4, 0xc5, 0xc6, 0xc7, 0xc8, 0xc9,
  1428. 0xca, 0xd2, 0xd3, 0xd4, 0xd5, 0xd6, 0xd7, 0xd8, 0xd9, 0xda, 0xe1, 0xe2,
  1429. 0xe3, 0xe4, 0xe5, 0xe6, 0xe7, 0xe8, 0xe9, 0xea, 0xf1, 0xf2, 0xf3, 0xf4,
  1430. 0xf5, 0xf6, 0xf7, 0xf8, 0xf9, 0xfa};
  1431. static const unsigned char std_dc_chrominance_nrcodes[] = {
  1432. 0, 0, 3, 1, 1, 1, 1, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0};
  1433. static const unsigned char std_dc_chrominance_values[] = {0, 1, 2, 3, 4, 5,
  1434. 6, 7, 8, 9, 10, 11};
  1435. static const unsigned char std_ac_chrominance_nrcodes[] = {
  1436. 0, 0, 2, 1, 2, 4, 4, 3, 4, 7, 5, 4, 4, 0, 1, 2, 0x77};
  1437. static const unsigned char std_ac_chrominance_values[] = {
  1438. 0x00, 0x01, 0x02, 0x03, 0x11, 0x04, 0x05, 0x21, 0x31, 0x06, 0x12, 0x41,
  1439. 0x51, 0x07, 0x61, 0x71, 0x13, 0x22, 0x32, 0x81, 0x08, 0x14, 0x42, 0x91,
  1440. 0xa1, 0xb1, 0xc1, 0x09, 0x23, 0x33, 0x52, 0xf0, 0x15, 0x62, 0x72, 0xd1,
  1441. 0x0a, 0x16, 0x24, 0x34, 0xe1, 0x25, 0xf1, 0x17, 0x18, 0x19, 0x1a, 0x26,
  1442. 0x27, 0x28, 0x29, 0x2a, 0x35, 0x36, 0x37, 0x38, 0x39, 0x3a, 0x43, 0x44,
  1443. 0x45, 0x46, 0x47, 0x48, 0x49, 0x4a, 0x53, 0x54, 0x55, 0x56, 0x57, 0x58,
  1444. 0x59, 0x5a, 0x63, 0x64, 0x65, 0x66, 0x67, 0x68, 0x69, 0x6a, 0x73, 0x74,
  1445. 0x75, 0x76, 0x77, 0x78, 0x79, 0x7a, 0x82, 0x83, 0x84, 0x85, 0x86, 0x87,
  1446. 0x88, 0x89, 0x8a, 0x92, 0x93, 0x94, 0x95, 0x96, 0x97, 0x98, 0x99, 0x9a,
  1447. 0xa2, 0xa3, 0xa4, 0xa5, 0xa6, 0xa7, 0xa8, 0xa9, 0xaa, 0xb2, 0xb3, 0xb4,
  1448. 0xb5, 0xb6, 0xb7, 0xb8, 0xb9, 0xba, 0xc2, 0xc3, 0xc4, 0xc5, 0xc6, 0xc7,
  1449. 0xc8, 0xc9, 0xca, 0xd2, 0xd3, 0xd4, 0xd5, 0xd6, 0xd7, 0xd8, 0xd9, 0xda,
  1450. 0xe2, 0xe3, 0xe4, 0xe5, 0xe6, 0xe7, 0xe8, 0xe9, 0xea, 0xf2, 0xf3, 0xf4,
  1451. 0xf5, 0xf6, 0xf7, 0xf8, 0xf9, 0xfa};
  1452. // Huffman tables
  1453. static const unsigned short YDC_HT[256][2] = {
  1454. {0, 2}, {2, 3}, {3, 3}, {4, 3}, {5, 3}, {6, 3},
  1455. {14, 4}, {30, 5}, {62, 6}, {126, 7}, {254, 8}, {510, 9}};
  1456. static const unsigned short UVDC_HT[256][2] = {
  1457. {0, 2}, {1, 2}, {2, 2}, {6, 3}, {14, 4}, {30, 5},
  1458. {62, 6}, {126, 7}, {254, 8}, {510, 9}, {1022, 10}, {2046, 11}};
  1459. static const unsigned short YAC_HT[256][2] = {
  1460. {10, 4}, {0, 2}, {1, 2}, {4, 3}, {11, 4},
  1461. {26, 5}, {120, 7}, {248, 8}, {1014, 10}, {65410, 16},
  1462. {65411, 16}, {0, 0}, {0, 0}, {0, 0}, {0, 0},
  1463. {0, 0}, {0, 0}, {12, 4}, {27, 5}, {121, 7},
  1464. {502, 9}, {2038, 11}, {65412, 16}, {65413, 16}, {65414, 16},
  1465. {65415, 16}, {65416, 16}, {0, 0}, {0, 0}, {0, 0},
  1466. {0, 0}, {0, 0}, {0, 0}, {28, 5}, {249, 8},
  1467. {1015, 10}, {4084, 12}, {65417, 16}, {65418, 16}, {65419, 16},
  1468. {65420, 16}, {65421, 16}, {65422, 16}, {0, 0}, {0, 0},
  1469. {0, 0}, {0, 0}, {0, 0}, {0, 0}, {58, 6},
  1470. {503, 9}, {4085, 12}, {65423, 16}, {65424, 16}, {65425, 16},
  1471. {65426, 16}, {65427, 16}, {65428, 16}, {65429, 16}, {0, 0},
  1472. {0, 0}, {0, 0}, {0, 0}, {0, 0}, {0, 0},
  1473. {59, 6}, {1016, 10}, {65430, 16}, {65431, 16}, {65432, 16},
  1474. {65433, 16}, {65434, 16}, {65435, 16}, {65436, 16}, {65437, 16},
  1475. {0, 0}, {0, 0}, {0, 0}, {0, 0}, {0, 0},
  1476. {0, 0}, {122, 7}, {2039, 11}, {65438, 16}, {65439, 16},
  1477. {65440, 16}, {65441, 16}, {65442, 16}, {65443, 16}, {65444, 16},
  1478. {65445, 16}, {0, 0}, {0, 0}, {0, 0}, {0, 0},
  1479. {0, 0}, {0, 0}, {123, 7}, {4086, 12}, {65446, 16},
  1480. {65447, 16}, {65448, 16}, {65449, 16}, {65450, 16}, {65451, 16},
  1481. {65452, 16}, {65453, 16}, {0, 0}, {0, 0}, {0, 0},
  1482. {0, 0}, {0, 0}, {0, 0}, {250, 8}, {4087, 12},
  1483. {65454, 16}, {65455, 16}, {65456, 16}, {65457, 16}, {65458, 16},
  1484. {65459, 16}, {65460, 16}, {65461, 16}, {0, 0}, {0, 0},
  1485. {0, 0}, {0, 0}, {0, 0}, {0, 0}, {504, 9},
  1486. {32704, 15}, {65462, 16}, {65463, 16}, {65464, 16}, {65465, 16},
  1487. {65466, 16}, {65467, 16}, {65468, 16}, {65469, 16}, {0, 0},
  1488. {0, 0}, {0, 0}, {0, 0}, {0, 0}, {0, 0},
  1489. {505, 9}, {65470, 16}, {65471, 16}, {65472, 16}, {65473, 16},
  1490. {65474, 16}, {65475, 16}, {65476, 16}, {65477, 16}, {65478, 16},
  1491. {0, 0}, {0, 0}, {0, 0}, {0, 0}, {0, 0},
  1492. {0, 0}, {506, 9}, {65479, 16}, {65480, 16}, {65481, 16},
  1493. {65482, 16}, {65483, 16}, {65484, 16}, {65485, 16}, {65486, 16},
  1494. {65487, 16}, {0, 0}, {0, 0}, {0, 0}, {0, 0},
  1495. {0, 0}, {0, 0}, {1017, 10}, {65488, 16}, {65489, 16},
  1496. {65490, 16}, {65491, 16}, {65492, 16}, {65493, 16}, {65494, 16},
  1497. {65495, 16}, {65496, 16}, {0, 0}, {0, 0}, {0, 0},
  1498. {0, 0}, {0, 0}, {0, 0}, {1018, 10}, {65497, 16},
  1499. {65498, 16}, {65499, 16}, {65500, 16}, {65501, 16}, {65502, 16},
  1500. {65503, 16}, {65504, 16}, {65505, 16}, {0, 0}, {0, 0},
  1501. {0, 0}, {0, 0}, {0, 0}, {0, 0}, {2040, 11},
  1502. {65506, 16}, {65507, 16}, {65508, 16}, {65509, 16}, {65510, 16},
  1503. {65511, 16}, {65512, 16}, {65513, 16}, {65514, 16}, {0, 0},
  1504. {0, 0}, {0, 0}, {0, 0}, {0, 0}, {0, 0},
  1505. {65515, 16}, {65516, 16}, {65517, 16}, {65518, 16}, {65519, 16},
  1506. {65520, 16}, {65521, 16}, {65522, 16}, {65523, 16}, {65524, 16},
  1507. {0, 0}, {0, 0}, {0, 0}, {0, 0}, {0, 0},
  1508. {2041, 11}, {65525, 16}, {65526, 16}, {65527, 16}, {65528, 16},
  1509. {65529, 16}, {65530, 16}, {65531, 16}, {65532, 16}, {65533, 16},
  1510. {65534, 16}, {0, 0}, {0, 0}, {0, 0}, {0, 0},
  1511. {0, 0}};
  1512. static const unsigned short UVAC_HT[256][2] = {
  1513. {0, 2}, {1, 2}, {4, 3}, {10, 4}, {24, 5},
  1514. {25, 5}, {56, 6}, {120, 7}, {500, 9}, {1014, 10},
  1515. {4084, 12}, {0, 0}, {0, 0}, {0, 0}, {0, 0},
  1516. {0, 0}, {0, 0}, {11, 4}, {57, 6}, {246, 8},
  1517. {501, 9}, {2038, 11}, {4085, 12}, {65416, 16}, {65417, 16},
  1518. {65418, 16}, {65419, 16}, {0, 0}, {0, 0}, {0, 0},
  1519. {0, 0}, {0, 0}, {0, 0}, {26, 5}, {247, 8},
  1520. {1015, 10}, {4086, 12}, {32706, 15}, {65420, 16}, {65421, 16},
  1521. {65422, 16}, {65423, 16}, {65424, 16}, {0, 0}, {0, 0},
  1522. {0, 0}, {0, 0}, {0, 0}, {0, 0}, {27, 5},
  1523. {248, 8}, {1016, 10}, {4087, 12}, {65425, 16}, {65426, 16},
  1524. {65427, 16}, {65428, 16}, {65429, 16}, {65430, 16}, {0, 0},
  1525. {0, 0}, {0, 0}, {0, 0}, {0, 0}, {0, 0},
  1526. {58, 6}, {502, 9}, {65431, 16}, {65432, 16}, {65433, 16},
  1527. {65434, 16}, {65435, 16}, {65436, 16}, {65437, 16}, {65438, 16},
  1528. {0, 0}, {0, 0}, {0, 0}, {0, 0}, {0, 0},
  1529. {0, 0}, {59, 6}, {1017, 10}, {65439, 16}, {65440, 16},
  1530. {65441, 16}, {65442, 16}, {65443, 16}, {65444, 16}, {65445, 16},
  1531. {65446, 16}, {0, 0}, {0, 0}, {0, 0}, {0, 0},
  1532. {0, 0}, {0, 0}, {121, 7}, {2039, 11}, {65447, 16},
  1533. {65448, 16}, {65449, 16}, {65450, 16}, {65451, 16}, {65452, 16},
  1534. {65453, 16}, {65454, 16}, {0, 0}, {0, 0}, {0, 0},
  1535. {0, 0}, {0, 0}, {0, 0}, {122, 7}, {2040, 11},
  1536. {65455, 16}, {65456, 16}, {65457, 16}, {65458, 16}, {65459, 16},
  1537. {65460, 16}, {65461, 16}, {65462, 16}, {0, 0}, {0, 0},
  1538. {0, 0}, {0, 0}, {0, 0}, {0, 0}, {249, 8},
  1539. {65463, 16}, {65464, 16}, {65465, 16}, {65466, 16}, {65467, 16},
  1540. {65468, 16}, {65469, 16}, {65470, 16}, {65471, 16}, {0, 0},
  1541. {0, 0}, {0, 0}, {0, 0}, {0, 0}, {0, 0},
  1542. {503, 9}, {65472, 16}, {65473, 16}, {65474, 16}, {65475, 16},
  1543. {65476, 16}, {65477, 16}, {65478, 16}, {65479, 16}, {65480, 16},
  1544. {0, 0}, {0, 0}, {0, 0}, {0, 0}, {0, 0},
  1545. {0, 0}, {504, 9}, {65481, 16}, {65482, 16}, {65483, 16},
  1546. {65484, 16}, {65485, 16}, {65486, 16}, {65487, 16}, {65488, 16},
  1547. {65489, 16}, {0, 0}, {0, 0}, {0, 0}, {0, 0},
  1548. {0, 0}, {0, 0}, {505, 9}, {65490, 16}, {65491, 16},
  1549. {65492, 16}, {65493, 16}, {65494, 16}, {65495, 16}, {65496, 16},
  1550. {65497, 16}, {65498, 16}, {0, 0}, {0, 0}, {0, 0},
  1551. {0, 0}, {0, 0}, {0, 0}, {506, 9}, {65499, 16},
  1552. {65500, 16}, {65501, 16}, {65502, 16}, {65503, 16}, {65504, 16},
  1553. {65505, 16}, {65506, 16}, {65507, 16}, {0, 0}, {0, 0},
  1554. {0, 0}, {0, 0}, {0, 0}, {0, 0}, {2041, 11},
  1555. {65508, 16}, {65509, 16}, {65510, 16}, {65511, 16}, {65512, 16},
  1556. {65513, 16}, {65514, 16}, {65515, 16}, {65516, 16}, {0, 0},
  1557. {0, 0}, {0, 0}, {0, 0}, {0, 0}, {0, 0},
  1558. {16352, 14}, {65517, 16}, {65518, 16}, {65519, 16}, {65520, 16},
  1559. {65521, 16}, {65522, 16}, {65523, 16}, {65524, 16}, {65525, 16},
  1560. {0, 0}, {0, 0}, {0, 0}, {0, 0}, {0, 0},
  1561. {1018, 10}, {32707, 15}, {65526, 16}, {65527, 16}, {65528, 16},
  1562. {65529, 16}, {65530, 16}, {65531, 16}, {65532, 16}, {65533, 16},
  1563. {65534, 16}, {0, 0}, {0, 0}, {0, 0}, {0, 0},
  1564. {0, 0}};
  1565. static const int YQT[] = {
  1566. 16, 11, 10, 16, 24, 40, 51, 61, 12, 12, 14, 19, 26, 58, 60, 55,
  1567. 14, 13, 16, 24, 40, 57, 69, 56, 14, 17, 22, 29, 51, 87, 80, 62,
  1568. 18, 22, 37, 56, 68, 109, 103, 77, 24, 35, 55, 64, 81, 104, 113, 92,
  1569. 49, 64, 78, 87, 103, 121, 120, 101, 72, 92, 95, 98, 112, 100, 103, 99};
  1570. static const int UVQT[] = {17, 18, 24, 47, 99, 99, 99, 99, 18, 21, 26, 66, 99,
  1571. 99, 99, 99, 24, 26, 56, 99, 99, 99, 99, 99, 47, 66,
  1572. 99, 99, 99, 99, 99, 99, 99, 99, 99, 99, 99, 99, 99,
  1573. 99, 99, 99, 99, 99, 99, 99, 99, 99, 99, 99, 99, 99,
  1574. 99, 99, 99, 99, 99, 99, 99, 99, 99, 99, 99, 99};
  1575. static const float aasf[] = {
  1576. 1.0f * 2.828427125f, 1.387039845f * 2.828427125f,
  1577. 1.306562965f * 2.828427125f, 1.175875602f * 2.828427125f,
  1578. 1.0f * 2.828427125f, 0.785694958f * 2.828427125f,
  1579. 0.541196100f * 2.828427125f, 0.275899379f * 2.828427125f};
  1580. int row, col, i, k, subsample;
  1581. float fdtbl_Y[64], fdtbl_UV[64];
  1582. unsigned char YTable[64], UVTable[64];
  1583. if (!data || !width || !height || comp > 4 || comp < 1) {
  1584. return 0;
  1585. }
  1586. quality = quality ? quality : 90;
  1587. subsample = quality <= 90 ? 1 : 0;
  1588. quality = quality < 1 ? 1 : quality > 100 ? 100 : quality;
  1589. quality = quality < 50 ? 5000 / quality : 200 - quality * 2;
  1590. for (i = 0; i < 64; ++i) {
  1591. int uvti, yti = (YQT[i] * quality + 50) / 100;
  1592. YTable[stbiw__jpg_ZigZag[i]] = (unsigned char) (yti < 1 ? 1 : yti > 255 ? 255 : yti);
  1593. uvti = (UVQT[i] * quality + 50) / 100;
  1594. UVTable[stbiw__jpg_ZigZag[i]] = (unsigned char) (uvti < 1 ? 1 : uvti > 255 ? 255 : uvti);
  1595. }
  1596. for (row = 0, k = 0; row < 8; ++row) {
  1597. for (col = 0; col < 8; ++col, ++k) {
  1598. fdtbl_Y[k] = 1 / (YTable[stbiw__jpg_ZigZag[k]] * aasf[row] * aasf[col]);
  1599. fdtbl_UV[k] = 1 / (UVTable[stbiw__jpg_ZigZag[k]] * aasf[row] * aasf[col]);
  1600. }
  1601. }
  1602. // Write Headers
  1603. {
  1604. static const unsigned char head0[] = {
  1605. 0xFF, 0xD8, 0xFF, 0xE0, 0, 0x10, 'J', 'F', 'I', 'F', 0, 1, 1,
  1606. 0, 0, 1, 0, 1, 0, 0, 0xFF, 0xDB, 0, 0x84, 0};
  1607. static const unsigned char head2[] = {0xFF, 0xDA, 0, 0xC, 3, 1, 0,
  1608. 2, 0x11, 3, 0x11, 0, 0x3F, 0};
  1609. const unsigned char head1[] = {
  1610. 0xFF,
  1611. 0xC0,
  1612. 0,
  1613. 0x11,
  1614. 8,
  1615. (unsigned char)(height >> 8),
  1616. STBIW_UCHAR(height),
  1617. (unsigned char)(width >> 8),
  1618. STBIW_UCHAR(width),
  1619. 3,
  1620. 1,
  1621. (unsigned char)(subsample ? 0x22 : 0x11),
  1622. 0,
  1623. 2,
  1624. 0x11,
  1625. 1,
  1626. 3,
  1627. 0x11,
  1628. 1,
  1629. 0xFF,
  1630. 0xC4,
  1631. 0x01,
  1632. 0xA2,
  1633. 0};
  1634. s->func(s->context, (void*)head0, sizeof(head0));
  1635. s->func(s->context, (void*)YTable, sizeof(YTable));
  1636. stbiw__putc(s, 1);
  1637. s->func(s->context, UVTable, sizeof(UVTable));
  1638. s->func(s->context, (void*)head1, sizeof(head1));
  1639. s->func(s->context, (void*)(std_dc_luminance_nrcodes + 1),
  1640. sizeof(std_dc_luminance_nrcodes) - 1);
  1641. s->func(s->context, (void*)std_dc_luminance_values,
  1642. sizeof(std_dc_luminance_values));
  1643. stbiw__putc(s, 0x10); // HTYACinfo
  1644. s->func(s->context, (void*)(std_ac_luminance_nrcodes + 1),
  1645. sizeof(std_ac_luminance_nrcodes) - 1);
  1646. s->func(s->context, (void*)std_ac_luminance_values,
  1647. sizeof(std_ac_luminance_values));
  1648. stbiw__putc(s, 1); // HTUDCinfo
  1649. s->func(s->context, (void*)(std_dc_chrominance_nrcodes + 1),
  1650. sizeof(std_dc_chrominance_nrcodes) - 1);
  1651. s->func(s->context, (void*)std_dc_chrominance_values,
  1652. sizeof(std_dc_chrominance_values));
  1653. stbiw__putc(s, 0x11); // HTUACinfo
  1654. s->func(s->context, (void*)(std_ac_chrominance_nrcodes + 1),
  1655. sizeof(std_ac_chrominance_nrcodes) - 1);
  1656. s->func(s->context, (void*)std_ac_chrominance_values,
  1657. sizeof(std_ac_chrominance_values));
  1658. s->func(s->context, (void*)head2, sizeof(head2));
  1659. }
  1660. // Encode 8x8 macroblocks
  1661. {
  1662. static const unsigned short fillBits[] = {0x7F, 7};
  1663. int DCY = 0, DCU = 0, DCV = 0;
  1664. int bitBuf = 0, bitCnt = 0;
  1665. // comp == 2 is grey+alpha (alpha is ignored)
  1666. int ofsG = comp > 2 ? 1 : 0, ofsB = comp > 2 ? 2 : 0;
  1667. const unsigned char* dataR = (const unsigned char*)data;
  1668. const unsigned char* dataG = dataR + ofsG;
  1669. const unsigned char* dataB = dataR + ofsB;
  1670. int x, y, pos;
  1671. if (subsample) {
  1672. for (y = 0; y < height; y += 16) {
  1673. for (x = 0; x < width; x += 16) {
  1674. float Y[256], U[256], V[256];
  1675. for (row = y, pos = 0; row < y + 16; ++row) {
  1676. // row >= height => use last input row
  1677. int clamped_row = (row < height) ? row : height - 1;
  1678. int base_p = (stbi__flip_vertically_on_write
  1679. ? (height - 1 - clamped_row)
  1680. : clamped_row) *
  1681. width * comp;
  1682. for (col = x; col < x + 16; ++col, ++pos) {
  1683. // if col >= width => use pixel from last input column
  1684. int p = base_p + ((col < width) ? col : (width - 1)) * comp;
  1685. float r = dataR[p], g = dataG[p], b = dataB[p];
  1686. Y[pos] = +0.29900f * r + 0.58700f * g + 0.11400f * b - 128;
  1687. U[pos] = -0.16874f * r - 0.33126f * g + 0.50000f * b;
  1688. V[pos] = +0.50000f * r - 0.41869f * g - 0.08131f * b;
  1689. }
  1690. }
  1691. DCY = stbiw__jpg_processDU(
  1692. s, &bitBuf, &bitCnt, Y + 0, 16, fdtbl_Y, DCY, YDC_HT,
  1693. YAC_HT);
  1694. DCY = stbiw__jpg_processDU(
  1695. s, &bitBuf, &bitCnt, Y + 8, 16, fdtbl_Y, DCY, YDC_HT,
  1696. YAC_HT);
  1697. DCY = stbiw__jpg_processDU(
  1698. s, &bitBuf, &bitCnt, Y + 128, 16, fdtbl_Y, DCY, YDC_HT,
  1699. YAC_HT);
  1700. DCY = stbiw__jpg_processDU(
  1701. s, &bitBuf, &bitCnt, Y + 136, 16, fdtbl_Y, DCY, YDC_HT,
  1702. YAC_HT);
  1703. // subsample U,V
  1704. {
  1705. float subU[64], subV[64];
  1706. int yy, xx;
  1707. for (yy = 0, pos = 0; yy < 8; ++yy) {
  1708. for (xx = 0; xx < 8; ++xx, ++pos) {
  1709. int j = yy * 32 + xx * 2;
  1710. subU[pos] =
  1711. (U[j + 0] + U[j + 1] + U[j + 16] + U[j + 17]) *
  1712. 0.25f;
  1713. subV[pos] =
  1714. (V[j + 0] + V[j + 1] + V[j + 16] + V[j + 17]) *
  1715. 0.25f;
  1716. }
  1717. }
  1718. DCU = stbiw__jpg_processDU(
  1719. s, &bitBuf, &bitCnt, subU, 8, fdtbl_UV, DCU, UVDC_HT,
  1720. UVAC_HT);
  1721. DCV = stbiw__jpg_processDU(
  1722. s, &bitBuf, &bitCnt, subV, 8, fdtbl_UV, DCV, UVDC_HT,
  1723. UVAC_HT);
  1724. }
  1725. }
  1726. }
  1727. } else {
  1728. for (y = 0; y < height; y += 8) {
  1729. for (x = 0; x < width; x += 8) {
  1730. float Y[64], U[64], V[64];
  1731. for (row = y, pos = 0; row < y + 8; ++row) {
  1732. // row >= height => use last input row
  1733. int clamped_row = (row < height) ? row : height - 1;
  1734. int base_p = (stbi__flip_vertically_on_write
  1735. ? (height - 1 - clamped_row)
  1736. : clamped_row) *
  1737. width * comp;
  1738. for (col = x; col < x + 8; ++col, ++pos) {
  1739. // if col >= width => use pixel from last input column
  1740. int p = base_p + ((col < width) ? col : (width - 1)) * comp;
  1741. float r = dataR[p], g = dataG[p], b = dataB[p];
  1742. Y[pos] = +0.29900f * r + 0.58700f * g + 0.11400f * b - 128;
  1743. U[pos] = -0.16874f * r - 0.33126f * g + 0.50000f * b;
  1744. V[pos] = +0.50000f * r - 0.41869f * g - 0.08131f * b;
  1745. }
  1746. }
  1747. DCY = stbiw__jpg_processDU(
  1748. s, &bitBuf, &bitCnt, Y, 8, fdtbl_Y, DCY, YDC_HT, YAC_HT);
  1749. DCU = stbiw__jpg_processDU(
  1750. s, &bitBuf, &bitCnt, U, 8, fdtbl_UV, DCU, UVDC_HT, UVAC_HT);
  1751. DCV = stbiw__jpg_processDU(
  1752. s, &bitBuf, &bitCnt, V, 8, fdtbl_UV, DCV, UVDC_HT, UVAC_HT);
  1753. }
  1754. }
  1755. }
  1756. // Do the bit alignment of the EOI marker
  1757. stbiw__jpg_writeBits(s, &bitBuf, &bitCnt, fillBits);
  1758. }
  1759. // EOI
  1760. stbiw__putc(s, 0xFF);
  1761. stbiw__putc(s, 0xD9);
  1762. return 1;
  1763. }
  1764. STBIWDEF int stbi_write_jpg_to_func(
  1765. stbi_write_func* func, void* context, int x, int y, int comp, const void* data,
  1766. int quality) {
  1767. stbi__write_context s = {0};
  1768. stbi__start_write_callbacks(&s, func, context);
  1769. return stbi_write_jpg_core(&s, x, y, comp, (void*)data, quality);
  1770. }
  1771. #ifndef STBI_WRITE_NO_STDIO
  1772. STBIWDEF int stbi_write_jpg(
  1773. char const* filename, int x, int y, int comp, const void* data, int quality) {
  1774. stbi__write_context s = {0};
  1775. if (stbi__start_write_file(&s, filename)) {
  1776. int r = stbi_write_jpg_core(&s, x, y, comp, data, quality);
  1777. stbi__end_write_file(&s);
  1778. return r;
  1779. } else
  1780. return 0;
  1781. }
  1782. #endif
  1783. #endif // STB_IMAGE_WRITE_IMPLEMENTATION
  1784. /* Revision history
  1785. 1.16 (2021-07-11)
  1786. make Deflate code emit uncompressed blocks when it would otherwise expand
  1787. support writing BMPs with alpha channel
  1788. 1.15 (2020-07-13) unknown
  1789. 1.14 (2020-02-02) updated JPEG writer to downsample chroma channels
  1790. 1.13
  1791. 1.12
  1792. 1.11 (2019-08-11)
  1793. 1.10 (2019-02-07)
  1794. support utf8 filenames in Windows; fix warnings and platform ifdefs
  1795. 1.09 (2018-02-11)
  1796. fix typo in zlib quality API, improve STB_I_W_STATIC in C++
  1797. 1.08 (2018-01-29)
  1798. add stbi__flip_vertically_on_write, external zlib, zlib quality, choose PNG
  1799. filter 1.07 (2017-07-24) doc fix 1.06 (2017-07-23) writing JPEG (using Jon Olick's
  1800. code) 1.05 ??? 1.04 (2017-03-03) monochrome BMP expansion 1.03 ??? 1.02
  1801. (2016-04-02) avoid allocating large structures on the stack 1.01 (2016-01-16)
  1802. STBIW_REALLOC_SIZED: support allocators with no realloc support
  1803. avoid race-condition in crc initialization
  1804. minor compile issues
  1805. 1.00 (2015-09-14)
  1806. installable file IO function
  1807. 0.99 (2015-09-13)
  1808. warning fixes; TGA rle support
  1809. 0.98 (2015-04-08)
  1810. added STBIW_MALLOC, STBIW_ASSERT etc
  1811. 0.97 (2015-01-18)
  1812. fixed HDR asserts, rewrote HDR rle logic
  1813. 0.96 (2015-01-17)
  1814. add HDR output
  1815. fix monochrome BMP
  1816. 0.95 (2014-08-17)
  1817. add monochrome TGA output
  1818. 0.94 (2014-05-31)
  1819. rename private functions to avoid conflicts with stb_image.h
  1820. 0.93 (2014-05-27)
  1821. warning fixes
  1822. 0.92 (2010-08-01)
  1823. casts to unsigned char to fix warnings
  1824. 0.91 (2010-07-17)
  1825. first public release
  1826. 0.90 first internal release
  1827. */
  1828. /*
  1829. ------------------------------------------------------------------------------
  1830. This software is available under 2 licenses -- choose whichever you prefer.
  1831. ------------------------------------------------------------------------------
  1832. ALTERNATIVE A - MIT License
  1833. Copyright (c) 2017 Sean Barrett
  1834. Permission is hereby granted, free of charge, to any person obtaining a copy of
  1835. this software and associated documentation files (the "Software"), to deal in
  1836. the Software without restriction, including without limitation the rights to
  1837. use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies
  1838. of the Software, and to permit persons to whom the Software is furnished to do
  1839. so, subject to the following conditions:
  1840. The above copyright notice and this permission notice shall be included in all
  1841. copies or substantial portions of the Software.
  1842. THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
  1843. IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
  1844. FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
  1845. AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
  1846. LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
  1847. OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
  1848. SOFTWARE.
  1849. ------------------------------------------------------------------------------
  1850. ALTERNATIVE B - Public Domain (www.unlicense.org)
  1851. This is free and unencumbered software released into the public domain.
  1852. Anyone is free to copy, modify, publish, use, compile, sell, or distribute this
  1853. software, either in source code form or as a compiled binary, for any purpose,
  1854. commercial or non-commercial, and by any means.
  1855. In jurisdictions that recognize copyright laws, the author or authors of this
  1856. software dedicate any and all copyright interest in the software to the public
  1857. domain. We make this dedication for the benefit of the public at large and to
  1858. the detriment of our heirs and successors. We intend this dedication to be an
  1859. overt act of relinquishment in perpetuity of all present and future rights to
  1860. this software under copyright law.
  1861. THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
  1862. IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
  1863. FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
  1864. AUTHORS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN
  1865. ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION
  1866. WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
  1867. ------------------------------------------------------------------------------
  1868. */