From d302628e8665572bc515c254a8d52909cc6db2ae Mon Sep 17 00:00:00 2001 From: ubq323 Date: Fri, 22 Mar 2024 19:38:29 +0000 Subject: refactor --- main.ha | 71 ++++++++++++++++++----------------------------------------------- 1 file changed, 19 insertions(+), 52 deletions(-) (limited to 'main.ha') diff --git a/main.ha b/main.ha index 89d197b..ca0c68e 100644 --- a/main.ha +++ b/main.ha @@ -5,6 +5,8 @@ export fn main() void = { sdl2::SDL_Init(sdl2::SDL_INIT_VIDEO)!; defer sdl2::SDL_Quit(); + fmt::println(size(i32), size(i64), size(int), size(size))!; + const win = sdl2::SDL_CreateWindow("hi", sdl2::SDL_WINDOWPOS_UNDEFINED, sdl2::SDL_WINDOWPOS_UNDEFINED, 640, 480, sdl2::SDL_WindowFlags::NONE)!; defer sdl2::SDL_DestroyWindow(win); @@ -21,14 +23,16 @@ export fn main() void = { fmt::println(wsurf.w * wsurf.h)!; fmt::println(sdl2::SDL_GetPixelFormatName(format.format))!; - const pic = picture_from_surface(wsurf); + let dstate = drawing_state { + drawing = false, + pos = (0,0), + picture = picture_from_surface(wsurf) + }; + let quit = false; let n = 0z; let lasttime = sdl2::SDL_GetTicks(); - let drawing = false; - let mousex = 0; - let mousey = 0; for (!quit) { let ev = sdl2::event { ... }; for (sdl2::SDL_PollEvent(&ev)! == 1) switch (ev.event_type) { @@ -38,20 +42,22 @@ export fn main() void = { if (keysym == sdl2::SDL_Keycode::ESCAPE) quit = true; case sdl2::SDL_EventType::MOUSEBUTTONDOWN, sdl2::SDL_EventType::MOUSEBUTTONUP => - const d = ev.button; - mousex = d.x; - mousey = d.y; - if (d.button == 1) - drawing = (d.state == 1); + const edata = ev.button; + dstate.pos = (edata.x, edata.y); + if (edata.button == 1) + dstate.drawing = (edata.state == 1); case sdl2::SDL_EventType::MOUSEMOTION => - const d = ev.motion; - mousex = d.x; - mousey = d.y; + const edata = ev.motion; + dstate.pos = (edata.x, edata.y); case => void; }; + do_drawing(&dstate); - if (drawing) circle(pic, mousex, mousey, 25, 0x00ffff); + + // if (drawing) { + // circle(pic, mousex, mousey, 5, 0x00ffff); + // }; // circle(pic, 100, 100, n:int, 0xff0000); @@ -70,43 +76,4 @@ export fn main() void = { }; }; -def WHITE = 0x556602; -def BLACK = 0x0; - -type picture = struct { - d: []u32, - w: size, - h: size, -}; -fn pidx(pic: picture, x: size, y: size) size = (pic.w*y)+x; -fn pic_set(pic: picture, x: size, y: size, val: u32) void = pic.d[pidx(pic,x,y)] = val; -fn picture_from_surface(surf: *sdl2::SDL_Surface) picture = picture { - w = surf.w: size, - h = surf.h: size, - d = (surf.pixels as *opaque: *[*]u32)[..surf.w*surf.h], -}; - -fn min(a: int, b: int) int = if (a