Compare commits

...

4 Commits

Author SHA1 Message Date
7ef431a9f0 Collision detection 2025-05-26 22:57:02 +02:00
ea539bdf99 Add collision box with parent child relationship 2025-05-26 22:39:05 +02:00
5134bf74b2 32kHz Audio 2025-05-26 22:08:56 +02:00
c15732e865 New basket 2025-05-26 22:03:57 +02:00
5 changed files with 99 additions and 17 deletions

View File

@@ -13,6 +13,10 @@ static constexpr uint8_t FRUITS_DATA[] = {
#embed "assets/images/fruits.bmp"
};
static constexpr uint8_t BASKET_DATA[] = {
#embed "assets/images/basket.bmp"
};
static constexpr uint8_t BACKGROUND_MUSIC_DATA[] = {
#embed "assets/sounds/JamaicanSunrise.wav"
};
@@ -58,11 +62,17 @@ void init_assets(flecs::world &world) {
TextureAtlasLayout fruits_layout = {
.width = 16, .height = 16, .rows = 6, .columns = 38};
auto *basket = load_texture(BASKET_DATA, sizeof(BASKET_DATA), renderer);
TextureAtlasLayout basket_layout = {
.width = 16, .height = 16, .rows = 1, .columns = 1};
world.set<TextureAssets>(TextureAssets{
.background = Texture{.sdl_texture = background,
.texture_atlas_layout = background_layout},
.fruits = Texture{.sdl_texture = fruits,
.texture_atlas_layout = fruits_layout}});
.fruits =
Texture{.sdl_texture = fruits, .texture_atlas_layout = fruits_layout},
.basket = Texture{.sdl_texture = basket,
.texture_atlas_layout = basket_layout}});
auto background_music =
load_audio(BACKGROUND_MUSIC_DATA, sizeof(BACKGROUND_MUSIC_DATA));

View File

@@ -20,6 +20,7 @@ struct Texture {
struct TextureAssets {
Texture background;
Texture fruits;
Texture basket;
};
struct AudioAssets {

BIN
assets/images/basket.bmp Normal file

Binary file not shown.

After

Width:  |  Height:  |  Size: 1.1 KiB

Binary file not shown.

101
main.cpp
View File

@@ -15,6 +15,11 @@
static constexpr int WINDOW_WIDTH = 400;
static constexpr int WINDOW_HEIGHT = 240;
struct WorldPosition {
int x;
int y;
};
struct Position {
int x;
int y;
@@ -71,19 +76,41 @@ int main() {
struct Fruit {};
struct Basket {};
struct CollisionBox {};
world.system<Game>("IncrementTicks")
.term_at(0)
.singleton()
.each([](Game &game_ticks) { game_ticks.ticks += 1; });
world.entity("Basket")
.set<Position>(
Position{.x = WINDOW_WIDTH / 2 - 32, .y = WINDOW_HEIGHT - 32})
.set<Sprite>(Sprite{.texture = &texture_assets->fruits,
.texture_atlas_index = 212})
.set<Size>(Size{.w = 72, .h = 32})
.add<Basket>();
auto basket = world.entity("Basket")
.add<WorldPosition>()
.set<Position>(Position{.x = WINDOW_WIDTH / 2 - 32,
.y = WINDOW_HEIGHT - 32})
.set<Sprite>(Sprite{.texture = &texture_assets->basket,
.texture_atlas_index = 0})
.set<Size>(Size{.w = 64, .h = 32})
.add<Basket>();
world.entity("CollisionBox")
.child_of(basket)
.add<WorldPosition>()
.set<Position>(Position{.x = 0, .y = 0})
.set<Size>(Size{.w = 64, .h = 32})
.add<CollisionBox>();
world
.system<SdlHandles const, WorldPosition const, Size const, CollisionBox>(
"DrawBoxes")
.term_at(0)
.singleton()
.each([](SdlHandles const &sdl_handles, WorldPosition const &pos,
Size const &size, CollisionBox) {
SDL_FRect rect{static_cast<float>(pos.x), static_cast<float>(pos.y),
static_cast<float>(size.w), static_cast<float>(size.h)};
SDL_SetRenderDrawColor(sdl_handles.renderer, 0, 0, 255, 255);
SDL_RenderRect(sdl_handles.renderer, &rect);
});
world.system<Game const, TextureAssets const>("SpawnFruits")
.term_at(0)
@@ -93,21 +120,65 @@ int main() {
.each([](flecs::iter &it, size_t index, Game const &game,
TextureAssets const &texture_assets) {
if ((game.ticks % 100) == 0) {
auto fruit =
it.world()
.entity()
.add<WorldPosition>()
.set<Position>(
Position{.x = static_cast<int>(game.ticks % WINDOW_WIDTH),
.y = -16})
.set<Velocity>(Velocity{.x = 0, .y = 1})
.set<Sprite>(
Sprite{.texture = &texture_assets.fruits,
.texture_atlas_index =
static_cast<uint16_t>(game.ticks % 228)})
.set<Size>(Size{.w = 32, .h = 32});
it.world()
.entity()
.set<Position>(Position{
.x = static_cast<int>(game.ticks % WINDOW_WIDTH), .y = -16})
.set<Velocity>(Velocity{.x = 0, .y = 1})
.set<Sprite>(Sprite{.texture = &texture_assets.fruits,
.texture_atlas_index =
static_cast<uint16_t>(game.ticks % 228)})
.set<Size>(Size{.w = 32, .h = 32});
.entity("CollisionBox")
.child_of(fruit)
.add<WorldPosition>()
.set<Position>(Position{.x = 0, .y = 0})
.set<Size>(Size{.w = 32, .h = 32})
.add<CollisionBox>();
}
});
world.system<WorldPosition, Position const>("PropagatePosition")
.kind(flecs::PostUpdate)
.each([](flecs::entity e, WorldPosition &world_pos,
Position const &local_pos) {
if (e.parent() == flecs::entity::null()) {
world_pos.x = local_pos.x;
world_pos.y = local_pos.y;
} else {
auto parent_world_pos = e.parent().get<WorldPosition>();
world_pos.x = parent_world_pos->x + local_pos.x;
world_pos.y = parent_world_pos->y + local_pos.y;
}
});
world.system<WorldPosition const, Size const, CollisionBox>("CollisionCheck")
.each([](flecs::iter &it, size_t index, WorldPosition const &world_pos,
Size const &size, CollisionBox) {
auto basket_box = it.world().lookup("Basket::CollisionBox");
if (it.entity(index) == basket_box)
return;
auto basket_box_pos = basket_box.get<WorldPosition>();
auto basket_box_size = basket_box.get<Size>();
if (basket_box_pos->x + basket_box_size->w >= world_pos.x &&
basket_box_pos->x <= world_pos.x + size.w &&
basket_box_pos->y + basket_box_size->h >= world_pos.y &&
basket_box_pos->y <= world_pos.y + size.h) {
spdlog::info("collision");
}
});
world
.system<SdlHandles const, Position const, Size const, Sprite const>(
"RenderSprites")
.kind(flecs::PreUpdate)
.term_at(0)
.singleton()
.each([](SdlHandles const &sdl_handles, Position const &pos,