mirror of https://gitlab.com/nakst/essence
add bitmap font
This commit is contained in:
parent
8dd2e3b496
commit
69f46115b6
Binary file not shown.
24
util/build.c
24
util/build.c
|
@ -368,17 +368,6 @@ void BuildUtilities() {
|
||||||
|
|
||||||
BUILD_UTILITY("render_svg", "-lm", "");
|
BUILD_UTILITY("render_svg", "-lm", "");
|
||||||
BUILD_UTILITY("build_core", "-pthread -DPARALLEL_BUILD", "");
|
BUILD_UTILITY("build_core", "-pthread -DPARALLEL_BUILD", "");
|
||||||
|
|
||||||
if (canBuildLuigi) {
|
|
||||||
BUILD_UTILITY("config_editor", "-lX11 -Wno-unused-parameter", "");
|
|
||||||
|
|
||||||
if (CheckDependencies("Utilities.Designer")) {
|
|
||||||
if (!CallSystem("g++ -MMD -MF \"bin/Dependency Files/designer2.d\" -D UI_LINUX -O3 "
|
|
||||||
"util/designer2.cpp -o bin/designer2 -g -lX11 -Wno-unused-parameter " WARNING_FLAGS)) {
|
|
||||||
ParseDependencies("bin/Dependency Files/designer2.d", "Utilities.Designer", false);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void Build(int optimise, bool compile) {
|
void Build(int optimise, bool compile) {
|
||||||
|
@ -1224,8 +1213,11 @@ void DoCommand(const char *l) {
|
||||||
CallSystem("cp LICENSE.md root/Installer\\ Data/licenses.txt");
|
CallSystem("cp LICENSE.md root/Installer\\ Data/licenses.txt");
|
||||||
CallSystem("mv bin/installer_archive.dat root/Installer\\ Data/archive.dat");
|
CallSystem("mv bin/installer_archive.dat root/Installer\\ Data/archive.dat");
|
||||||
CallSystem("mv bin/installer_metadata.dat root/Installer\\ Data/metadata.dat");
|
CallSystem("mv bin/installer_metadata.dat root/Installer\\ Data/metadata.dat");
|
||||||
|
} else if (0 == strcmp(l, "font-editor")) {
|
||||||
|
BUILD_UTILITY("font_editor", "-lX11 -Wno-unused-parameter", "");
|
||||||
|
CallSystem("bin/font_editor res/Fonts/Bitmap\\ Sans\\ Regular\\ 9.font");
|
||||||
} else if (0 == strcmp(l, "config")) {
|
} else if (0 == strcmp(l, "config")) {
|
||||||
BuildUtilities();
|
BUILD_UTILITY("config_editor", "-lX11 -Wno-unused-parameter", "");
|
||||||
|
|
||||||
if (CallSystem("bin/config_editor")) {
|
if (CallSystem("bin/config_editor")) {
|
||||||
printf("The config editor could not be opened.\n"
|
printf("The config editor could not be opened.\n"
|
||||||
|
@ -1235,7 +1227,13 @@ void DoCommand(const char *l) {
|
||||||
"But please bare in mind that manually editing the config file is not recommended.\n");
|
"But please bare in mind that manually editing the config file is not recommended.\n");
|
||||||
}
|
}
|
||||||
} else if (0 == strcmp(l, "designer2")) {
|
} else if (0 == strcmp(l, "designer2")) {
|
||||||
BuildUtilities();
|
if (CheckDependencies("Utilities.Designer")) {
|
||||||
|
if (!CallSystem("g++ -MMD -MF \"bin/Dependency Files/designer2.d\" -D UI_LINUX -O3 "
|
||||||
|
"util/designer2.cpp -o bin/designer2 -g -lX11 -Wno-unused-parameter " WARNING_FLAGS)) {
|
||||||
|
ParseDependencies("bin/Dependency Files/designer2.d", "Utilities.Designer", false);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
CallSystem("bin/designer2");
|
CallSystem("bin/designer2");
|
||||||
} else if (0 == strcmp(l, "replace-many")) {
|
} else if (0 == strcmp(l, "replace-many")) {
|
||||||
forceRebuild = true;
|
forceRebuild = true;
|
||||||
|
|
|
@ -1,4 +1,4 @@
|
||||||
// TODO Required: final file format, line metrics.
|
// TODO Required: final file format, line metrics, horizontally scrolling kerning editor.
|
||||||
// TODO Extensions: binary search, shifting glyphs in editor, undo/redo.
|
// TODO Extensions: binary search, shifting glyphs in editor, undo/redo.
|
||||||
|
|
||||||
#define UI_IMPLEMENTATION
|
#define UI_IMPLEMENTATION
|
||||||
|
@ -13,7 +13,7 @@
|
||||||
|
|
||||||
typedef struct FileHeader {
|
typedef struct FileHeader {
|
||||||
uint16_t glyphCount;
|
uint16_t glyphCount;
|
||||||
uint16_t _unused0;
|
uint8_t headerBytes, glyphHeaderBytes;
|
||||||
// Followed by glyphCount copies of FileGlyphHeader, sorted by codepoint.
|
// Followed by glyphCount copies of FileGlyphHeader, sorted by codepoint.
|
||||||
} FileHeader;
|
} FileHeader;
|
||||||
|
|
||||||
|
@ -62,7 +62,9 @@ void Save(void *cp) {
|
||||||
|
|
||||||
if (f) {
|
if (f) {
|
||||||
FileHeader header = {
|
FileHeader header = {
|
||||||
.glyphCount = glyphCount
|
.glyphCount = glyphCount,
|
||||||
|
.headerBytes = sizeof(FileHeader),
|
||||||
|
.glyphHeaderBytes = sizeof(FileGlyphHeader),
|
||||||
};
|
};
|
||||||
|
|
||||||
fwrite(&header, 1, sizeof(header), f);
|
fwrite(&header, 1, sizeof(header), f);
|
||||||
|
@ -279,7 +281,8 @@ void SetXAdvance(void *cp) {
|
||||||
UIElementRepaint(editor, NULL);
|
UIElementRepaint(editor, NULL);
|
||||||
}
|
}
|
||||||
|
|
||||||
int GetAdvance(int leftGlyph, int rightGlyph) {
|
int GetAdvance(int leftGlyph, int rightGlyph, bool *hasKerningEntry) {
|
||||||
|
if (hasKerningEntry) *hasKerningEntry = false;
|
||||||
int p = glyphsArray[leftGlyph].xAdvance;
|
int p = glyphsArray[leftGlyph].xAdvance;
|
||||||
|
|
||||||
if (rightGlyph != -1) {
|
if (rightGlyph != -1) {
|
||||||
|
@ -288,6 +291,7 @@ int GetAdvance(int leftGlyph, int rightGlyph) {
|
||||||
for (uintptr_t i = 0; i < glyphsArray[leftGlyph].kerningCount; i++) {
|
for (uintptr_t i = 0; i < glyphsArray[leftGlyph].kerningCount; i++) {
|
||||||
if (glyphsArray[leftGlyph].kerningArray[i].number == glyphsArray[rightGlyph].number) {
|
if (glyphsArray[leftGlyph].kerningArray[i].number == glyphsArray[rightGlyph].number) {
|
||||||
p += glyphsArray[leftGlyph].kerningArray[i].xOffset;
|
p += glyphsArray[leftGlyph].kerningArray[i].xOffset;
|
||||||
|
if (hasKerningEntry) *hasKerningEntry = true;
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -296,6 +300,31 @@ int GetAdvance(int leftGlyph, int rightGlyph) {
|
||||||
return p;
|
return p;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void DrawPreviewText(UIPainter *painter, UIElement *element, Glyph *g) {
|
||||||
|
UIDrawBlock(painter, UI_RECT_4(element->clip.r - 100, element->clip.r, element->clip.t, element->clip.t + 50), 0xFFFFFFFF);
|
||||||
|
|
||||||
|
if (previewText->bytes == 0 && g) {
|
||||||
|
DrawGlyph(painter, g, element->clip.r - 100 + 5, element->clip.t + 25);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
int px = 0;
|
||||||
|
int previous = -1;
|
||||||
|
|
||||||
|
for (int i = 0; i < previewText->bytes; i++) {
|
||||||
|
// TODO Binary search.
|
||||||
|
|
||||||
|
for (uintptr_t j = 0; j < glyphCount; j++) {
|
||||||
|
if (glyphsArray[j].number == previewText->string[i]) {
|
||||||
|
if (previous != -1) px += GetAdvance(previous, j, NULL);
|
||||||
|
DrawGlyph(painter, &glyphsArray[j], element->clip.r - 100 + 5 + px, element->clip.t + 25);
|
||||||
|
previous = j;
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
int GlyphEditorMessage(UIElement *element, UIMessage message, int di, void *dp) {
|
int GlyphEditorMessage(UIElement *element, UIMessage message, int di, void *dp) {
|
||||||
if (message == UI_MSG_PAINT) {
|
if (message == UI_MSG_PAINT) {
|
||||||
UIPainter *painter = (UIPainter *) dp;
|
UIPainter *painter = (UIPainter *) dp;
|
||||||
|
@ -325,27 +354,7 @@ int GlyphEditorMessage(UIElement *element, UIMessage message, int di, void *dp)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
UIDrawBlock(painter, UI_RECT_4(element->bounds.r - 100, element->bounds.r, element->bounds.t, element->bounds.t + 50), 0xFFFFFFFF);
|
DrawPreviewText(painter, element, g);
|
||||||
|
|
||||||
if (previewText->bytes == 0) {
|
|
||||||
DrawGlyph(painter, g, element->bounds.r - 100 + 5, element->bounds.t + 25);
|
|
||||||
} else {
|
|
||||||
int px = 0;
|
|
||||||
int previous = -1;
|
|
||||||
|
|
||||||
for (int i = 0; i < previewText->bytes; i++) {
|
|
||||||
// TODO Binary search.
|
|
||||||
|
|
||||||
for (uintptr_t j = 0; j < glyphCount; j++) {
|
|
||||||
if (glyphsArray[j].number == previewText->string[i]) {
|
|
||||||
if (previous != -1) px += GetAdvance(previous, j);
|
|
||||||
DrawGlyph(painter, &glyphsArray[j], element->bounds.r - 100 + 5 + px, element->bounds.t + 25);
|
|
||||||
previous = j;
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
} else if (message == UI_MSG_MIDDLE_UP) {
|
} else if (message == UI_MSG_MIDDLE_UP) {
|
||||||
if (selectedGlyph >= 0 && selectedGlyph < (intptr_t) glyphCount) {
|
if (selectedGlyph >= 0 && selectedGlyph < (intptr_t) glyphCount) {
|
||||||
|
@ -411,24 +420,36 @@ int KerningEditorMessage(UIElement *element, UIMessage message, int di, void *dp
|
||||||
|
|
||||||
int x = element->bounds.l + 20, y = element->bounds.t + 20;
|
int x = element->bounds.l + 20, y = element->bounds.t + 20;
|
||||||
|
|
||||||
|
selectedPairI = -1, selectedPairJ = -1;
|
||||||
|
|
||||||
for (uintptr_t i = 0; i < glyphCount; i++) {
|
for (uintptr_t i = 0; i < glyphCount; i++) {
|
||||||
for (uintptr_t j = 0; j < glyphCount; j++) {
|
for (uintptr_t j = 0; j < glyphCount; j++) {
|
||||||
|
bool hasKerningEntry = false;
|
||||||
|
|
||||||
DrawGlyph(painter, &glyphsArray[j], x, y);
|
DrawGlyph(painter, &glyphsArray[j], x, y);
|
||||||
DrawGlyph(painter, &glyphsArray[i], x + GetAdvance(j, i), y);
|
DrawGlyph(painter, &glyphsArray[i], x + GetAdvance(j, i, &hasKerningEntry), y);
|
||||||
|
|
||||||
|
UIRectangle border = UI_RECT_4(x - 5, x + 20, y - 15, y + 5);
|
||||||
|
|
||||||
|
if (hasKerningEntry) {
|
||||||
|
UIDrawBorder(painter, border, 0xFF0099FF, UI_RECT_1(1));
|
||||||
|
}
|
||||||
|
|
||||||
if (selectedPairX == (x - 20 - element->bounds.l) / 25 && selectedPairY == (y - 20 - element->bounds.t) / 20) {
|
if (selectedPairX == (x - 20 - element->bounds.l) / 25 && selectedPairY == (y - 20 - element->bounds.t) / 20) {
|
||||||
UIDrawBorder(painter, UI_RECT_4(x - 5, x + 20, y - 15, y + 5), 0xFF000000, UI_RECT_1(1));
|
UIDrawBorder(painter, border, 0xFF000000, UI_RECT_1(1));
|
||||||
selectedPairI = i, selectedPairJ = j;
|
selectedPairI = i, selectedPairJ = j;
|
||||||
}
|
}
|
||||||
|
|
||||||
x += 25;
|
x += 25;
|
||||||
|
|
||||||
if (x + 25 > element->bounds.r - 20) {
|
|
||||||
x = element->bounds.l + 20;
|
|
||||||
y += 20;
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
x = element->bounds.l + 20;
|
||||||
|
y += 20;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
DrawPreviewText(painter, element, NULL);
|
||||||
|
} else if (message == UI_MSG_GET_HEIGHT) {
|
||||||
|
return 20 * glyphCount + 40;
|
||||||
} else if (message == UI_MSG_LEFT_DOWN || message == UI_MSG_RIGHT_DOWN) {
|
} else if (message == UI_MSG_LEFT_DOWN || message == UI_MSG_RIGHT_DOWN) {
|
||||||
int delta = message == UI_MSG_LEFT_DOWN ? 1 : -1;
|
int delta = message == UI_MSG_LEFT_DOWN ? 1 : -1;
|
||||||
|
|
||||||
|
@ -478,6 +499,7 @@ int KerningEditorMessage(UIElement *element, UIMessage message, int di, void *dp
|
||||||
int PreviewTextMessage(UIElement *element, UIMessage message, int di, void *dp) {
|
int PreviewTextMessage(UIElement *element, UIMessage message, int di, void *dp) {
|
||||||
if (message == UI_MSG_VALUE_CHANGED) {
|
if (message == UI_MSG_VALUE_CHANGED) {
|
||||||
UIElementRepaint(editor, NULL);
|
UIElementRepaint(editor, NULL);
|
||||||
|
UIElementRepaint(kerning, NULL);
|
||||||
}
|
}
|
||||||
|
|
||||||
return 0;
|
return 0;
|
||||||
|
@ -509,7 +531,7 @@ int main(int argc, char **argv) {
|
||||||
glyphsTable = UITableCreate(0, 0, "ASCII\tNumber");
|
glyphsTable = UITableCreate(0, 0, "ASCII\tNumber");
|
||||||
glyphsTable->e.messageUser = GlyphsTableMessage;
|
glyphsTable->e.messageUser = GlyphsTableMessage;
|
||||||
editor = UIElementCreate(sizeof(UIElement), 0, 0, GlyphEditorMessage, "Glyph editor");
|
editor = UIElementCreate(sizeof(UIElement), 0, 0, GlyphEditorMessage, "Glyph editor");
|
||||||
kerning = UIElementCreate(sizeof(UIElement), 0, 0, KerningEditorMessage, "Kerning editor");
|
kerning = UIElementCreate(sizeof(UIElement), &UIPanelCreate(0, UI_PANEL_SCROLL)->e, UI_ELEMENT_H_FILL, KerningEditorMessage, "Kerning editor");
|
||||||
|
|
||||||
UIWindowRegisterShortcut(window, (UIShortcut) { .code = UI_KEYCODE_LETTER('S'), .ctrl = true, .invoke = Save });
|
UIWindowRegisterShortcut(window, (UIShortcut) { .code = UI_KEYCODE_LETTER('S'), .ctrl = true, .invoke = Save });
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue