summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorkitty piapiac <kcp@bsd.computer>2023-04-21 23:50:06 -0700
committerkitty piapiac <kcp@bsd.computer>2023-04-21 23:50:06 -0700
commit8f38659932677a2b0e00b7f4abda54ac76a8ecd9 (patch)
tree705767e858a3fe0c89b7b4bc0440012a084c6921
parent599cde356b576759475d34dbfadb5548926c089d (diff)
SRS-style rotation skeleton
-rw-r--r--.gitmodules3
-rw-r--r--Makefile11
-rw-r--r--core.c75
m---------dep/cglm0
-rw-r--r--graph.c22
-rw-r--r--include/core.h6
-rw-r--r--include/graph.h1
-rw-r--r--include/input.h11
-rw-r--r--input.c42
-rw-r--r--mino.c10
-rw-r--r--scene-title.c51
-rw-r--r--scenes.c25
12 files changed, 168 insertions, 89 deletions
diff --git a/.gitmodules b/.gitmodules
index 1bbb38a..8ac074e 100644
--- a/.gitmodules
+++ b/.gitmodules
@@ -1,3 +1,6 @@
[submodule "include/stb"]
path = include/stb
url = https://github.com/nothings/stb
+[submodule "dep/cglm"]
+ path = dep/cglm
+ url = https://github.com/recp/cglm
diff --git a/Makefile b/Makefile
index ea2ca2a..6875c69 100644
--- a/Makefile
+++ b/Makefile
@@ -1,16 +1,17 @@
.POSIX:
CC := clang
-CFLAGS := -std=c11 -g -O0 -Wall -Wextra -Wshadow -Iinclude $(shell sdl2-config --cflags) $(shell pkg-config --cflags cglm)
+CFLAGS := -std=c11 -g -O0 -Wall -Wextra -Wshadow -Iinclude -Idep/cglm/include $(shell sdl2-config --cflags)
LDFLAGS :=
-LDLIBS := -ldl -lm $(shell sdl2-config --libs) $(shell pkg-config --libs cglm)
+LDLIBS := -ldl -lm $(shell sdl2-config --libs)
all: mino
-mino: glad.o tex.o graph.o input.o scene.o scene-title.o mino.o
+mino: glad.o tex.o graph.o input.o scene.o scenes.o core.o mino.o
mino.o: mino.c include/mino.h
+core.o: core.c include/core.h
scene.o: scene.c include/scene.h
-scene-title.o: scene-title.c
+scenes.o: scenes.c
input.o: input.c include/input.h
graph.o: graph.c include/graph.h
tex.o: tex.c include/tex.h
glad.o: glad.c include/glad/glad.h
clean:
- rm -rf mino mino.o scene-title.o scene.o input.o graph.o tex.o glad.o
+ rm -rf mino mino.o core.o scenes.o scene.o input.o graph.o tex.o glad.o
diff --git a/core.c b/core.c
new file mode 100644
index 0000000..2a90b16
--- /dev/null
+++ b/core.c
@@ -0,0 +1,75 @@
+#include<string.h>
+#include<cglm/cglm.h>
+#include"mino.h"
+#include"graph.h"
+#include"input.h"
+#include"core.h"
+
+#define GRID_W 10
+#define GRID_H 16
+_ mat4 proj;
+_ S8 grid[GRID_H][GRID_W]={0};/*indexes into tetros,-1 for nothing*/
+_ Tetro tetros[]={
+ {0,{0,0},{1.5,1.5}, {{0,1},{1,1},{2,1},{3,1}}},
+ {1,{0,0},{1,1}, {{0,0},{0,1},{1,1},{2,1}}},
+ {2,{0,0},{1,1}, {{2,0},{0,1},{1,1},{2,1}}},
+ {3,{0,0},{1,1}, {{1,0},{0,1},{1,1},{2,1}}},
+ {4,{0,0},{1,1}, {{1,0},{2,0},{0,1},{1,1}}},
+ {5,{0,0},{1,1}, {{0,0},{1,0},{1,1},{2,1}}},
+ {6,{0,0},{0.5,0.5}, {{0,0},{1,0},{0,1},{1,1}}}};
+_ C tetros_c[]="IJLTSZO";
+_ vec3 tetros_col[]={{0,1,1},{0,0,1},{1,0.5,0},{1,0,1},{1,0,0},{0,1,0},{1,1,0}};
+
+_ U32 shader_tetro;
+_ IM C shader_tetro_vert[]=GRAPH_GLSL(
+ layout (location=0) in vec3 pos;
+ uniform mat4 proj;
+ uniform mat4 model;
+ void main(){gl_Position=proj*model*vec4(pos,1);});
+_ IM C shader_tetro_frag[]=GRAPH_GLSL(
+ out vec4 Frag;
+ uniform vec3 col;
+ void main(){Frag=vec4(col,1);});
+_ V shader_tetro_init(V){
+ shader_tetro=graph_shader_create(shader_tetro_vert,shader_tetro_frag),
+ graph_shader_use(shader_tetro),
+ graph_shader_setM4("proj",proj),
+ graph_shader_setV3("col",(vec3){1,1,1});}
+
+_ V tetro_copy(Tetro*d,Tetro*s){*d=*s;}
+_ V tetro_trans(Tetro*t,vec2 m){
+ glm_vec2_add(t->pos,m,t->pos);}
+_ V tetro_rot(Tetro*t,S8 c){U8 i;vec2 a;
+ for(i=0;i<4;++i){
+ glm_vec2_sub(t->org,t->v[i],a),
+ glm_vec2_rotate(a,GLM_PI_2*(2-c),a),
+ glm_vec2_add(a,t->org,a),
+ glm_vec2_copy(a,t->v[i]);}}
+
+_ V tetro_draw(Tetro t){U8 i;vec2 a;vec2 z={32,32};
+ graph_shader_use(shader_tetro),
+ graph_shader_setM4("proj",proj),
+ graph_shader_setV3("col",tetros_col[t.i]);
+ for(i=0;i<4;++i){
+ glm_vec2_mul(t.v[i],z,a),
+ glm_vec2_add(t.pos,a,a),
+ graph_quad(a,z);}}
+
+_ Tetro held;
+V core_init(V){
+ glm_ortho(0,graph_win_w,0,graph_win_h,0,4,proj),
+ shader_tetro_init(),
+ memset(grid,-1,GRID_W*GRID_H);
+ held=tetros[3];}
+
+V core_tick(InputPoint p,InputButtons b){
+ glm_ortho(0,graph_win_w,0,graph_win_h,0,4,proj);
+ tetro_draw(held);
+ Q(IB_Z&b.p,tetro_rot(&held, 1))
+ Q(IB_X&b.p,tetro_rot(&held,-1))
+ Q(IB_C&b.p,held=tetros[(held.i+1)%7])
+ Q(IB_L&b.p,tetro_trans(&held,(vec2){-32, 0}))
+ Q(IB_R&b.p,tetro_trans(&held,(vec2){ 32, 0}))
+ Q(IB_U&b.p,tetro_trans(&held,(vec2){ 0, 32}))
+ Q(IB_D&b.p,tetro_trans(&held,(vec2){ 0,-32}))
+}
diff --git a/dep/cglm b/dep/cglm
new file mode 160000
+Subproject 13036036c4e5caa5c2236dee2fb1f518d9a534b
diff --git a/graph.c b/graph.c
index 78965fd..05c22bf 100644
--- a/graph.c
+++ b/graph.c
@@ -15,7 +15,7 @@ _ SDL_Window*win;
_ SDL_GLContext ctx;
_ V on_err(IM C*d){die("Could not %s: %s",d,SDL_GetError());}
-_ V q_init(V);
+_ V q_init(V);_ V q_deinit(V);
V graph_init(V){SDL_version sdl_vh,sdl_vl;
Q(SDL_Init(SDL_INIT_VIDEO),on_err("init sdl2"))
SDL_GL_SetAttribute(SDL_GL_CONTEXT_MAJOR_VERSION,3),
@@ -46,7 +46,7 @@ V graph_events(V){SDL_Event ev;U32 t;WH(SDL_PollEvent(&ev),t=ev.type;
||SDL_WINDOWEVENT_SIZE_CHANGED==ew.event,graph_win_w=ew.data1,graph_win_h=ew.data2,
glViewport(0,0,ew.data1,ew.data2))))}
-V graph_deinit(V){SDL_GL_DeleteContext(ctx),SDL_DestroyWindow(win),SDL_Quit();}
+V graph_deinit(V){q_deinit(),SDL_GL_DeleteContext(ctx),SDL_DestroyWindow(win),SDL_Quit();}
V graph_before(V){glClearColor(1.0,0.75,0.8,1.0),glClear(GL_COLOR_BUFFER_BIT);}
V graph_after(V){SDL_GL_SwapWindow(win);}
@@ -54,12 +54,10 @@ U32 graph_ticks(V){R SDL_GetTicks();}
_ U32 q_vao,q_vbo,q_ebo;
_ V q_init(V){
- _ IM F32 verts[]={
- /*positions*/ /*colours*/ /*texture*/
- 0.5, 0.5,0.0, 1.0,0.0,0.0, 1.0,1.0,
- 0.5,-0.5,0.0, 0.0,1.0,0.0, 1.0,0.0,
- -0.5,-0.5,0.0, 1.0,0.0,1.0, 0.0,0.0,
- -0.5, 0.5,0.0, 0.0,0.0,0.0, 0.0,1.0};
+ _ IM F32 verts[]={1,1,0, 1,1,
+ 1,0,0, 1,0,
+ 0,0,0, 0,0,
+ 0,1,0, 0,1};
_ IM U32 indxs[]={0,1,3,1,2,3};
glGenVertexArrays(1,&q_vao),glGenBuffers(1,&q_vbo),glGenBuffers(1,&q_ebo);
glBindVertexArray(q_vao),
@@ -67,13 +65,12 @@ _ V q_init(V){
glBufferData(GL_ARRAY_BUFFER,SZ verts,verts,GL_STATIC_DRAW),
glBindBuffer(GL_ELEMENT_ARRAY_BUFFER,q_ebo),
glBufferData(GL_ELEMENT_ARRAY_BUFFER,SZ indxs,indxs,GL_STATIC_DRAW);
- glVertexAttribPointer(0,3,GL_FLOAT,GL_FALSE,8*SZ(F32),(V*)(0*SZ(F32))),
+ glVertexAttribPointer(0,3,GL_FLOAT,GL_FALSE,5*SZ(F32),(V*)(0*SZ(F32))),
glEnableVertexAttribArray(0),
- glVertexAttribPointer(1,3,GL_FLOAT,GL_FALSE,8*SZ(F32),(V*)(3*SZ(F32))),
+ glVertexAttribPointer(1,2,GL_FLOAT,GL_FALSE,5*SZ(F32),(V*)(3*SZ(F32))),
glEnableVertexAttribArray(1),
- glVertexAttribPointer(2,2,GL_FLOAT,GL_FALSE,8*SZ(F32),(V*)(6*SZ(F32))),
- glEnableVertexAttribArray(2),
glBindVertexArray(0);}
+_ V q_deinit(V){glDeleteBuffers(1,&q_vao),glDeleteBuffers(1,&q_vbo),glDeleteBuffers(1,&q_ebo);}
V graph_quad_xywh(F32 x,F32 y,F32 w,F32 h){graph_quad((vec2){x,y},(vec2){w,h});}
V graph_quad(vec2 p,vec2 z){mat4 trans;
glm_mat4_identity(trans),
@@ -96,6 +93,7 @@ U32 graph_shader_create(IM C*vert,IM C*frag){I ok;C info[512];U32 v,f,p;
V graph_shader_use(U32 s){glUseProgram(s);}
V graph_shader_setI(IM C*s,I i) {I p;glGetIntegerv(GL_CURRENT_PROGRAM,&p),glUniform1i(glGetUniformLocation(p,s),i);}
+V graph_shader_setV3(IM C*s,vec3 v3){I p;glGetIntegerv(GL_CURRENT_PROGRAM,&p),glUniform3f(glGetUniformLocation(p,s),v3[0],v3[1],v3[2]);}
V graph_shader_setM4(IM C*s,mat4 m4){I p;glGetIntegerv(GL_CURRENT_PROGRAM,&p),glUniformMatrix4fv(glGetUniformLocation(p,s),1,GL_FALSE,&m4[0][0]);}
U32 graph_tex_create(IM C*f){Tex tex;U32 t;
diff --git a/include/core.h b/include/core.h
new file mode 100644
index 0000000..cc9ef1c
--- /dev/null
+++ b/include/core.h
@@ -0,0 +1,6 @@
+#ifndef MINO_CORE_H
+#define MINO_CORE_H
+typedef struct{U8 i;vec2 pos,org,v[4];}Tetro;
+X V core_init(V);
+X V core_tick(InputPoint,InputButtons);
+#endif
diff --git a/include/graph.h b/include/graph.h
index f04bfb5..ff2ab8a 100644
--- a/include/graph.h
+++ b/include/graph.h
@@ -17,6 +17,7 @@ X U32 graph_shader_create(IM C*,IM C*);
X U32 graph_shader_tex;
X V graph_shader_use(U32);
X V graph_shader_setI(IM C*,I);
+X V graph_shader_setV3(IM C*,vec3);
X V graph_shader_setM4(IM C*,mat4);
X U32 graph_tex_create(IM C*);
diff --git a/include/input.h b/include/input.h
index 0a54d19..b2a0ea1 100644
--- a/include/input.h
+++ b/include/input.h
@@ -2,8 +2,11 @@
#define MINO_INPUT_H
#include"mino.h"
typedef struct{U32 x,y;}InputPoint;
-typedef struct{U32 f;}InputButtons;
-enum{IB_1=1<<0,IB_2=1<<1,IB_3=1<<2,IB_4=1<<3};
-X InputPoint input_point(V);
-X InputButtons input_buttons(V);
+enum{IB_1=1<<0, IB_2=1<<1, IB_3=1<<2, IB_4=1<<3,
+ IB_L=1<<4, IB_R=1<<5, IB_U=1<<6, IB_D=1<<7,
+ IB_S=1<<8, IB_Z=1<<9, IB_X=1<<10,IB_C=1<<11};
+typedef struct{U32 p,h;}InputButtons;
+X InputPoint input_point;
+X InputButtons input_buttons;
+X V input_update(V);
#endif
diff --git a/input.c b/input.c
index 8248ded..d22e2cb 100644
--- a/input.c
+++ b/input.c
@@ -4,10 +4,38 @@
#include"graph.h"
#include"input.h"
#define SDLBUT(x)SDL_BUTTON(SDL_BUTTON_##x)
-InputPoint input_point(V){InputPoint ip;SDL_GetMouseState((S32*)&ip.x,(S32*)&ip.y);ip.y=graph_win_h-ip.y;R ip;}
-InputButtons input_button(V){InputButtons ib={0};U32 mb;mb=SDL_GetMouseState(0,0);
- Q(SDLBUT(LEFT)&mb, ib.f|=IB_1)
- Q(SDLBUT(MIDDLE)&mb, ib.f|=IB_2)
- Q(SDLBUT(RIGHT)&mb, ib.f|=IB_3)
- Q(SDLBUT(X1)&mb, ib.f|=IB_4)
- R ib;}
+InputPoint input_point;
+InputButtons input_buttons;
+
+_ U32 map_mouse[][2]={
+ {SDLBUT(LEFT), IB_1},
+ {SDLBUT(RIGHT), IB_2},
+ {SDLBUT(MIDDLE),IB_3},
+ {SDLBUT(X1), IB_4}};
+
+_ U32 map_keeb[][2]={
+ {SDL_SCANCODE_LEFT, IB_L},
+ {SDL_SCANCODE_RIGHT, IB_R},
+ {SDL_SCANCODE_UP, IB_U},
+ {SDL_SCANCODE_DOWN, IB_D},
+ {SDL_SCANCODE_SPACE, IB_S},
+ {SDL_SCANCODE_Z, IB_Z},
+ {SDL_SCANCODE_X, IB_X},
+ {SDL_SCANCODE_C, IB_C}};
+
+#define ip input_point
+#define ib input_buttons
+#define mm map_mouse
+#define mk map_keeb
+V input_update(V){U32 mb,mm_len,mk_len,i,kb_len;IM U8*kb;InputButtons nb={0,0};
+ mb=SDL_GetMouseState((S32*)&ip.x,(S32*)&ip.y),ip.y=graph_win_h-ip.y,
+ kb=SDL_GetKeyboardState((S32*)&kb_len),
+ mm_len=(SZ mm)/(SZ mm[0]),
+ mk_len=(SZ mk)/(SZ mk[0]),
+ i=0;WH(i<mm_len,Q(mm[i][0]&mb, Q(mm[i][1]&(ib.p|ib.h),nb.h|=mm[i][1])OR nb.p|=mm[i][1]);++i)
+ i=0;WH(i<mk_len,Q(kb[mk[i][0]],Q(mk[i][1]&(ib.p|ib.h),nb.h|=mk[i][1])OR nb.p|=mk[i][1]);++i)
+ input_buttons=nb;}
+#undef mk
+#undef mm
+#undef ib
+#undef ip
diff --git a/mino.c b/mino.c
index 8d02bc6..72bb981 100644
--- a/mino.c
+++ b/mino.c
@@ -1,18 +1,8 @@
#include<stdio.h>
#include<stdlib.h>
-#include<cglm/affine.h>
-#include<cglm/cglm.h>
#include"mino.h"
-#include"graph.h"
-#include"scene.h"
NR V die(IM C*f,...)VA(f,vfprintf(stderr,f,ap),fputc('\n',stderr),exit(1))
V*make(Uz z){V*p;N(p=malloc(z), die("oom"))R p;}
V*remk(V*p,Uz z){N(p=realloc(p,z),die("oom"))R p;}
V del(V*p){free(p);}
-
-X Scene scene_title;
-I main(I ac,C**av){(V)ac,(V)av;
- graph_init(),atexit(graph_deinit);
- scene_run(&scene_title);
- R 0;}
diff --git a/scene-title.c b/scene-title.c
deleted file mode 100644
index 527c686..0000000
--- a/scene-title.c
+++ /dev/null
@@ -1,51 +0,0 @@
-/*2d title screen*/
-
-#include<cglm/affine.h>
-#include<cglm/cglm.h>
-#include"mino.h"
-#include"graph.h"
-#include"scene.h"
-#include"input.h"
-
-_ mat4 win_proj;
-
-_ U32 shader_tex;
-_ IM C shader_tex_vert[]=GRAPH_GLSL(
- layout (location=0) in vec3 pos;
- layout (location=1) in vec3 col;
- layout (location=2) in vec2 tex;
- out vec3 Col;
- out vec2 Tex;
- uniform mat4 proj;
- uniform mat4 model;
- void main(){gl_Position=proj*model*vec4(pos,1.0);Col=col;Tex=tex;});
-_ IM C shader_tex_frag[]=GRAPH_GLSL(
- out vec4 Frag;
- in vec3 Col;
- in vec2 Tex;
- uniform sampler2D buf;
- void main(){Frag=texture(buf,Tex);});
-_ V shader_tex_init(V){
- shader_tex=graph_shader_create(shader_tex_vert,shader_tex_frag),
- graph_shader_use(shader_tex),
- graph_shader_setM4("proj",win_proj),
- graph_shader_setI("buf",0);}
-
-_ U32 tex_cat;
-_ V title_init(V){
- glm_ortho(0,graph_win_w,0,graph_win_h,0,4,win_proj),
- shader_tex_init();
- tex_cat=graph_tex_create("res/tex/cat.jpg");}
-
-_ V title_loop(V){/*prelude*/graph_before(),graph_events();InputPoint p;
- glm_ortho(0,graph_win_w,0,graph_win_h,0,4,win_proj),
- /*interlude*/
- p=input_point(),
- graph_shader_use(shader_tex),graph_shader_setM4("proj",win_proj),
- graph_tex_use(tex_cat,0),
- graph_quad_xywh(p.x,p.y,256,256),
- /*postlude*/
- graph_after();}
-
-_ Scene*title_run(V){title_init();WH(1,title_loop());R 0;}
-Scene scene_title={"title",title_run};
diff --git a/scenes.c b/scenes.c
new file mode 100644
index 0000000..bb4202e
--- /dev/null
+++ b/scenes.c
@@ -0,0 +1,25 @@
+#include<cglm/affine.h>
+#include<cglm/cglm.h>
+#include"mino.h"
+#include"graph.h"
+#include"scene.h"
+#include"input.h"
+#include"core.h"
+
+_ V game_loop(V){/*prelude*/graph_before(),graph_events();InputPoint p;InputButtons b;
+ /*interlude*/
+ input_update(),p=input_point,b=input_buttons;
+ core_tick(p,b);
+ /*postlude*/
+ graph_after();}
+
+_ Scene*game_run(V){core_init();WH(1,game_loop());R 0;}
+Scene scene_game={"Game",game_run};
+
+_ Scene*title_run(V){R&scene_game;}
+Scene scene_title={"Title",title_run};
+
+I main(I ac,C**av){(V)ac,(V)av;
+ graph_init(),atexit(graph_deinit);
+ scene_run(&scene_title);
+ R 0;}