Fixed #211 font baking bug with multiple ranges
This commit is contained in:
parent
cae6005015
commit
338eba3d57
35
nuklear.h
35
nuklear.h
@ -1,5 +1,5 @@
|
|||||||
/*
|
/*
|
||||||
Nuklear - v1.091 - public domain
|
Nuklear - v1.092 - public domain
|
||||||
no warrenty implied; use at your own risk.
|
no warrenty implied; use at your own risk.
|
||||||
authored from 2015-2016 by Micha Mettke
|
authored from 2015-2016 by Micha Mettke
|
||||||
|
|
||||||
@ -199,6 +199,8 @@ LICENSE:
|
|||||||
publish and distribute this file as you see fit.
|
publish and distribute this file as you see fit.
|
||||||
|
|
||||||
CHANGELOG:
|
CHANGELOG:
|
||||||
|
- 2016/08/12 (1.092)- Fixed a bug in font atlas which caused wrong loading
|
||||||
|
of glyphes for font with multiple ranges.
|
||||||
- 2016/08/12 (1.091)- Added additional function to check if window is currently
|
- 2016/08/12 (1.091)- Added additional function to check if window is currently
|
||||||
hidden and therefore not visible.
|
hidden and therefore not visible.
|
||||||
- 2016/08/12 (1.091)- nk_window_is_closed now queries the correct flag `NK_WINDOW_CLOSED`
|
- 2016/08/12 (1.091)- nk_window_is_closed now queries the correct flag `NK_WINDOW_CLOSED`
|
||||||
@ -680,6 +682,7 @@ NK_API struct nk_vec2 nk_layout_space_to_screen(struct nk_context*, st
|
|||||||
NK_API struct nk_vec2 nk_layout_space_to_local(struct nk_context*, struct nk_vec2);
|
NK_API struct nk_vec2 nk_layout_space_to_local(struct nk_context*, struct nk_vec2);
|
||||||
NK_API struct nk_rect nk_layout_space_rect_to_screen(struct nk_context*, struct nk_rect);
|
NK_API struct nk_rect nk_layout_space_rect_to_screen(struct nk_context*, struct nk_rect);
|
||||||
NK_API struct nk_rect nk_layout_space_rect_to_local(struct nk_context*, struct nk_rect);
|
NK_API struct nk_rect nk_layout_space_rect_to_local(struct nk_context*, struct nk_rect);
|
||||||
|
NK_API float nk_layout_ratio_from_pixel(struct nk_context*, float pixel_width);
|
||||||
|
|
||||||
/* Layout: Group */
|
/* Layout: Group */
|
||||||
NK_API int nk_group_begin(struct nk_context*, struct nk_panel*, const char *title, nk_flags);
|
NK_API int nk_group_begin(struct nk_context*, struct nk_panel*, const char *title, nk_flags);
|
||||||
@ -961,6 +964,7 @@ NK_API void nk_color_hsva_fv(float *hsva_out, struct nk_colo
|
|||||||
/* image */
|
/* image */
|
||||||
NK_API nk_handle nk_handle_ptr(void*);
|
NK_API nk_handle nk_handle_ptr(void*);
|
||||||
NK_API nk_handle nk_handle_id(int);
|
NK_API nk_handle nk_handle_id(int);
|
||||||
|
NK_API struct nk_image nk_image_handle(nk_handle);
|
||||||
NK_API struct nk_image nk_image_ptr(void*);
|
NK_API struct nk_image nk_image_ptr(void*);
|
||||||
NK_API struct nk_image nk_image_id(int);
|
NK_API struct nk_image nk_image_id(int);
|
||||||
NK_API int nk_image_is_subimage(const struct nk_image* img);
|
NK_API int nk_image_is_subimage(const struct nk_image* img);
|
||||||
@ -4151,6 +4155,20 @@ nk_subimage_handle(nk_handle handle, unsigned short w, unsigned short h,
|
|||||||
return s;
|
return s;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
NK_API struct nk_image
|
||||||
|
nk_image_handle(nk_handle handle)
|
||||||
|
{
|
||||||
|
struct nk_image s;
|
||||||
|
nk_zero(&s, sizeof(s));
|
||||||
|
s.handle = handle;
|
||||||
|
s.w = 0; s.h = 0;
|
||||||
|
s.region[0] = 0;
|
||||||
|
s.region[1] = 0;
|
||||||
|
s.region[2] = 0;
|
||||||
|
s.region[3] = 0;
|
||||||
|
return s;
|
||||||
|
}
|
||||||
|
|
||||||
NK_API struct nk_image
|
NK_API struct nk_image
|
||||||
nk_image_ptr(void *ptr)
|
nk_image_ptr(void *ptr)
|
||||||
{
|
{
|
||||||
@ -9266,14 +9284,13 @@ nk_font_bake(struct nk_font_baker *baker, void *image_memory, int width, int hei
|
|||||||
|
|
||||||
/* query glyph bounds from stb_truetype */
|
/* query glyph bounds from stb_truetype */
|
||||||
const struct nk_tt_packedchar *pc = &range->chardata_for_range[char_idx];
|
const struct nk_tt_packedchar *pc = &range->chardata_for_range[char_idx];
|
||||||
glyph_count++;
|
|
||||||
if (!pc->x0 && !pc->x1 && !pc->y0 && !pc->y1) continue;
|
if (!pc->x0 && !pc->x1 && !pc->y0 && !pc->y1) continue;
|
||||||
codepoint = (nk_rune)(range->first_unicode_codepoint_in_range + char_idx);
|
codepoint = (nk_rune)(range->first_unicode_codepoint_in_range + char_idx);
|
||||||
nk_tt_GetPackedQuad(range->chardata_for_range, (int)width,
|
nk_tt_GetPackedQuad(range->chardata_for_range, (int)width,
|
||||||
(int)height, char_idx, &dummy_x, &dummy_y, &q, 0);
|
(int)height, char_idx, &dummy_x, &dummy_y, &q, 0);
|
||||||
|
|
||||||
/* fill own glyph type with data */
|
/* fill own glyph type with data */
|
||||||
glyph = &glyphs[dst_font->glyph_offset + (unsigned int)char_idx];
|
glyph = &glyphs[dst_font->glyph_offset + (unsigned int)glyph_count];
|
||||||
glyph->codepoint = codepoint;
|
glyph->codepoint = codepoint;
|
||||||
glyph->x0 = q.x0; glyph->y0 = q.y0;
|
glyph->x0 = q.x0; glyph->y0 = q.y0;
|
||||||
glyph->x1 = q.x1; glyph->y1 = q.y1;
|
glyph->x1 = q.x1; glyph->y1 = q.y1;
|
||||||
@ -9296,6 +9313,7 @@ nk_font_bake(struct nk_font_baker *baker, void *image_memory, int width, int hei
|
|||||||
glyph->xadvance = (pc->xadvance + cfg->spacing.x);
|
glyph->xadvance = (pc->xadvance + cfg->spacing.x);
|
||||||
if (cfg->pixel_snap)
|
if (cfg->pixel_snap)
|
||||||
glyph->xadvance = (float)(int)(glyph->xadvance + 0.5f);
|
glyph->xadvance = (float)(int)(glyph->xadvance + 0.5f);
|
||||||
|
glyph_count++;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
dst_font->glyph_count = glyph_count;
|
dst_font->glyph_count = glyph_count;
|
||||||
@ -16806,6 +16824,17 @@ nk_row_layout(struct nk_context *ctx, enum nk_layout_format fmt,
|
|||||||
win->layout->row.filled = 0;
|
win->layout->row.filled = 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
NK_API float
|
||||||
|
nk_layout_ratio_from_pixel(struct nk_context *ctx, float pixel_width)
|
||||||
|
{
|
||||||
|
struct nk_window *win;
|
||||||
|
NK_ASSERT(ctx);
|
||||||
|
NK_ASSERT(pixel_width);
|
||||||
|
if (!ctx || !ctx->current || !ctx->current->layout) return 0;
|
||||||
|
win = ctx->current;
|
||||||
|
return NK_CLAMP(0.0f, pixel_width/win->bounds.x, 1.0f);
|
||||||
|
}
|
||||||
|
|
||||||
NK_API void
|
NK_API void
|
||||||
nk_layout_row_dynamic(struct nk_context *ctx, float height, int cols)
|
nk_layout_row_dynamic(struct nk_context *ctx, float height, int cols)
|
||||||
{
|
{
|
||||||
|
Loading…
Reference in New Issue
Block a user