clang-format on /apps/demos/bunnymark files
This commit is contained in:
parent
78034b69f5
commit
5c91423fbb
@ -180,7 +180,7 @@ function(give_options_without_warnings target)
|
||||
-Bsymbolic-functions
|
||||
-Wl,--hash-style=gnu)
|
||||
|
||||
target_compile_definitions(${target} PUBLIC
|
||||
target_compile_definitions(${target} PRIVATE
|
||||
$<$<BOOL:${TWN_FEATURE_DYNLIB_GAME}>:TWN_FEATURE_DYNLIB_GAME>)
|
||||
endfunction()
|
||||
|
||||
|
@ -6,108 +6,105 @@
|
||||
#include <stdio.h>
|
||||
#include <stdlib.h>
|
||||
|
||||
#define GRAY ((Color){ 130,130,130,255 })
|
||||
#define BLACK ((Color){ 0,0,0,255 })
|
||||
#define GRAY ((Color){130, 130, 130, 255})
|
||||
#define BLACK ((Color){0, 0, 0, 255})
|
||||
|
||||
#define LEFT_CLICK_ADD 20
|
||||
#define RIGHT_CLICK_ADD 500
|
||||
|
||||
|
||||
void handle_input(void){
|
||||
|
||||
void handle_input(void)
|
||||
{
|
||||
State *state = ctx.udata;
|
||||
if(ctx.input.mouse_state == 1 && ctx.input.mouse_window_position.y > 60){ // Left click
|
||||
if (ctx.input.mouse_state == 1 && ctx.input.mouse_window_position.y > 60)
|
||||
{ // Left click
|
||||
for (int i = 0; i < LEFT_CLICK_ADD; i++)
|
||||
{
|
||||
if (state->bunniesCount < MAX_BUNNIES)
|
||||
{
|
||||
if (state->bunniesCount < MAX_BUNNIES)
|
||||
{
|
||||
state->bunnies[state->bunniesCount].position = (Vec2){
|
||||
(float)ctx.input.mouse_window_position.x,
|
||||
(float)ctx.input.mouse_window_position.y
|
||||
};
|
||||
state->bunnies[state->bunniesCount].speed.x = (float)(rand() % 500 - 250) / 60.0;
|
||||
state->bunnies[state->bunniesCount].speed.y = (float)(rand() % 500 - 250) / 60.0;
|
||||
state->bunnies[state->bunniesCount].color = (Color){
|
||||
rand() % 190 + 50,
|
||||
rand() % 160 + 80,
|
||||
rand() % 140 + 100,
|
||||
255
|
||||
};
|
||||
state->bunniesCount++;
|
||||
}
|
||||
state->bunnies[state->bunniesCount].position =
|
||||
(Vec2){(float)ctx.input.mouse_window_position.x, (float)ctx.input.mouse_window_position.y};
|
||||
state->bunnies[state->bunniesCount].speed.x = (float)(rand() % 500 - 250) / 60.0;
|
||||
state->bunnies[state->bunniesCount].speed.y = (float)(rand() % 500 - 250) / 60.0;
|
||||
state->bunnies[state->bunniesCount].color =
|
||||
(Color){rand() % 190 + 50, rand() % 160 + 80, rand() % 140 + 100, 255};
|
||||
state->bunniesCount++;
|
||||
}
|
||||
}
|
||||
}
|
||||
if(ctx.input.mouse_state == 4){ // Right click
|
||||
|
||||
if (ctx.input.mouse_state == 4)
|
||||
{ // Right click
|
||||
for (int i = 0; i < RIGHT_CLICK_ADD; i++)
|
||||
{
|
||||
if (state->bunniesCount < MAX_BUNNIES)
|
||||
{
|
||||
if (state->bunniesCount < MAX_BUNNIES)
|
||||
{
|
||||
state->bunnies[state->bunniesCount].position = (Vec2){
|
||||
(float)ctx.input.mouse_window_position.x,
|
||||
(float)ctx.input.mouse_window_position.y
|
||||
};
|
||||
state->bunnies[state->bunniesCount].speed.x = (float)(rand() % 500 - 250) / 60.0;
|
||||
state->bunnies[state->bunniesCount].speed.y = (float)(rand() % 500 - 250) / 60.0;
|
||||
state->bunnies[state->bunniesCount].color = (Color){
|
||||
rand() % 190 + 50,
|
||||
rand() % 160 + 80,
|
||||
rand() % 140 + 100,
|
||||
255
|
||||
};
|
||||
state->bunniesCount++;
|
||||
}
|
||||
state->bunnies[state->bunniesCount].position =
|
||||
(Vec2){(float)ctx.input.mouse_window_position.x, (float)ctx.input.mouse_window_position.y};
|
||||
state->bunnies[state->bunniesCount].speed.x = (float)(rand() % 500 - 250) / 60.0;
|
||||
state->bunnies[state->bunniesCount].speed.y = (float)(rand() % 500 - 250) / 60.0;
|
||||
state->bunnies[state->bunniesCount].color =
|
||||
(Color){rand() % 190 + 50, rand() % 160 + 80, rand() % 140 + 100, 255};
|
||||
state->bunniesCount++;
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
void game_tick(void) {
|
||||
void game_tick(void)
|
||||
{
|
||||
static char bunny_count_text[64];
|
||||
static char bunny_path[64] = "wabbit_alpha.png";
|
||||
|
||||
// State *state = ctx.udata;
|
||||
if (ctx.initialization_needed) { // First tick, initalizing data
|
||||
if (ctx.initialization_needed)
|
||||
{ // First tick, initalizing data
|
||||
// Allocating State struct to store data there
|
||||
if (!ctx.udata) ctx.udata = ccalloc(1, sizeof(State));
|
||||
if (!ctx.udata)
|
||||
ctx.udata = ccalloc(1, sizeof(State));
|
||||
((State *)ctx.udata)->bunniesCount = 0;
|
||||
}
|
||||
|
||||
State *state = ctx.udata;
|
||||
|
||||
const double delta = (double)(ctx.delta_time) / 1000.0; // Receiving floating point delta value (diving by 1000 based on vibe)
|
||||
const double delta =
|
||||
(double)(ctx.delta_time) / 1000.0; // Receiving floating point delta value (diving by 1000 based on vibe)
|
||||
|
||||
for (int i = 0; i < state->bunniesCount; i++){
|
||||
state->bunnies[i].position.x += state->bunnies[i].speed.x;
|
||||
state->bunnies[i].position.y += state->bunnies[i].speed.y;
|
||||
for (int i = 0; i < state->bunniesCount; i++)
|
||||
{
|
||||
state->bunnies[i].position.x += state->bunnies[i].speed.x;
|
||||
state->bunnies[i].position.y += state->bunnies[i].speed.y;
|
||||
|
||||
if (((state->bunnies[i].position.x + BUNNY_W/2) > ctx.window_w) ||
|
||||
((state->bunnies[i].position.x + BUNNY_W/2) < 0)) state->bunnies[i].speed.x *= -1;
|
||||
if (((state->bunnies[i].position.y + BUNNY_H/2) > ctx.window_h) ||
|
||||
((state->bunnies[i].position.y + BUNNY_H/2 - 60) < 0)) state->bunnies[i].speed.y *= -1;
|
||||
if (((state->bunnies[i].position.x + BUNNY_W / 2) > ctx.window_w) ||
|
||||
((state->bunnies[i].position.x + BUNNY_W / 2) < 0))
|
||||
state->bunnies[i].speed.x *= -1;
|
||||
if (((state->bunnies[i].position.y + BUNNY_H / 2) > ctx.window_h) ||
|
||||
((state->bunnies[i].position.y + BUNNY_H / 2 - 60) < 0))
|
||||
state->bunnies[i].speed.y *= -1;
|
||||
}
|
||||
|
||||
handle_input();
|
||||
|
||||
// Clear window with Gray color (set the background color this way)
|
||||
draw_rectangle((Rect){0,0, ctx.window_w, ctx.window_h}, GRAY);
|
||||
draw_rectangle((Rect){0, 0, ctx.window_w, ctx.window_h}, GRAY);
|
||||
|
||||
for (int i = 0; i < state->bunniesCount; i++){ // Draw each bunny based on their position and color, also scale accordingly
|
||||
m_sprite(
|
||||
m_set(path, bunny_path),
|
||||
m_set(rect, ((Rect){ .x = (int)state->bunnies[i].position.x, .y = (int)state->bunnies[i].position.y,
|
||||
.w = BUNNY_W * SPRITE_SCALE, .h = BUNNY_H * SPRITE_SCALE
|
||||
})),
|
||||
m_opt(color, (state->bunnies[i].color)),
|
||||
m_opt(stretch, true),
|
||||
);
|
||||
for (int i = 0; i < state->bunniesCount; i++)
|
||||
{ // Draw each bunny based on their position and color, also scale accordingly
|
||||
m_sprite(m_set(path, bunny_path),
|
||||
m_set(rect, ((Rect){.x = (int)state->bunnies[i].position.x,
|
||||
.y = (int)state->bunnies[i].position.y,
|
||||
.w = BUNNY_W * SPRITE_SCALE,
|
||||
.h = BUNNY_H * SPRITE_SCALE})),
|
||||
m_opt(color, (state->bunnies[i].color)), m_opt(stretch, true), );
|
||||
}
|
||||
// Formatting text to display, might want to add FPS here too
|
||||
snprintf(bunny_count_text, 64, "Bunnies: %d", state->bunniesCount);
|
||||
|
||||
draw_text(bunny_count_text, (Vec2){ 0, 0 }, 40, BLACK, "/fonts/kenney-pixel.ttf");
|
||||
draw_text(bunny_count_text, (Vec2){0, 0}, 40, BLACK, "/fonts/kenney-pixel.ttf");
|
||||
}
|
||||
|
||||
|
||||
void game_end(void) {
|
||||
void game_end(void)
|
||||
{
|
||||
State *state = ctx.udata;
|
||||
|
||||
// Free state when game ends
|
||||
|
@ -3,23 +3,23 @@
|
||||
|
||||
#include "twn_game_api.h"
|
||||
|
||||
#define MAX_BUNNIES 50000 // 50K bunnies limit
|
||||
#define MAX_BUNNIES 100000 // 100K bunnies limit
|
||||
#define BUNNY_W 26
|
||||
#define BUNNY_H 37
|
||||
#define SPRITE_SCALE 1
|
||||
|
||||
typedef struct Bunny {
|
||||
typedef struct Bunny
|
||||
{
|
||||
Vec2 position;
|
||||
Vec2 speed;
|
||||
Color color;
|
||||
} Bunny;
|
||||
|
||||
typedef struct State {
|
||||
typedef struct State
|
||||
{
|
||||
Bunny bunnies[MAX_BUNNIES];
|
||||
int bunniesCount;
|
||||
InputState mouse_state;
|
||||
} State;
|
||||
|
||||
|
||||
|
||||
#endif
|
||||
|
@ -44,8 +44,8 @@ typedef struct ActionHashItem {
|
||||
} ActionHashItem;
|
||||
|
||||
|
||||
/* TODO: don't assume SDL button mask */
|
||||
typedef struct InputState {
|
||||
const uint8_t *keyboard_state; /* array of booleans indexed by scancode */
|
||||
uint32_t mouse_state; /* SDL mouse button bitmask */
|
||||
Vec2i mouse_window_position;
|
||||
Vec2i mouse_relative_position;
|
||||
@ -54,6 +54,7 @@ typedef struct InputState {
|
||||
|
||||
/* engine state */
|
||||
ActionHashItem *action_hash;
|
||||
const uint8_t *keyboard_state; /* array of booleans indexed by scancode */
|
||||
} InputState;
|
||||
|
||||
|
||||
|
@ -245,6 +245,8 @@ void use_texture_mode(TextureMode mode) {
|
||||
VertexBufferBuilder build_vertex_buffer(VertexBuffer buffer, size_t bytes) {
|
||||
glBindBuffer(GL_ARRAY_BUFFER, buffer);
|
||||
glBufferData(GL_ARRAY_BUFFER, bytes, NULL, GL_STREAM_DRAW);
|
||||
if (bytes == 0)
|
||||
SDL_TriggerBreakpoint();
|
||||
void *mapping = glMapBuffer(GL_ARRAY_BUFFER, GL_WRITE_ONLY);
|
||||
if (!mapping)
|
||||
CRY("build_vertex_buffer", "Error mapping a vertex array buffer");
|
||||
@ -282,7 +284,6 @@ void finally_render_sprites(const Primitive2D primitives[],
|
||||
{
|
||||
/* TODO: maybe do, dunno */
|
||||
// glBindBuffer(GL_VERTEX_ARRAY, vertex_buffer);
|
||||
(void)buffer;
|
||||
|
||||
GLsizei off;
|
||||
GLsizei voff;
|
||||
|
@ -70,7 +70,6 @@ void clear_draw_buffer(void) {
|
||||
(1.0f / 255) * 230,
|
||||
(1.0f / 255) * 230, 1);
|
||||
|
||||
/* TODO: don't clear color when skybox is applied? */
|
||||
glClear(GL_COLOR_BUFFER_BIT |
|
||||
GL_DEPTH_BUFFER_BIT |
|
||||
GL_STENCIL_BUFFER_BIT);
|
||||
|
@ -138,6 +138,7 @@ void render_sprites(const Primitive2D primitives[],
|
||||
const size_t cur = batch.mode == TEXTURE_MODE_GHOSTLY ? i : batch.size - i - 1;
|
||||
const SpritePrimitive sprite = primitives[cur].sprite;
|
||||
|
||||
/* TODO: try caching it */
|
||||
const Rect srcrect =
|
||||
textures_get_srcrect(&ctx.texture_cache, primitives[cur].sprite.texture_key);
|
||||
|
||||
|
Loading…
Reference in New Issue
Block a user