mirror of
https://github.com/ocornut/imgui.git
synced 2024-11-23 21:09:01 +08:00
Tools: binary_to_compressed_c: added -u8/-u32/-base85 export options.
This commit is contained in:
parent
d0e870aad2
commit
551b6c4d66
@ -56,6 +56,7 @@ Other changes:
|
|||||||
- Misc: changed embedded ProggyClean encoding to save a bit of binary space (~12kb to 9.5kb).
|
- Misc: changed embedded ProggyClean encoding to save a bit of binary space (~12kb to 9.5kb).
|
||||||
- Misc: added IMGUI_DISABLE_DEFAULT_FONT to strip embedded font from binary. (#8161)
|
- Misc: added IMGUI_DISABLE_DEFAULT_FONT to strip embedded font from binary. (#8161)
|
||||||
[@demonese]
|
[@demonese]
|
||||||
|
- Tools: binary_to_compressed_c: added -u8/-u32/-base85 export options.
|
||||||
- Demo: example tree used by Property Editor & Selection demos properly freed
|
- Demo: example tree used by Property Editor & Selection demos properly freed
|
||||||
on application closure. (#8158) [@Legulysse]
|
on application closure. (#8158) [@Legulysse]
|
||||||
- Examples: Win32+DX12: Using a basic free-list allocator to manage multiple
|
- Examples: Win32+DX12: Using a basic free-list allocator to manage multiple
|
||||||
|
@ -4583,11 +4583,11 @@ static unsigned int stb_decompress(unsigned char *output, const unsigned char *i
|
|||||||
// MIT license (see License.txt in http://www.proggyfonts.net/index.php?menu=download)
|
// MIT license (see License.txt in http://www.proggyfonts.net/index.php?menu=download)
|
||||||
// Download and more information at http://www.proggyfonts.net or http://upperboundsinteractive.com/fonts.php
|
// Download and more information at http://www.proggyfonts.net or http://upperboundsinteractive.com/fonts.php
|
||||||
//-----------------------------------------------------------------------------
|
//-----------------------------------------------------------------------------
|
||||||
// File: 'ProggyClean.ttf' (41208 bytes)
|
|
||||||
// Exported using "misc/fonts/binary_to_compressed_c.exe ../ProggyClean.ttf proggy_clean_ttf_compressed (with compression, no base85 encoding).
|
|
||||||
//-----------------------------------------------------------------------------
|
|
||||||
|
|
||||||
#ifndef IMGUI_DISABLE_DEFAULT_FONT
|
#ifndef IMGUI_DISABLE_DEFAULT_FONT
|
||||||
|
|
||||||
|
// File: 'ProggyClean.ttf' (41208 bytes)
|
||||||
|
// Exported using binary_to_compressed_c.exe -u8 "ProggyClean.ttf" proggy_clean_ttf
|
||||||
static const unsigned int proggy_clean_ttf_compressed_size = 9583;
|
static const unsigned int proggy_clean_ttf_compressed_size = 9583;
|
||||||
static const unsigned char proggy_clean_ttf_compressed_data[9583] =
|
static const unsigned char proggy_clean_ttf_compressed_data[9583] =
|
||||||
{
|
{
|
||||||
|
@ -2,10 +2,11 @@
|
|||||||
// (binary_to_compressed_c.cpp)
|
// (binary_to_compressed_c.cpp)
|
||||||
// Helper tool to turn a file into a C array, if you want to embed font data in your source code.
|
// Helper tool to turn a file into a C array, if you want to embed font data in your source code.
|
||||||
|
|
||||||
// The data is first compressed with stb_compress() to reduce source code size,
|
// The data is first compressed with stb_compress() to reduce source code size.
|
||||||
// then encoded in Base85 to fit in a string so we can fit roughly 4 bytes of compressed data into 5 bytes of source code (suggested by @mmalex)
|
// Then stored in a C array:
|
||||||
// (If we used 32-bit constants it would require take 11 bytes of source code to encode 4 bytes, and be endianness dependent)
|
// - Base85: ~5 bytes of source code for 4 bytes of input data. 5 bytes stored in binary (suggested by @mmalex).
|
||||||
// Note that even with compression, the output array is likely to be bigger than the binary file..
|
// - As int: ~11 bytes of source code for 4 bytes of input data. 4 bytes stored in binary. Endianness dependant, need swapping on big-endian CPU.
|
||||||
|
// - As char: ~12 bytes of source code for 4 bytes of input data. 4 bytes stored in binary. Not endianness dependant.
|
||||||
// Load compressed TTF fonts with ImGui::GetIO().Fonts->AddFontFromMemoryCompressedTTF()
|
// Load compressed TTF fonts with ImGui::GetIO().Fonts->AddFontFromMemoryCompressedTTF()
|
||||||
|
|
||||||
// Build with, e.g:
|
// Build with, e.g:
|
||||||
@ -15,10 +16,12 @@
|
|||||||
// You can also find a precompiled Windows binary in the binary/demo package available from https://github.com/ocornut/imgui
|
// You can also find a precompiled Windows binary in the binary/demo package available from https://github.com/ocornut/imgui
|
||||||
|
|
||||||
// Usage:
|
// Usage:
|
||||||
// binary_to_compressed_c.exe [-base85] [-nocompress] [-nostatic] <inputfile> <symbolname>
|
// binary_to_compressed_c.exe [-nocompress] [-nostatic] [-base85] <inputfile> <symbolname>
|
||||||
// Usage example:
|
// Usage example:
|
||||||
// # binary_to_compressed_c.exe myfont.ttf MyFont > myfont.cpp
|
// # binary_to_compressed_c.exe myfont.ttf MyFont > myfont.cpp
|
||||||
// # binary_to_compressed_c.exe -base85 myfont.ttf MyFont > myfont.cpp
|
// # binary_to_compressed_c.exe -base85 myfont.ttf MyFont > myfont.cpp
|
||||||
|
// Note:
|
||||||
|
// Base85 encoding will be obsoleted by future version of Dear ImGui!
|
||||||
|
|
||||||
#define _CRT_SECURE_NO_WARNINGS
|
#define _CRT_SECURE_NO_WARNINGS
|
||||||
#include <stdio.h>
|
#include <stdio.h>
|
||||||
@ -31,23 +34,36 @@ typedef unsigned int stb_uint;
|
|||||||
typedef unsigned char stb_uchar;
|
typedef unsigned char stb_uchar;
|
||||||
stb_uint stb_compress(stb_uchar* out, stb_uchar* in, stb_uint len);
|
stb_uint stb_compress(stb_uchar* out, stb_uchar* in, stb_uint len);
|
||||||
|
|
||||||
static bool binary_to_compressed_c(const char* filename, const char* symbol, bool use_base85_encoding, bool use_compression, bool use_static);
|
enum SourceEncoding
|
||||||
|
{
|
||||||
|
SourceEncoding_U8, // New default since 2024/11
|
||||||
|
SourceEncoding_U32,
|
||||||
|
SourceEncoding_Base85,
|
||||||
|
};
|
||||||
|
|
||||||
|
static bool binary_to_compressed_c(const char* filename, const char* symbol, SourceEncoding source_encoding, bool use_compression, bool use_static);
|
||||||
|
|
||||||
int main(int argc, char** argv)
|
int main(int argc, char** argv)
|
||||||
{
|
{
|
||||||
if (argc < 3)
|
if (argc < 3)
|
||||||
{
|
{
|
||||||
printf("Syntax: %s [-base85] [-nocompress] [-nostatic] <inputfile> <symbolname>\n", argv[0]);
|
printf("Syntax: %s [-u8|-u32|-base85] [-nocompress] [-nostatic] <inputfile> <symbolname>\n", argv[0]);
|
||||||
|
printf("Source encoding types:\n");
|
||||||
|
printf(" -u8 = ~12 bytes of source per 4 bytes of data. 4 bytes in binary.\n");
|
||||||
|
printf(" -u32 = ~11 bytes of source per 4 bytes of data. 4 bytes in binary. Need endianness swapping on big-endian.\n");
|
||||||
|
printf(" -base85 = ~5 bytes of source per 4 bytes of data. 5 bytes in binary. Need decoder.\n");
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
int argn = 1;
|
int argn = 1;
|
||||||
bool use_base85_encoding = false;
|
|
||||||
bool use_compression = true;
|
bool use_compression = true;
|
||||||
bool use_static = true;
|
bool use_static = true;
|
||||||
|
SourceEncoding source_encoding = SourceEncoding_U8; // New default
|
||||||
while (argn < (argc - 2) && argv[argn][0] == '-')
|
while (argn < (argc - 2) && argv[argn][0] == '-')
|
||||||
{
|
{
|
||||||
if (strcmp(argv[argn], "-base85") == 0) { use_base85_encoding = true; argn++; }
|
if (strcmp(argv[argn], "-u8") == 0) { source_encoding = SourceEncoding_U8; argn++; }
|
||||||
|
else if (strcmp(argv[argn], "-u32") == 0) { source_encoding = SourceEncoding_U32; argn++; }
|
||||||
|
else if (strcmp(argv[argn], "-base85") == 0) { source_encoding = SourceEncoding_Base85; argn++; }
|
||||||
else if (strcmp(argv[argn], "-nocompress") == 0) { use_compression = false; argn++; }
|
else if (strcmp(argv[argn], "-nocompress") == 0) { use_compression = false; argn++; }
|
||||||
else if (strcmp(argv[argn], "-nostatic") == 0) { use_static = false; argn++; }
|
else if (strcmp(argv[argn], "-nostatic") == 0) { use_static = false; argn++; }
|
||||||
else
|
else
|
||||||
@ -57,7 +73,7 @@ int main(int argc, char** argv)
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
bool ret = binary_to_compressed_c(argv[argn], argv[argn + 1], use_base85_encoding, use_compression, use_static);
|
bool ret = binary_to_compressed_c(argv[argn], argv[argn + 1], source_encoding, use_compression, use_static);
|
||||||
if (!ret)
|
if (!ret)
|
||||||
fprintf(stderr, "Error opening or reading file: '%s'\n", argv[argn]);
|
fprintf(stderr, "Error opening or reading file: '%s'\n", argv[argn]);
|
||||||
return ret ? 0 : 1;
|
return ret ? 0 : 1;
|
||||||
@ -69,7 +85,7 @@ char Encode85Byte(unsigned int x)
|
|||||||
return (char)((x >= '\\') ? x + 1 : x);
|
return (char)((x >= '\\') ? x + 1 : x);
|
||||||
}
|
}
|
||||||
|
|
||||||
bool binary_to_compressed_c(const char* filename, const char* symbol, bool use_base85_encoding, bool use_compression, bool use_static)
|
bool binary_to_compressed_c(const char* filename, const char* symbol, SourceEncoding source_encoding, bool use_compression, bool use_static)
|
||||||
{
|
{
|
||||||
// Read file
|
// Read file
|
||||||
FILE* f = fopen(filename, "rb");
|
FILE* f = fopen(filename, "rb");
|
||||||
@ -91,11 +107,11 @@ bool binary_to_compressed_c(const char* filename, const char* symbol, bool use_b
|
|||||||
// Output as Base85 encoded
|
// Output as Base85 encoded
|
||||||
FILE* out = stdout;
|
FILE* out = stdout;
|
||||||
fprintf(out, "// File: '%s' (%d bytes)\n", filename, (int)data_sz);
|
fprintf(out, "// File: '%s' (%d bytes)\n", filename, (int)data_sz);
|
||||||
fprintf(out, "// Exported using binary_to_compressed_c.cpp\n");
|
|
||||||
const char* static_str = use_static ? "static " : "";
|
const char* static_str = use_static ? "static " : "";
|
||||||
const char* compressed_str = use_compression ? "compressed_" : "";
|
const char* compressed_str = use_compression ? "compressed_" : "";
|
||||||
if (use_base85_encoding)
|
if (source_encoding == SourceEncoding_Base85)
|
||||||
{
|
{
|
||||||
|
fprintf(out, "// Exported using binary_to_compressed_c.exe -base85 \"%s\" %s\n", filename, symbol);
|
||||||
fprintf(out, "%sconst char %s_%sdata_base85[%d+1] =\n \"", static_str, symbol, compressed_str, (int)((compressed_sz + 3) / 4)*5);
|
fprintf(out, "%sconst char %s_%sdata_base85[%d+1] =\n \"", static_str, symbol, compressed_str, (int)((compressed_sz + 3) / 4)*5);
|
||||||
char prev_c = 0;
|
char prev_c = 0;
|
||||||
for (int src_i = 0; src_i < compressed_sz; src_i += 4)
|
for (int src_i = 0; src_i < compressed_sz; src_i += 4)
|
||||||
@ -113,10 +129,10 @@ bool binary_to_compressed_c(const char* filename, const char* symbol, bool use_b
|
|||||||
}
|
}
|
||||||
fprintf(out, "\";\n\n");
|
fprintf(out, "\";\n\n");
|
||||||
}
|
}
|
||||||
#if 0
|
else if (source_encoding == SourceEncoding_U8)
|
||||||
else
|
|
||||||
{
|
{
|
||||||
// As individual bytes, not subject to endianness issues.
|
// As individual bytes, not subject to endianness issues.
|
||||||
|
fprintf(out, "// Exported using binary_to_compressed_c.exe -u8 \"%s\" %s\n", filename, symbol);
|
||||||
fprintf(out, "%sconst unsigned int %s_%ssize = %d;\n", static_str, symbol, compressed_str, (int)compressed_sz);
|
fprintf(out, "%sconst unsigned int %s_%ssize = %d;\n", static_str, symbol, compressed_str, (int)compressed_sz);
|
||||||
fprintf(out, "%sconst unsigned char %s_%sdata[%d] =\n{", static_str, symbol, compressed_str, (int)compressed_sz);
|
fprintf(out, "%sconst unsigned char %s_%sdata[%d] =\n{", static_str, symbol, compressed_str, (int)compressed_sz);
|
||||||
int column = 0;
|
int column = 0;
|
||||||
@ -131,10 +147,10 @@ bool binary_to_compressed_c(const char* filename, const char* symbol, bool use_b
|
|||||||
}
|
}
|
||||||
fprintf(out, "\n};\n\n");
|
fprintf(out, "\n};\n\n");
|
||||||
}
|
}
|
||||||
#else
|
else if (source_encoding == SourceEncoding_U32)
|
||||||
else
|
|
||||||
{
|
{
|
||||||
// As integers
|
// As integers
|
||||||
|
fprintf(out, "// Exported using binary_to_compressed_c.exe -u32 \"%s\" %s\n", filename, symbol);
|
||||||
fprintf(out, "%sconst unsigned int %s_%ssize = %d;\n", static_str, symbol, compressed_str, (int)compressed_sz);
|
fprintf(out, "%sconst unsigned int %s_%ssize = %d;\n", static_str, symbol, compressed_str, (int)compressed_sz);
|
||||||
fprintf(out, "%sconst unsigned int %s_%sdata[%d/4] =\n{", static_str, symbol, compressed_str, (int)((compressed_sz + 3) / 4)*4);
|
fprintf(out, "%sconst unsigned int %s_%sdata[%d/4] =\n{", static_str, symbol, compressed_str, (int)((compressed_sz + 3) / 4)*4);
|
||||||
int column = 0;
|
int column = 0;
|
||||||
@ -148,7 +164,6 @@ bool binary_to_compressed_c(const char* filename, const char* symbol, bool use_b
|
|||||||
}
|
}
|
||||||
fprintf(out, "\n};\n\n");
|
fprintf(out, "\n};\n\n");
|
||||||
}
|
}
|
||||||
#endif
|
|
||||||
|
|
||||||
// Cleanup
|
// Cleanup
|
||||||
delete[] data;
|
delete[] data;
|
||||||
|
Loading…
Reference in New Issue
Block a user