.{Vec2} := @use("../../../../libraries/stn/src/lib.hb").math; .{random} := @use("../../../../libraries/stn/src/lib.hb") render := @use("../../../../libraries/render/src/lib.hb") /* expected result: the square example bounces around the screen */ example := fn(): void { screen := render.init(true) image := render.new_surface(screen.width / 3, screen.height / 3) vel := Vec2(int).(-1, -1) pos := Vec2(int).(100, 100) side := image.width / 8 vel_inner := Vec2(int).(1, 1) pos_inner := Vec2(int).((image.width - side) / 2, (image.height - side) / 2) // workaround for compiler bug color := render.Color.(0, 0, 0, 0) color = random.range(render.Color, render.black, render.white) target_color := color loop { render.clear(screen, render.black) // color += .(1, 1, 1, 1) render.put_filled_rect(image, pos_inner, .(side, side), color) render.put_rect(image, pos_inner, .(side, side), render.black) render.put_rect(image, .(0, 0), .(image.width - 1, image.height - 1), color) render.put_surface(screen, image, pos, false) render.put_rect(image, pos_inner, .(side, side), color) render.sync(screen) if pos_inner.x == 0 | pos_inner.x == image.width - side { vel_inner.x = -vel_inner.x target_color = random.range(render.Color, render.black, render.white) } if pos_inner.y == 0 | pos_inner.y == image.height - side { vel_inner.y = -vel_inner.y target_color = random.range(render.Color, render.black, render.white) } if pos.x == 0 | pos.x == screen.width - image.width { vel.x = -vel.x } if pos.y == 0 | pos.y == screen.height - image.height { vel.y = -vel.y } color += .( @intcast(color.b < target_color.b) - @intcast(color.b > target_color.b), @intcast(color.g < target_color.g) - @intcast(color.g > target_color.g), @intcast(color.r < target_color.r) - @intcast(color.r > target_color.r), 0, ) pos += vel pos_inner += vel_inner } return }