package karl2d_minimal_example import k2 "../.." import "core:mem" import "core:log" import "core:fmt" _ :: fmt _ :: mem main :: proc() { context.logger = log.create_console_logger() when ODIN_DEBUG { track: mem.Tracking_Allocator mem.tracking_allocator_init(&track, context.allocator) context.allocator = mem.tracking_allocator(&track) defer { if len(track.allocation_map) > 0 { for _, entry in track.allocation_map { fmt.eprintf("%v leaked: %v bytes\n", entry.location, entry.size) } } mem.tracking_allocator_destroy(&track) } } k2.init(1080, 1080, "Karl2D Render Texture Example") k2.set_window_position(300, 100) render_texture := k2.create_render_texture(128, 128) for !k2.shutdown_wanted() { k2.process_events() k2.set_render_texture(render_texture) k2.clear(k2.BLUE) k2.draw_rect({1, 1, 12, 12}, k2.GREEN) k2.draw_rect({2, 2, 10, 10}, k2.BLACK) k2.draw_circle({20, 7}, 6, k2.BLACK) k2.draw_circle({20, 7}, 5, k2.GREEN) k2.draw_text("Hellöpe!", {1, 20}, 20, k2.WHITE) k2.set_render_texture(nil) k2.clear(k2.GRAY) k2.draw_texture_ex(render_texture.texture, {0, 0, 128, 128}, {0, 0, 1080, 1080}, {}, 0, k2.WHITE) k2.draw_texture(render_texture.texture, {400, 20}, k2.WHITE) k2.draw_texture_ex(render_texture.texture, {0, 0, 128, 128}, {512, 512, 512, 512}, {}, 70, k2.WHITE) k2.present() free_all(context.temp_allocator) } k2.destroy_render_texture(render_texture) k2.shutdown() }