remove os/time references from live programs, fix warnings

pull/3029/head
Delyan Angelov 2019-12-09 17:53:17 +02:00 committed by Alexander Medvednikov
parent 8082a5e7f4
commit 32b0225079
6 changed files with 52 additions and 34 deletions

View File

@ -1,6 +1,5 @@
module main module main
import time
import gg import gg
import glfw import glfw
import gx import gx
@ -50,9 +49,7 @@ fn main() {
gg.post_empty_event() // needed so the animation does not stop gg.post_empty_event() // needed so the animation does not stop
/////////////////////////////////////////////// ///////////////////////////////////////////////
a.update() a.update()
print_automaton(a) print_automaton(a)
graphics.render() graphics.render()
time.sleep_ms(1) // TODO: remove this when live reload depence on the time module is fixed
} }
} }

View File

@ -31,6 +31,8 @@ fn main() {
dy: 2 dy: 2
height: height height: height
width: width width: width
main_wnd: 0
draw_fn: 0
} }
window := glfw.create_window(glfw.WinCfg { window := glfw.create_window(glfw.WinCfg {
width: width width: width
@ -49,6 +51,7 @@ fn main() {
height: height height: height
font_size: 20 font_size: 20
use_ortho: true use_ortho: true
window_user_ptr: 0
}) })
println('Starting the game loop...') println('Starting the game loop...')
go game.run() go game.run()
@ -63,26 +66,39 @@ fn main() {
const ( const (
width = 50 width = 50
red = gx.rgb(255,0,0)
green = gx.rgb(0,255,0)
blue = gx.rgb(0,0,255)
) )
// Try uncommenting or changing the lines inside the live functions.
// Guess what will happen:
[live] [live]
fn (game &Game) draw() { fn (game &Game) draw() {
game.gg.draw_rect(game.x, game.y, width, width, gx.rgb(255, 0, 0)) game.gg.draw_rect(game.x, game.y, width, width, blue)
// game.gg.draw_rect(game.x, game.y, width, width, gx.rgb(128,10,255))
}
[live]
fn (game mut Game) update_model() {
// game.x = 0 game.y = 0 game.dx = 1 game.dy = 1
// game.dx = 3 game.dy = 3
speed := 2
game.x += speed * game.dx
game.y += speed * game.dy
if game.y >= game.height - width || game.y <= 0 {
game.dy = - game.dy
}
if game.x >= game.width - width || game.x <= 0 {
game.dx = - game.dx
}
} }
fn (game mut Game) run() { fn (game mut Game) run() {
for { for {
game.x += game.dx game.update_model()
game.y += game.dy glfw.post_empty_event() // Refresh
if game.y >= game.height - width || game.y <= 0 {
game.dy = - game.dy
}
if game.x >= game.width - width || game.x <= 0 {
game.dx = - game.dx
}
// Refresh
time.sleep_ms(17) time.sleep_ms(17)
glfw.post_empty_event()
} }
} }

View File

@ -4,12 +4,12 @@ import gx
import gg import gg
import time import time
import glfw import glfw
// import math import math
import os
const ( const (
Size = 700 Size = 700
Scale = 50.0 Scale = 50.0
pi = math.pi
) )
struct Context { struct Context {
@ -17,7 +17,6 @@ struct Context {
} }
fn main() { fn main() {
os.clear()
glfw.init_glfw() glfw.init_glfw()
ctx:= &Context{ ctx:= &Context{
gg: gg.new_context(gg.Cfg { gg: gg.new_context(gg.Cfg {
@ -40,23 +39,31 @@ fn main() {
[live] [live]
fn (ctx &Context) draw() { fn (ctx &Context) draw() {
ctx.gg.draw_line(0, Size / 2, Size, Size / 2) // x axis
ctx.gg.draw_line(Size / 2, 0, Size / 2, Size) // y axis
center := f64(Size / 2) center := f64(Size / 2)
ctx.gg.draw_line(0, center, Size, center) // x axis
ctx.gg.draw_line(center, 0, center, Size) // y axis
atime := f64( time.ticks() / 10 )
stime := math.sin( 2.0 * pi * f64( time.ticks() % 6000 ) / 6000 )
mut y := 0.0 mut y := 0.0
for x := -10.0; x <= 10.0; x += 0.002 { y = 1.0
y = x * x - 1 for x := -10.0; x <= 10.0; x += 0.02 {
//y = (x + 3) * (x + 3) - 1 //y = x*x + 2
//y = math.sqrt(30.0 - x * x) y = x*x + stime*stime
ctx.gg.draw_rect(center + x * Scale, center - y * Scale, 1, 1, gx.Black) //y = stime
//ctx.gg.draw_rect(center + x * Scale, center + y * Scale, 1, 1, gx.Black) //y = stime * x
y = stime*1.0*math.sin(x + stime+atime/50) * x
//y = (stime * x) * x + stime
//y = (x + 3) * (x + 3) / stime + stime*2.5
//y = math.sqrt(30.0 - x * x) * stime
//y -= (stime-0.5) + stime
ctx.gg.draw_rect(center + x * Scale, center - y * Scale, 1, 1, gx.Blue)
ctx.gg.draw_rect(center + x * Scale, center + y * Scale, 1, 1, gx.Red)
} }
} }
fn update() { fn update() {
for { for {
gg.post_empty_event() gg.post_empty_event()
time.sleep_ms(300) time.sleep_ms(16) // 60 fps
} }
} }

View File

@ -2,7 +2,6 @@
// v -live message.v // v -live message.v
module main module main
import os
import time import time
[live] [live]
@ -11,7 +10,6 @@ fn print_message() {
} }
fn main() { fn main() {
os.clear()
for { for {
print_message() print_message()
time.sleep_ms(500) time.sleep_ms(500)

View File

@ -277,7 +277,7 @@ fn todo_remove_me(cfg Cfg, scale int) {
} }
width := cfg.width * scale width := cfg.width * scale
height := cfg.height * scale height := cfg.height * scale
font_size := cfg.font_size * scale //font_size := cfg.font_size * scale
gl.enable(C.GL_BLEND) gl.enable(C.GL_BLEND)
//# glBlendFunc(C.GL_SRC_ALPHA, GL_ONE_MINUS_SRC_ALPHA); //# glBlendFunc(C.GL_SRC_ALPHA, GL_ONE_MINUS_SRC_ALPHA);
shader := gl.new_shader('text') shader := gl.new_shader('text')

View File

@ -272,8 +272,8 @@ pub fn identity3() []f32 {
// https://github.com/toji/gl-matrix/blob/1549cf21dfa14a2bc845993485343d519cf064fe/src/gl-matrix/mat4.js // https://github.com/toji/gl-matrix/blob/1549cf21dfa14a2bc845993485343d519cf064fe/src/gl-matrix/mat4.js
fn ortho_js(left, right, bottom, top f32) &f32 { fn ortho_js(left, right, bottom, top f32) &f32 {
mynear := 1 // mynear := 1
myfar := 1 // myfar := 1
lr := 1.0 / (left - right) lr := 1.0 / (left - right)
bt := 1.0 / (bottom - top) bt := 1.0 / (bottom - top)
nf := 1.0 / 1.0// (mynear -myfar) nf := 1.0 / 1.0// (mynear -myfar)