From 1d69a0bd223ace4c7ae9c7b3a24cd762658024de Mon Sep 17 00:00:00 2001 From: penguindark <57967770+penguindark@users.noreply.github.com> Date: Sat, 27 Feb 2021 22:11:26 +0100 Subject: [PATCH] gg: window_size_real_pixels that for 3D without dpi scaling (#9004) --- examples/sokol/01_cubes/cube.v | 2 +- examples/sokol/02_cubes_glsl/cube_glsl.v | 4 ++-- examples/sokol/03_march_tracing_glsl/rt_glsl.v | 4 ++-- examples/sokol/04_multi_shader_glsl/rt_glsl.v | 8 ++++---- examples/sokol/05_instancing_glsl/rt_glsl.v | 6 +++--- vlib/gg/gg.v | 5 +++++ 6 files changed, 17 insertions(+), 12 deletions(-) diff --git a/examples/sokol/01_cubes/cube.v b/examples/sokol/01_cubes/cube.v index e40b7af7ee..41e3e7fd9a 100644 --- a/examples/sokol/01_cubes/cube.v +++ b/examples/sokol/01_cubes/cube.v @@ -268,7 +268,7 @@ fn cube_field(app App) { } fn frame(mut app App) { - ws := gg.window_size() + ws := gg.window_size_real_pixels() ratio := f32(ws.width) / ws.height dw := ws.width dh := ws.height diff --git a/examples/sokol/02_cubes_glsl/cube_glsl.v b/examples/sokol/02_cubes_glsl/cube_glsl.v index 4c47fd11c0..e057f1de27 100644 --- a/examples/sokol/02_cubes_glsl/cube_glsl.v +++ b/examples/sokol/02_cubes_glsl/cube_glsl.v @@ -359,7 +359,7 @@ fn draw_cube_glsl(app App) { rot := [f32(app.mouse_y), f32(app.mouse_x)] - ws := gg.window_size() + ws := gg.window_size_real_pixels() // ratio := f32(ws.width)/ws.height dw := f32(ws.width / 2) dh := f32(ws.height / 2) @@ -428,7 +428,7 @@ fn draw_texture_cubes(app App) { } fn frame(mut app App) { - ws := gg.window_size() + ws := gg.window_size_real_pixels() ratio := f32(ws.width) / ws.height dw := ws.width dh := ws.height diff --git a/examples/sokol/03_march_tracing_glsl/rt_glsl.v b/examples/sokol/03_march_tracing_glsl/rt_glsl.v index 47e2a41805..1369ad6c36 100644 --- a/examples/sokol/03_march_tracing_glsl/rt_glsl.v +++ b/examples/sokol/03_march_tracing_glsl/rt_glsl.v @@ -255,7 +255,7 @@ fn draw_cube_glsl(app App) { return } - ws := gg.window_size() + ws := gg.window_size_real_pixels() ratio := f32(ws.width) / ws.height dw := f32(ws.width / 2) dh := f32(ws.height / 2) @@ -297,7 +297,7 @@ fn draw_cube_glsl(app App) { } fn frame(mut app App) { - ws := gg.window_size() + ws := gg.window_size_real_pixels() // clear mut color_action := C.sg_color_attachment_action{ diff --git a/examples/sokol/04_multi_shader_glsl/rt_glsl.v b/examples/sokol/04_multi_shader_glsl/rt_glsl.v index 909d85f41b..6378cef2a7 100644 --- a/examples/sokol/04_multi_shader_glsl/rt_glsl.v +++ b/examples/sokol/04_multi_shader_glsl/rt_glsl.v @@ -372,7 +372,7 @@ fn draw_cube_glsl_m(app App) { return } - ws := gg.window_size() + ws := gg.window_size_real_pixels() ratio := f32(ws.width) / ws.height dw := f32(ws.width / 2) dh := f32(ws.height / 2) @@ -415,7 +415,7 @@ fn draw_cube_glsl_p(app App) { return } - ws := gg.window_size() + ws := gg.window_size_real_pixels() ratio := f32(ws.width) / ws.height dw := f32(ws.width / 2) dh := f32(ws.height / 2) @@ -458,7 +458,7 @@ fn draw_start_glsl(app App) { return } - ws := gg.window_size() + ws := gg.window_size_real_pixels() // ratio := f32(ws.width) / ws.height // dw := f32(ws.width / 2) // dh := f32(ws.height / 2) @@ -472,7 +472,7 @@ fn draw_end_glsl(app App) { } fn frame(mut app App) { - ws := gg.window_size() + ws := gg.window_size_real_pixels() // clear mut color_action := C.sg_color_attachment_action{ diff --git a/examples/sokol/05_instancing_glsl/rt_glsl.v b/examples/sokol/05_instancing_glsl/rt_glsl.v index 469bd38557..f2c6c3fb5e 100644 --- a/examples/sokol/05_instancing_glsl/rt_glsl.v +++ b/examples/sokol/05_instancing_glsl/rt_glsl.v @@ -292,7 +292,7 @@ fn draw_cube_glsl_i(mut app App){ return } - ws := gg.window_size() + ws := gg.window_size_real_pixels() //ratio := f32(ws.width) / ws.height dw := f32(ws.width / 2) dh := f32(ws.height / 2) @@ -356,7 +356,7 @@ fn draw_start_glsl(app App){ return } - ws := gg.window_size() + ws := gg.window_size_real_pixels() //ratio := f32(ws.width) / ws.height //dw := f32(ws.width / 2) //dh := f32(ws.height / 2) @@ -370,7 +370,7 @@ fn draw_end_glsl(app App){ } fn frame(mut app App) { - ws := gg.window_size() + ws := gg.window_size_real_pixels() // clear mut color_action := C.sg_color_attachment_action{ diff --git a/vlib/gg/gg.v b/vlib/gg/gg.v index 75563f358e..59d90af7d3 100644 --- a/vlib/gg/gg.v +++ b/vlib/gg/gg.v @@ -760,6 +760,11 @@ pub fn window_size() Size { return Size{int(sapp.width() / s), int(sapp.height() / s)} } +// window_size_real_pixels returns the `Size` of the active window without scale +pub fn window_size_real_pixels() Size { + return Size{sapp.width(), sapp.height()} +} + pub fn dpi_scale() f32 { mut s := sapp.dpi_scale() $if android {