2024-01-21 13:35:52 -05:00
|
|
|
package sectr
|
|
|
|
|
2024-02-13 17:16:39 -05:00
|
|
|
import "core:math"
|
2024-05-13 21:53:08 -04:00
|
|
|
import "core:strings"
|
2024-02-27 07:50:57 -05:00
|
|
|
import "core:unicode/utf8"
|
2024-01-21 13:35:52 -05:00
|
|
|
import rl "vendor:raylib"
|
|
|
|
|
2024-02-13 17:16:39 -05:00
|
|
|
debug_draw_text :: proc( content : string, pos : Vec2, size : f32, color : rl.Color = rl.WHITE, font : FontID = Font_Default )
|
2024-01-21 13:35:52 -05:00
|
|
|
{
|
2024-03-11 02:05:18 -04:00
|
|
|
// profile(#procedure)
|
2024-02-11 23:00:06 -05:00
|
|
|
state := get_state(); using state
|
|
|
|
|
2024-01-21 13:35:52 -05:00
|
|
|
if len( content ) == 0 {
|
|
|
|
return
|
|
|
|
}
|
2024-03-07 15:57:05 -05:00
|
|
|
runes, alloc_error := to_runes( content, frame_allocator() )
|
2024-03-05 10:40:28 -05:00
|
|
|
// runes, alloc_error := to_runes( content, context.temp_allocator )
|
|
|
|
// verify( alloc_error == AllocatorError.None, "Failed to temp allocate runes" )
|
2024-01-21 13:35:52 -05:00
|
|
|
|
2024-01-22 03:47:53 -05:00
|
|
|
font := font
|
2024-02-27 09:32:26 -05:00
|
|
|
if font.key == Font_Default.key {
|
2024-02-13 18:50:22 -05:00
|
|
|
// if ( len(font) == 0 ) {
|
2024-02-11 23:00:06 -05:00
|
|
|
font = default_font
|
2024-01-22 03:47:53 -05:00
|
|
|
}
|
2024-05-10 19:50:37 -04:00
|
|
|
pos := screen_to_render_pos(pos)
|
2024-02-11 23:00:06 -05:00
|
|
|
|
2024-02-13 17:16:39 -05:00
|
|
|
px_size := size
|
|
|
|
|
|
|
|
rl_font := to_rl_Font(font, px_size )
|
2024-05-10 19:20:50 -04:00
|
|
|
rl.SetTextureFilter(rl_font.texture, rl.TextureFilter.POINT)
|
2024-02-13 17:16:39 -05:00
|
|
|
rl.DrawTextCodepoints( rl_font,
|
|
|
|
raw_data(runes), cast(i32) len(runes),
|
|
|
|
position = transmute(rl.Vector2) pos,
|
|
|
|
fontSize = px_size,
|
|
|
|
spacing = 0.0,
|
|
|
|
tint = color );
|
2024-05-10 19:20:50 -04:00
|
|
|
rl.SetTextureFilter(rl_font.texture, rl.TextureFilter.POINT)
|
2024-02-13 17:16:39 -05:00
|
|
|
}
|
|
|
|
|
2024-05-09 04:02:33 -04:00
|
|
|
draw_text_screenspace :: proc( content : StrRunesPair, pos : Vec2, size : f32, color : rl.Color = rl.WHITE, font : FontID = Font_Default )
|
|
|
|
{
|
|
|
|
// profile(#procedure)
|
|
|
|
state := get_state(); using state
|
|
|
|
|
|
|
|
if len( content.str ) == 0 {
|
|
|
|
return
|
|
|
|
}
|
|
|
|
font := font
|
|
|
|
if font.key == Font_Default.key {
|
|
|
|
font = default_font
|
|
|
|
}
|
|
|
|
pos := pos
|
|
|
|
|
|
|
|
rl_font := to_rl_Font(font, size )
|
|
|
|
runes := content.runes
|
|
|
|
|
2024-05-10 19:20:50 -04:00
|
|
|
rl.SetTextureFilter(rl_font.texture, rl.TextureFilter.POINT)
|
2024-05-09 04:02:33 -04:00
|
|
|
rl.DrawTextCodepoints( rl_font,
|
|
|
|
raw_data(runes), cast(i32) len(runes),
|
|
|
|
position = transmute(rl.Vector2) pos,
|
|
|
|
fontSize = size,
|
|
|
|
spacing = 0.0,
|
|
|
|
tint = color );
|
|
|
|
rl.SetTextureFilter(rl_font.texture, rl.TextureFilter.POINT)
|
|
|
|
}
|
|
|
|
|
|
|
|
ws_view_draw_text_string :: proc( content : string, pos : Vec2, size : f32, color : rl.Color = rl.WHITE, font : FontID = Font_Default )
|
2024-02-13 17:16:39 -05:00
|
|
|
{
|
2024-03-11 02:05:18 -04:00
|
|
|
// profile(#procedure)
|
2024-02-13 17:16:39 -05:00
|
|
|
state := get_state(); using state
|
|
|
|
|
|
|
|
if len( content ) == 0 {
|
|
|
|
return
|
|
|
|
}
|
2024-03-07 15:57:05 -05:00
|
|
|
runes, alloc_error := to_runes( content, frame_allocator() )
|
2024-03-02 20:22:28 -05:00
|
|
|
verify( alloc_error == AllocatorError.None, "Failed to temp allocate runes" )
|
2024-02-13 17:16:39 -05:00
|
|
|
|
|
|
|
font := font
|
2024-02-27 09:32:26 -05:00
|
|
|
if font.key == Font_Default.key {
|
2024-02-13 18:50:22 -05:00
|
|
|
// if len(font) == 0 {
|
2024-02-13 17:16:39 -05:00
|
|
|
font = default_font
|
|
|
|
}
|
2024-05-09 04:02:33 -04:00
|
|
|
pos := ws_view_to_render_pos(pos)
|
2024-02-13 17:16:39 -05:00
|
|
|
|
|
|
|
px_size := size
|
|
|
|
zoom_adjust := px_size * project.workspace.cam.zoom
|
|
|
|
|
|
|
|
rl_font := to_rl_Font(font, zoom_adjust )
|
2024-05-13 21:53:08 -04:00
|
|
|
rl.SetTextureFilter(rl_font.texture, rl.TextureFilter.POINT)
|
2024-02-13 17:16:39 -05:00
|
|
|
rl.DrawTextCodepoints( rl_font,
|
2024-01-21 13:35:52 -05:00
|
|
|
raw_data(runes), cast(i32) len(runes),
|
2024-03-08 23:20:49 -05:00
|
|
|
position = transmute(rl.Vector2) pos,
|
|
|
|
fontSize = px_size,
|
|
|
|
spacing = 0.0,
|
|
|
|
tint = color );
|
2024-05-13 01:52:55 -04:00
|
|
|
rl.SetTextureFilter(rl_font.texture, rl.TextureFilter.POINT)
|
2024-03-08 23:20:49 -05:00
|
|
|
}
|
|
|
|
|
2024-05-13 21:53:08 -04:00
|
|
|
when true
|
2024-03-11 02:05:18 -04:00
|
|
|
{
|
2024-05-13 21:53:08 -04:00
|
|
|
ws_view_draw_text_StrRunesPair :: proc( content : StrRunesPair, pos : Vec2, size : f32, color : rl.Color = rl.WHITE, font : FontID = Font_Default )
|
|
|
|
{
|
|
|
|
profile(#procedure)
|
|
|
|
state := get_state(); using state
|
|
|
|
|
|
|
|
if len( content.str ) == 0 {
|
|
|
|
return
|
|
|
|
}
|
|
|
|
font := font
|
|
|
|
if font.key == Font_Default.key {
|
|
|
|
font = default_font
|
|
|
|
}
|
|
|
|
pos := ws_view_to_render_pos(pos)
|
|
|
|
|
|
|
|
px_size := size
|
|
|
|
zoom_adjust := px_size * project.workspace.cam.zoom
|
|
|
|
rl_font := to_rl_Font(font, zoom_adjust )
|
|
|
|
runes := content.runes
|
|
|
|
|
|
|
|
profile_begin("raylib draw codepoints related")
|
|
|
|
// rl.DrawTextCodepoints( rl_font,
|
|
|
|
// raw_data(runes), cast(i32) len(runes),
|
|
|
|
// position = transmute(rl.Vector2) pos,
|
|
|
|
// fontSize = px_size,
|
|
|
|
// spacing = 0.0,
|
|
|
|
// tint = color );
|
|
|
|
rl.DrawTextEx(rl_font,
|
|
|
|
strings.clone_to_cstring(content.str),
|
|
|
|
position = transmute(rl.Vector2) pos,
|
|
|
|
fontSize = px_size,
|
|
|
|
spacing = 0.0,
|
|
|
|
tint = color
|
|
|
|
)
|
|
|
|
profile_end()
|
2024-03-08 23:20:49 -05:00
|
|
|
}
|
2024-05-13 21:53:08 -04:00
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
|
|
|
ws_view_draw_text_StrRunesPair :: proc( content : StrRunesPair, pos : Vec2, size : f32, color : rl.Color = rl.WHITE, font : FontID = Font_Default )
|
|
|
|
{
|
|
|
|
profile(#procedure)
|
|
|
|
state := get_state(); using state
|
2024-03-08 23:20:49 -05:00
|
|
|
|
2024-05-13 21:53:08 -04:00
|
|
|
// We need an alternative way to draw text to the screen (the above is way to expensive)
|
|
|
|
// Possibly need to watch handmade hero...
|
2024-03-08 23:20:49 -05:00
|
|
|
|
2024-05-13 21:53:08 -04:00
|
|
|
|
|
|
|
}
|
2024-01-21 13:35:52 -05:00
|
|
|
}
|
2024-02-11 23:00:06 -05:00
|
|
|
|
|
|
|
// Raylib's equivalent doesn't take a length for the string (making it a pain in the ass)
|
|
|
|
// So this is a 1:1 copy except it takes Odin strings
|
2024-03-09 13:55:47 -05:00
|
|
|
measure_text_size :: proc( text : string, font : FontID, font_size := Font_Use_Default_Size, spacing : f32 ) -> Vec2
|
2024-02-11 23:00:06 -05:00
|
|
|
{
|
2024-03-11 02:05:18 -04:00
|
|
|
// profile(#procedure)
|
2024-02-13 17:16:39 -05:00
|
|
|
px_size := math.round( points_to_pixels( font_size ) )
|
|
|
|
rl_font := to_rl_Font( font, font_size )
|
|
|
|
|
2024-02-11 23:00:06 -05:00
|
|
|
// This is a static var within raylib. We don't have getter access to it.
|
2024-02-13 17:16:39 -05:00
|
|
|
// Note(Ed) : raylib font size is in pixels so this is also.
|
2024-02-11 23:00:06 -05:00
|
|
|
@static text_line_spacing : f32 = 15
|
|
|
|
|
2024-03-09 13:55:47 -05:00
|
|
|
text_size : Vec2
|
2024-02-11 23:00:06 -05:00
|
|
|
|
2024-02-13 17:16:39 -05:00
|
|
|
if rl_font.texture.id == 0 || len(text) == 0 {
|
2024-02-11 23:00:06 -05:00
|
|
|
return text_size
|
|
|
|
}
|
|
|
|
|
|
|
|
temp_byte_counter : i32 = 0 // Used to count longer text line num chars
|
|
|
|
byte_counter : i32 = 0
|
|
|
|
|
|
|
|
text_width : f32 = 0.0
|
|
|
|
temp_text_width : f32 = 0.0 // Used to counter longer text line width
|
|
|
|
|
2024-02-13 17:16:39 -05:00
|
|
|
text_height := cast(f32) rl_font.baseSize
|
|
|
|
scale_factor := px_size / text_height
|
2024-02-11 23:00:06 -05:00
|
|
|
|
|
|
|
letter : rune
|
|
|
|
index : i32 = 0
|
|
|
|
|
2024-02-13 17:16:39 -05:00
|
|
|
for id : i32 = 0; id < i32(len(text));
|
|
|
|
{
|
2024-02-11 23:00:06 -05:00
|
|
|
byte_counter += 1
|
|
|
|
|
|
|
|
next : i32 = 0
|
|
|
|
|
|
|
|
ctext := cast(cstring) ( & raw_data( text )[id] )
|
|
|
|
letter = rl.GetCodepointNext( ctext, & next )
|
2024-02-13 17:16:39 -05:00
|
|
|
index = rl.GetGlyphIndex( rl_font, letter )
|
2024-02-11 23:00:06 -05:00
|
|
|
|
|
|
|
id += 1
|
|
|
|
|
|
|
|
if letter != rune('\n')
|
|
|
|
{
|
2024-02-13 17:16:39 -05:00
|
|
|
if rl_font.glyphs[index].advanceX != 0 {
|
|
|
|
text_width += f32(rl_font.glyphs[index].advanceX)
|
2024-02-11 23:00:06 -05:00
|
|
|
}
|
|
|
|
else {
|
2024-02-13 17:16:39 -05:00
|
|
|
text_width += rl_font.recs[index].width + f32(rl_font.glyphs[index].offsetX)
|
2024-02-11 23:00:06 -05:00
|
|
|
}
|
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
|
|
|
if temp_text_width < text_width {
|
|
|
|
temp_text_width = text_width
|
|
|
|
}
|
|
|
|
byte_counter = 0
|
|
|
|
text_width = 0
|
|
|
|
|
|
|
|
text_height += text_line_spacing
|
|
|
|
|
|
|
|
if temp_byte_counter < byte_counter {
|
|
|
|
temp_byte_counter = byte_counter
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
if temp_text_width < text_width {
|
|
|
|
temp_text_width = text_width
|
|
|
|
}
|
|
|
|
text_size.x = temp_text_width * scale_factor + f32(temp_byte_counter - 1) * spacing
|
|
|
|
text_size.y = text_height * scale_factor
|
|
|
|
|
|
|
|
return text_size
|
|
|
|
}
|