Skip to content

Commit

Permalink
remove opengl more
Browse files Browse the repository at this point in the history
  • Loading branch information
ColleagueRiley committed Jan 2, 2025
1 parent 8fea015 commit 36965e5
Show file tree
Hide file tree
Showing 14 changed files with 294 additions and 151 deletions.
155 changes: 116 additions & 39 deletions deps/RFont.h
Original file line number Diff line number Diff line change
@@ -1,5 +1,5 @@
/*
* Copyright (c) 2021-24 ColleagueRiley [email protected]
* Copyright (c) 2021-25 ColleagueRiley [email protected]
*
* This software is provided 'as-is', without any express or implied
* warranty. In no event will the authors be held liable for any damages
Expand Down Expand Up @@ -128,7 +128,7 @@ typedef u32 RFont_texture;
#endif

#ifndef RFONT_MAX_GLYPHS
#define RFONT_MAX_GLYPHS 224
#define RFONT_MAX_GLYPHS 256
#endif

#ifndef RFONT_ATLAS_WIDTH_DEFAULT
Expand All @@ -148,7 +148,7 @@ typedef u32 RFont_texture;
#endif

#ifndef RFONT_INIT_VERTS
#define RFONT_INIT_VERTS 1024 * 600
#define RFONT_INIT_VERTS 20 * RFONT_MAX_GLYPHS
#endif

#ifndef RFONT_TEXTFORMAT_MAX_SIZE
Expand Down Expand Up @@ -179,12 +179,20 @@ typedef struct {
u32 codepoint; /* the character (for checking) */
size_t size; /* the size of the glyph */
i32 x, x2; /* coords of the character on the texture */
RFont_font* font; /* the font that the glyph belongs to */

/* source glyph data */
i32 src;
float w, h, x1, y1, advance;
} RFont_glyph;

/**
* @brief Converts a codepoint to a utf8 string.
* @param codepoint The codepoint to convert to utf8.
* @return The utf8 string.
*/
inline char* RFont_codepoint_to_utf8(u32 codepoint);

/**
* @brief Sets the framebuffer size AND runs the graphics init function.
* @param width The framebuffer width.
Expand Down Expand Up @@ -244,6 +252,9 @@ inline RFont_font* RFont_font_init_data_pro(u8* font_data, b8 auto_free, size_t
*/
inline void RFont_font_free(RFont_font* font);

typedef RFont_glyph (*RFont_glyph_fallback_callback)(RFont_font* font, u32 codepoint, size_t size);
RFont_glyph_fallback_callback RFont_set_glyph_fallback_callback(RFont_glyph_fallback_callback callback);

/**
* @brief Add a character to the font's atlas.
* @param font The font to use.
Expand All @@ -253,6 +264,25 @@ inline void RFont_font_free(RFont_font* font);
*/
inline RFont_glyph RFont_font_add_char(RFont_font* font, char ch, size_t size);

/**
* @brief Add a codepoint to the font's atlas.
* @param font The font to use.
* @param codepoint The codepoint to add to the atlas.
* @param size The size of the character.
* @return The `RFont_glyph` created from the data and added to the atlas.
*/
inline RFont_glyph RFont_font_add_codepoint(RFont_font* font, u32 codepoint, size_t size);

/**
* @brief Add a codepoint to the font's atlas.
* @param font The font to use.
* @param codepoint The codepoint to add to the atlas.
* @param size The size of the character.
* @param fallback If the fallback function should not be called.
* @return The `RFont_glyph` created from the data and added to the atlas.
*/
inline RFont_glyph RFont_font_add_codepointPro(RFont_font* font, u32 codepoint, size_t size, b8 fallback);

#ifndef RFONT_NO_FMT
/**
* @brief Formats a string.
Expand Down Expand Up @@ -481,13 +511,13 @@ struct RFont_font {
RFont_texture atlas; /* atlas texture */
size_t atlasWidth, atlasHeight;
float atlasX; /* the current x position inside the atlas */

float* verts;
float* tcoords;
};

size_t RFont_width = 0, RFont_height = 0;

float* RFont_verts;
float* RFont_tcoords;

RFont_font* font2;

void RFont_update_framebuffer(size_t width, size_t height) {
Expand All @@ -497,15 +527,12 @@ void RFont_update_framebuffer(size_t width, size_t height) {
}

void RFont_init(size_t width, size_t height) {
RFont_update_framebuffer(width, height);

#ifndef RFONT_NO_GRAPHICS
/* init any rendering stuff that needs to be initalized (eg. vbo objects) */
RFont_render_init();
#endif
RFont_update_framebuffer(width, height);

RFont_verts = (float*)RFONT_MALLOC(sizeof(float) * RFONT_INIT_VERTS);
RFont_tcoords = (float*)RFONT_MALLOC(sizeof(float) * RFONT_INIT_VERTS);
#ifndef RFONT_NO_GRAPHICS
/* init any rendering stuff that needs to be initalized (eg. vbo objects) */
RFont_render_init();
#endif
}

#ifndef RFONT_NO_STDIO
Expand Down Expand Up @@ -537,6 +564,9 @@ RFont_font* RFont_font_init_data(u8* font_data, b8 auto_free) {
RFont_font* RFont_font_init_data_pro(u8* font_data, b8 auto_free, size_t atlasWidth, size_t atlasHeight) {
RFont_font* font = (RFont_font*)RFONT_MALLOC(sizeof(RFont_font));

font->verts = (float*)RFONT_MALLOC(sizeof(float) * RFONT_INIT_VERTS);
font->tcoords = (float*)RFONT_MALLOC(sizeof(float) * RFONT_INIT_VERTS);

font->atlasWidth = atlasWidth;
font->atlasHeight = atlasHeight;

Expand Down Expand Up @@ -567,12 +597,14 @@ void RFont_font_free(RFont_font* font) {
if (font->free_font_memory)
RFONT_FREE(font->info.data);

RFONT_FREE(font->verts);
RFONT_FREE(font->tcoords);

RFONT_FREE (font);
}

void RFont_close(void) {
RFONT_FREE(RFont_verts);
RFONT_FREE(RFont_tcoords);

}


Expand Down Expand Up @@ -628,13 +660,28 @@ void RFont_font_add_string_len(RFont_font* font, const char* string, size_t strL
RFont_font_add_char(font, *str, sizes[i]);
}

RFont_glyph_fallback_callback RFont_glyph_fallback = NULL;
RFont_glyph_fallback_callback RFont_set_glyph_fallback_callback(RFont_glyph_fallback_callback callback) {
RFont_glyph_fallback_callback old = RFont_glyph_fallback;
RFont_glyph_fallback = callback;
return old;
}

RFont_glyph RFont_font_add_char(RFont_font* font, char ch, size_t size) {
static u32 utf8state = 0, codepoint = 0;

if (RFont_decode_utf8(&utf8state, &codepoint, (u8)ch) != RFONT_UTF8_ACCEPT)
return (RFont_glyph){0, 0, 0, 0, 0, 0, 0, 0, 0, 0};
if (RFont_decode_utf8(&utf8state, &codepoint, (u8)ch) != RFONT_UTF8_ACCEPT) {
return (RFont_glyph){0, 0, 0, 0, (RFont_font*)0, 0, 0, 0, 0, 0, 0};
}

return RFont_font_add_codepoint(font, codepoint, size);
}

RFont_glyph RFont_font_add_codepoint(RFont_font* font, u32 codepoint, size_t size) {
return RFont_font_add_codepointPro(font, codepoint, size, 1);
}

RFont_glyph RFont_font_add_codepointPro(RFont_font* font, u32 codepoint, size_t size, b8 fallback) {
u32 i;
for (i = 0; i < font->glyph_len; i++)
if (font->glyphs[i].codepoint == codepoint && font->glyphs[i].size == size)
Expand All @@ -643,25 +690,20 @@ RFont_glyph RFont_font_add_char(RFont_font* font, char ch, size_t size) {
RFont_glyph* glyph = &font->glyphs[i];

glyph->src = stbtt_FindGlyphIndex(&font->info, codepoint);

if (glyph->src == 0 && font2 != NULL && font2->info.data != font->info.data) {
stbtt_fontinfo saveInfo = font->info;

RFont_font* fakeFont = font;
fakeFont->info = font2->info;

RFont_glyph g = RFont_font_add_char(fakeFont, 't', size);

fakeFont->info = saveInfo;

return g;

if (glyph->src == 0 && fallback && RFont_glyph_fallback) {
RFont_glyph fallback = RFont_glyph_fallback(font, codepoint, size);
if (fallback.codepoint != 0 && fallback.size != 0) {
return fallback;
}
}

font->glyph_len++;

i32 x0, y0, x1, y1, w = 0, h = 0;
if (stbtt_GetGlyphBox(&font->info, glyph->src, &x0, &y0, &x1, &y1) == 0)
return (RFont_glyph){0, 0, 0, 0, 0, 0, 0, 0, 0, 0};
if (stbtt_GetGlyphBox(&font->info, glyph->src, &x0, &y0, &x1, &y1) == 0) {
return (RFont_glyph){0, 0, 0, 0, (RFont_font*)0, 0, 0, 0, 0, 0, 0};
}

float scale = ((float)size) / font->fheight;

Expand All @@ -676,6 +718,7 @@ RFont_glyph RFont_font_add_char(RFont_font* font, char ch, size_t size) {
glyph->x2 = font->atlasX + glyph->w;
glyph->x1 = floorf(x0 * scale);
glyph->y1 = floor(-y1 * scale);
glyph->font = font;

#ifndef RFONT_NO_GRAPHICS

Expand Down Expand Up @@ -756,9 +799,36 @@ RFont_area RFont_draw_text_spacing(RFont_font* font, const char* text, float x,
return RFont_draw_text_len(font, text, 0, x, y, size, spacing);
}

char* RFont_codepoint_to_utf8(u32 codepoint) {
static char utf8[5];
if (codepoint <= 0x7F) {
utf8[0] = codepoint;
utf8[1] = 0;
} else if (codepoint <= 0x7FF) {
utf8[0] = 0xC0 | (codepoint >> 6);
utf8[1] = 0x80 | (codepoint & 0x3F);
utf8[2] = 0;
} else if (codepoint <= 0xFFFF) {
utf8[0] = 0xE0 | (codepoint >> 12);
utf8[1] = 0x80 | ((codepoint >> 6) & 0x3F);
utf8[2] = 0x80 | (codepoint & 0x3F);
utf8[3] = 0;
} else if (codepoint <= 0x10FFFF) {
utf8[0] = 0xF0 | (codepoint >> 18);
utf8[1] = 0x80 | ((codepoint >> 12) & 0x3F);
utf8[2] = 0x80 | ((codepoint >> 6) & 0x3F);
utf8[3] = 0x80 | (codepoint & 0x3F);
utf8[4] = 0;
} else {
utf8[0] = 0;
}

return utf8;
}

RFont_area RFont_draw_text_len(RFont_font* font, const char* text, size_t len, float x, float y, u32 size, float spacing) {
float* verts = RFont_verts;
float* tcoords = RFont_tcoords;
float* verts = font->verts;
float* tcoords = font->tcoords;

float startX = x;
float startY = y;
Expand All @@ -772,8 +842,9 @@ RFont_area RFont_draw_text_len(RFont_font* font, const char* text, size_t len, f

float scale = (((float)size) / font->fheight);
float space_adv = (scale * font->space_adv) / 2;

y -= (-font->descent * scale);

float descent_offset = (-font->descent * scale);
y -= descent_offset;

for (str = (char*)text; (len == 0 || (size_t)(str - text) < len) && *str; str++) {
if (*str == '\n') {
Expand All @@ -792,6 +863,12 @@ RFont_area RFont_draw_text_len(RFont_font* font, const char* text, size_t len, f
if (glyph.codepoint == 0 && glyph.size == 0)
continue;

if (glyph.font != font) {
RFont_draw_text_len(glyph.font, RFont_codepoint_to_utf8(glyph.codepoint), 4, x, y - size + descent_offset, size, spacing);
x += glyph.advance + spacing;
continue;
}

float realX = x + glyph.x1;
float realY = y + glyph.y1;

Expand Down Expand Up @@ -845,14 +922,14 @@ RFont_area RFont_draw_text_len(RFont_font* font, const char* text, size_t len, f
tcoords[tIndex + 10] = RFONT_GET_TEXPOSX(glyph.x2, font->atlasWidth);
tcoords[tIndex + 11] = RFONT_GET_TEXPOSY(glyph.h, font->atlasHeight);

x += glyph.advance + spacing;
i += 18;
tIndex += 12;

x += glyph.advance + spacing;
}

#ifndef RFONT_NO_GRAPHICS
RFont_render_text(font->atlas, verts, tcoords, i / 3);
if (i)
RFont_render_text(font->atlas, verts, tcoords, i / 3);
#endif

return (RFont_area){(u32)(x - startX), (u32)(y - startY) + (-font->descent * scale)};
Expand Down
5 changes: 2 additions & 3 deletions examples/advanced/RSGL_rsoft.h
Original file line number Diff line number Diff line change
@@ -1,6 +1,4 @@
#define RSGL_CUSTOM_RENDER
#define RSGL_IMPLEMENTATION

#ifdef RSGL_IMPLEMENTATION
#define RSGL_GET_WORLD_X(x) (float)(x)
#define RSGL_GET_WORLD_Y(y) (float)(y)
#define RSGL_GET_WORLD_Z(z) (float)(z)
Expand Down Expand Up @@ -224,3 +222,4 @@ RSGL_programInfo RSGL_renderCreateProgram(const char* VShaderCode, const char* F
RSGL_UNUSED(VShaderCode); RSGL_UNUSED(FShaderCode); RSGL_UNUSED(posName); RSGL_UNUSED(texName); RSGL_UNUSED(colorName);
return (RSGL_programInfo) {};
}
#endif
1 change: 1 addition & 0 deletions examples/advanced/glfw.c
Original file line number Diff line number Diff line change
Expand Up @@ -2,6 +2,7 @@

#define RSGL_IMPLEMENTATION
#include "RSGL.h"
#include "RSGL_gl.h"

#define GLFW_UNUSED(x) if(x){}

Expand Down
4 changes: 3 additions & 1 deletion examples/advanced/rsoft.c
Original file line number Diff line number Diff line change
@@ -1,8 +1,10 @@
#define RGFW_IMPLEMENTATION
#define RGFW_BUFFER
#include "RGFW.h"

#define RSoft_area RGFW_area
#include "RSGL.h"

#define RSGL_IMPLEMENTATION
#include "RSGL_rsoft.h"
#include <stdio.h>

Expand Down
1 change: 1 addition & 0 deletions examples/advanced/shader.c
Original file line number Diff line number Diff line change
Expand Up @@ -3,6 +3,7 @@

#define RSGL_IMPLEMENTATION
#include "RSGL.h"
#include "RSGL_gl.h"

/*
this example is designed for Opengl 3.3 GLSL shaders
Expand Down
2 changes: 2 additions & 0 deletions examples/basics/basic.c
Original file line number Diff line number Diff line change
Expand Up @@ -5,7 +5,9 @@
#define RSGL_IMPLEMENTATION
#define RSGL_NO_X11_CURSOR

#define RSGL_IMPLEMENTATION
#include "RSGL.h"
#include "RSGL_gl.h"

#include <stdio.h>

Expand Down
2 changes: 2 additions & 0 deletions examples/basics/shapes.c
Original file line number Diff line number Diff line change
Expand Up @@ -7,7 +7,9 @@
#undef __linux__
#endif

#define RSGL_IMPLEMENTATION
#include "RSGL.h"
#include "RSGL_gl.h"

#include <stdio.h>

Expand Down
11 changes: 8 additions & 3 deletions examples/basics/text.c
Original file line number Diff line number Diff line change
@@ -1,8 +1,10 @@
#define RSGL_RENDER_LEGACY
#define RGFW_IMPLEMENTATION
#include "RGFW.h"

#define RSGL_IMPLEMENTATION
#include "RSGL.h"
#include "RSGL_gl.h"

int main(void) {
RGFW_window* win = RGFW_createWindow("name", (RGFW_rect){500, 500, 500, 500}, RGFW_CENTER);
Expand All @@ -12,7 +14,7 @@ int main(void) {
RSGL_setFont(RSGL_loadFont("Super Easy.ttf"));

u32 fps;

RFONT_UNUSED(fps);
for (; RGFW_window_shouldClose(win) == false;) {
RGFW_window_checkEvent(win);

Expand All @@ -21,9 +23,12 @@ int main(void) {

RSGL_clear(RSGL_RGB(255, 255, 255));

//RSGL_drawRect(RSGL_RECT(0, 0, 100, 100), RSGL_RGB(0, 255, 0));

RSGL_drawText("Text example\nnewlines too", RSGL_CIRCLE(200, 200, 20), RSGL_RGB(255, 0, 0));
RSGL_drawText(RSGL_strFmt("FPS : %i\nOpenGL %s", fps, RSGL_args.legacy ? "legacy (2-)" : "modern (3.3 +)"), RSGL_CIRCLE(0, 40, 40), RSGL_RGB(255, 0, 0));

RSGL_drawText(RSGL_strFmt("FPS : %i\nOpenGL %s", fps, RSGL_GL_legacy ? "legacy (2-)" : "modern (3.3 +)"), RSGL_CIRCLE(0, 40, 40), RSGL_RGB(255, 0, 0));
RSGL_drawRect(RSGL_RECT(0, 0, 100, 100), RSGL_RGB(0, 255, 0));
RSGL_drawRect(RSGL_RECT(50, 50, 100, 100), RSGL_RGBA(0, 255, 0, 50));
RSGL_draw();
RGFW_window_swapBuffers(win);

Expand Down
Loading

0 comments on commit 36965e5

Please sign in to comment.