examples: use os.resource_abs_path, so `v run examples/ttf_font/example_ttf.v` works
parent
c067cc0357
commit
692a718428
|
@ -2,37 +2,30 @@ import gg
|
|||
import gx
|
||||
import sokol.sapp
|
||||
import sokol.sgl
|
||||
|
||||
import x.ttf
|
||||
import os
|
||||
//import math
|
||||
|
||||
// import math
|
||||
const (
|
||||
win_width = 600
|
||||
win_height = 700
|
||||
bg_color = gx.white
|
||||
font_paths = [
|
||||
"Imprima-Regular.ttf"
|
||||
"Graduate-Regular.ttf"
|
||||
os.resource_abs_path('Imprima-Regular.ttf'),
|
||||
os.resource_abs_path('Graduate-Regular.ttf'),
|
||||
]
|
||||
)
|
||||
|
||||
/******************************************************************************
|
||||
*
|
||||
* UI
|
||||
*
|
||||
*****************************************************************************/
|
||||
// UI
|
||||
struct App_data {
|
||||
pub mut:
|
||||
gg &gg.Context
|
||||
sg_img C.sg_image
|
||||
init_flag bool
|
||||
frame_c int
|
||||
|
||||
tf []ttf.TTF_File
|
||||
ttf_render []ttf.TTF_render_Sokol
|
||||
text_ready_flag bool
|
||||
|
||||
mouse_x int = -1
|
||||
mouse_y int = -1
|
||||
}
|
||||
|
@ -41,29 +34,24 @@ fn my_init(mut app App_data) {
|
|||
app.init_flag = true
|
||||
}
|
||||
|
||||
fn draw_frame(mut app &App_data) {
|
||||
cframe_txt := "Current Frame: $app.frame_c"
|
||||
|
||||
fn draw_frame(mut app App_data) {
|
||||
cframe_txt := 'Current Frame: $app.frame_c'
|
||||
app.gg.begin()
|
||||
|
||||
sgl.defaults()
|
||||
sgl.matrix_mode_projection()
|
||||
sgl.ortho(0.0, f32(sapp.width()), f32(sapp.height()), 0.0, -1.0, 1.0)
|
||||
sgl.c4b(0, 0, 0, 255) // black
|
||||
|
||||
// draw a line as background
|
||||
sgl.begin_line_strip()
|
||||
sgl.v2f(10, 10)
|
||||
sgl.v2f(100, 100)
|
||||
sgl.end()
|
||||
|
||||
// draw text only if the app is already initialized
|
||||
if app.init_flag == true {
|
||||
sgl.begin_line_strip()
|
||||
sgl.v2f(410, 400)
|
||||
sgl.v2f(510, 400)
|
||||
sgl.end()
|
||||
|
||||
// update the text
|
||||
mut txt1 := &app.ttf_render[0]
|
||||
if app.frame_c % 2 == 0 {
|
||||
|
@ -71,14 +59,11 @@ fn draw_frame(mut app &App_data) {
|
|||
txt1.create_text(cframe_txt, 43)
|
||||
txt1.create_texture()
|
||||
}
|
||||
|
||||
// ----- decomment if you want text rotation ----
|
||||
// txt1.bmp.angle = 3.141592 / 180 * f32(app.frame_c % 360)
|
||||
// txt1.draw_text_bmp(app.gg, 300, 350)
|
||||
// txt1.bmp.angle = 0
|
||||
|
||||
txt1.draw_text_bmp(app.gg, 30, 60)
|
||||
|
||||
// block test
|
||||
block_txt := "Today it is a good day!
|
||||
Tommorow I'm not so sure :(
|
||||
|
@ -88,13 +73,11 @@ But Vwill prevail for sure, V is the way!!
|
|||
"
|
||||
txt1 = &app.ttf_render[1]
|
||||
if app.frame_c % 2 == 0 {
|
||||
|
||||
txt1.bmp.justify = false
|
||||
if (app.frame_c >> 6) % 2 == 0 {
|
||||
// txt1.align = .left
|
||||
txt1.bmp.justify = true
|
||||
}
|
||||
|
||||
txt1.bmp.align = .left
|
||||
if (app.frame_c >> 6) % 3 == 0 {
|
||||
txt1.bmp.align = .right
|
||||
|
@ -103,20 +86,16 @@ But Vwill prevail for sure, V is the way!!
|
|||
txt1.create_text_block(block_txt, 500, 500, 32)
|
||||
txt1.create_texture()
|
||||
}
|
||||
|
||||
// decomment if want block color change
|
||||
// txt1.bmp.color = ttf.color_multiply(0xFF00FFFF, f32(app.frame_c % 255)/255.0)
|
||||
|
||||
// decomment if want block rotation wanted
|
||||
// txt1.bmp.angle = 3.141592/180 * f32(app.frame_c % 45)
|
||||
|
||||
txt1.draw_text_bmp(app.gg, 30 + (app.frame_c >> 1) & 0xFF, 200)
|
||||
|
||||
// draw mouse position
|
||||
if app.mouse_x >= 0 {
|
||||
txt1 = &app.ttf_render[2]
|
||||
txt1.destroy_texture()
|
||||
txt1.create_text("$app.mouse_x,$app.mouse_y",25)
|
||||
txt1.create_text('$app.mouse_x,$app.mouse_y', 25)
|
||||
txt1.create_texture()
|
||||
r := app.mouse_x % 255
|
||||
g := app.mouse_y % 255
|
||||
|
@ -124,14 +103,12 @@ But Vwill prevail for sure, V is the way!!
|
|||
txt1.bmp.color = color
|
||||
txt1.draw_text_bmp(app.gg, app.mouse_x, app.mouse_y)
|
||||
}
|
||||
|
||||
app.frame_c++
|
||||
}
|
||||
|
||||
app.gg.end()
|
||||
}
|
||||
|
||||
fn my_event_manager(mut ev sapp.Event, mut app &App_data) {
|
||||
fn my_event_manager(mut ev sapp.Event, mut app App_data) {
|
||||
if ev.typ == .mouse_move {
|
||||
app.mouse_x = int(ev.mouse_x)
|
||||
app.mouse_y = int(ev.mouse_y)
|
||||
|
@ -140,12 +117,10 @@ fn my_event_manager(mut ev sapp.Event, mut app &App_data) {
|
|||
|
||||
[console]
|
||||
fn main() {
|
||||
|
||||
mut app := &App_data{
|
||||
gg: 0
|
||||
}
|
||||
|
||||
app.gg = gg.new_context({
|
||||
app.gg = gg.new_context(
|
||||
width: win_width
|
||||
height: win_height
|
||||
use_ortho: true // This is needed for 2D drawing
|
||||
|
@ -156,18 +131,16 @@ fn main(){
|
|||
frame_fn: draw_frame
|
||||
event_fn: my_event_manager
|
||||
init_fn: my_init
|
||||
})
|
||||
|
||||
)
|
||||
// load TTF fonts
|
||||
for font_path in font_paths {
|
||||
mut tf := ttf.TTF_File{}
|
||||
tf.buf = os.read_bytes(font_path) or { panic(err) }
|
||||
println("TrueTypeFont file [$font_path] len: ${tf.buf.len}")
|
||||
println('TrueTypeFont file [$font_path] len: $tf.buf.len')
|
||||
tf.init()
|
||||
println("Unit per EM: $tf.units_per_em")
|
||||
println('Unit per EM: $tf.units_per_em')
|
||||
app.tf << tf
|
||||
}
|
||||
|
||||
// TTF render 0 Frame counter
|
||||
app.ttf_render << &ttf.TTF_render_Sokol{
|
||||
bmp: &ttf.BitMap{
|
||||
|
@ -179,7 +152,6 @@ fn main(){
|
|||
// use_font_metrics: true
|
||||
}
|
||||
}
|
||||
|
||||
// TTF render 1 Text Block
|
||||
app.ttf_render << &ttf.TTF_render_Sokol{
|
||||
bmp: &ttf.BitMap{
|
||||
|
@ -189,14 +161,12 @@ fn main(){
|
|||
// use_font_metrics: true
|
||||
}
|
||||
}
|
||||
|
||||
// TTF mouse position render
|
||||
app.ttf_render << &ttf.TTF_render_Sokol{
|
||||
bmp: &ttf.BitMap{
|
||||
tf: &(app.tf[0])
|
||||
}
|
||||
}
|
||||
|
||||
/* setup sokol_gfx */
|
||||
// setup sokol_gfx
|
||||
app.gg.run()
|
||||
}
|
||||
|
|
|
@ -7,6 +7,7 @@
|
|||
* that can be found in the LICENSE file.
|
||||
*
|
||||
* Note:
|
||||
* use `v -d create_data vlib/x/ttf/ttf_test.v` to generate binary data for this test file
|
||||
*
|
||||
* TODO:
|
||||
* - manage text directions R to L
|
||||
|
@ -16,8 +17,7 @@ import os
|
|||
import strings
|
||||
|
||||
const (
|
||||
font_path = "Qarmic_sans_Abridged.ttf"
|
||||
create_data = false // use true to generate binary data for this test file
|
||||
font_path = 'Qarmic_sans_Abridged.ttf'
|
||||
)
|
||||
|
||||
fn save_raw_data_as_array(buf_bin []byte, file_name string) {
|
||||
|
@ -30,11 +30,11 @@ fn save_raw_data_as_array(buf_bin []byte, file_name string) {
|
|||
|
||||
fn test_main() {
|
||||
mut tf := ttf.TTF_File{}
|
||||
if create_data == true {
|
||||
$if create_data ? {
|
||||
tf.buf = os.read_bytes(font_path) or { panic(err) }
|
||||
println("TrueTypeFont file [$font_path] len: ${tf.buf.len}")
|
||||
save_raw_data_as_array(tf.buf, "test_ttf_Font_arr.bin")
|
||||
} else {
|
||||
} $else {
|
||||
tf.buf = font_bytes
|
||||
}
|
||||
tf.init()
|
||||
|
@ -65,7 +65,7 @@ fn test_main() {
|
|||
bmp.draw_text("Test Text")
|
||||
|
||||
mut test_buf := get_raw_data(test_data)
|
||||
if create_data == true {
|
||||
$if create_data ? {
|
||||
bmp.save_as_ppm("test_ttf.ppm")
|
||||
bmp.save_raw_data("test_ttf.bin")
|
||||
test_buf = os.read_bytes("test_ttf.bin") or { panic(err) }
|
||||
|
|
Loading…
Reference in New Issue