aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--game/GameScene.cpp2
-rw-r--r--game/Random.h1
-rw-r--r--game/background/AquariumSubScene.cpp69
-rw-r--r--game/background/AquariumSubScene.h7
-rw-r--r--game/coins/CoinScript.cpp20
-rw-r--r--game/coins/CoinSubScene.cpp22
-rw-r--r--game/coins/CoinSystemScript.cpp4
7 files changed, 115 insertions, 10 deletions
diff --git a/game/GameScene.cpp b/game/GameScene.cpp
index 72d8b20..72eec9b 100644
--- a/game/GameScene.cpp
+++ b/game/GameScene.cpp
@@ -46,7 +46,7 @@ void GameScene::load_scene() {
camera.add_component<Camera>(
ivec2(990, 720), vec2(VIEWPORT_X, VIEWPORT_Y),
Camera::Data {
- .bg_color = Color::RED,
+ .bg_color = Color::BLACK,
}
);
camera.add_component<BehaviorScript>().set_script<MoveCameraManualyScript>();
diff --git a/game/Random.h b/game/Random.h
index 8db616c..0f0f79b 100644
--- a/game/Random.h
+++ b/game/Random.h
@@ -9,4 +9,3 @@ public:
static bool b();
};
-
diff --git a/game/background/AquariumSubScene.cpp b/game/background/AquariumSubScene.cpp
index 99466e3..2a07daf 100644
--- a/game/background/AquariumSubScene.cpp
+++ b/game/background/AquariumSubScene.cpp
@@ -4,6 +4,7 @@
#include <crepe/api/Animator.h>
#include <crepe/api/GameObject.h>
+#include <crepe/api/ParticleEmitter.h>
#include <crepe/api/Scene.h>
#include <crepe/api/Sprite.h>
#include <crepe/types.h>
@@ -41,6 +42,9 @@ float AquariumSubScene::create(Scene & scn, float begin_x) {
begin_x += 400;
this->add_background(scn, begin_x - 200);
+ this->add_bubbles(aquarium_middle_1, vec2(-400, 300), 2, 0.7f);
+ this->add_bubbles(aquarium_middle_1, vec2(-100, 300), 4, 1.0f);
+ this->add_bubbles(aquarium_middle_1, vec2(500, 300), 4, 0.9f);
GameObject aquarium_middle_2
= scn.new_object("aquarium_middle", "background_aqua", vec2(begin_x, 0));
@@ -55,6 +59,8 @@ float AquariumSubScene::create(Scene & scn, float begin_x) {
);
begin_x += 400;
+ this->add_bubbles(aquarium_middle_2, vec2(300, 300), 2, 0.6f);
+
GameObject aquarium_middle_3
= scn.new_object("aquarium_middle", "background_aqua", vec2(begin_x, 0));
Asset aquarium_middle_3_asset {"asset/background/aquarium/glassTubeFG_3_TVOS.png"};
@@ -84,6 +90,8 @@ float AquariumSubScene::create(Scene & scn, float begin_x) {
begin_x += 600;
this->add_background(scn, begin_x);
+ this->add_bubbles(aquarium_middle_4, vec2(175, 300), 4, 1.0f);
+ this->add_bubbles(aquarium_middle_4, vec2(200, 300), 4, 0.7f);
GameObject aquarium_end
= scn.new_object("aquarium_end", "background_aqua", vec2(begin_x, 0));
@@ -108,7 +116,7 @@ void AquariumSubScene::add_background(Scene & scn, float begin_x) {
bg_1_1_asset,
Sprite::Data {
.sorting_in_layer = SORT_IN_LAY_BACK_BACKGROUND,
- .order_in_layer = 2,
+ .order_in_layer = 5,
.size = vec2(0, 400),
.position_offset = vec2(-200, 100),
}
@@ -118,7 +126,7 @@ void AquariumSubScene::add_background(Scene & scn, float begin_x) {
bg_1_2_asset,
Sprite::Data {
.sorting_in_layer = SORT_IN_LAY_BACK_BACKGROUND,
- .order_in_layer = 2,
+ .order_in_layer = 5,
.size = vec2(0, 400),
.position_offset = vec2(200, 100),
}
@@ -129,7 +137,7 @@ void AquariumSubScene::add_background(Scene & scn, float begin_x) {
bg_2_1_asset,
Sprite::Data {
.sorting_in_layer = SORT_IN_LAY_BACK_BACKGROUND,
- .order_in_layer = 1,
+ .order_in_layer = 3,
.size = vec2(0, 400),
.position_offset = vec2(200, -50),
}
@@ -139,7 +147,7 @@ void AquariumSubScene::add_background(Scene & scn, float begin_x) {
bg_2_2_asset,
Sprite::Data {
.sorting_in_layer = SORT_IN_LAY_BACK_BACKGROUND,
- .order_in_layer = 1,
+ .order_in_layer = 3,
.size = vec2(0, 400),
.position_offset = vec2(-200, -50),
}
@@ -150,7 +158,7 @@ void AquariumSubScene::add_background(Scene & scn, float begin_x) {
bg_3_1_asset,
Sprite::Data {
.sorting_in_layer = SORT_IN_LAY_BACK_BACKGROUND,
- .order_in_layer = 0,
+ .order_in_layer = 1,
.size = vec2(0, 400),
.position_offset = vec2(200, -200),
}
@@ -160,9 +168,58 @@ void AquariumSubScene::add_background(Scene & scn, float begin_x) {
bg_3_2_asset,
Sprite::Data {
.sorting_in_layer = SORT_IN_LAY_BACK_BACKGROUND,
- .order_in_layer = 0,
+ .order_in_layer = 1,
.size = vec2(0, 400),
.position_offset = vec2(-200, -200),
}
);
}
+
+void AquariumSubScene::add_bubbles(
+ GameObject & obj, vec2 offset, int order_in_layer, float scale
+) {
+ Sprite & sprite = obj.add_component<Sprite>(
+ Asset {"asset/background/aquarium/bubble.png"},
+ Sprite::Data {
+ .sorting_in_layer = SORT_IN_LAY_BACK_BACKGROUND,
+ .order_in_layer = order_in_layer,
+ .size = vec2(0, 12.5),
+ .scale_offset = scale,
+ }
+ );
+ obj.add_component<ParticleEmitter>(
+ sprite,
+ ParticleEmitter::Data {
+ .offset = offset,
+ .max_particles = 20,
+ .emission_rate = 1.2,
+ .min_speed = 50,
+ .max_speed = 100,
+ .min_angle = 265,
+ .max_angle = 275,
+ .force_over_time = vec2(0, -50),
+ }
+ );
+ Sprite & sprite_small = obj.add_component<Sprite>(
+ Asset {"asset/background/aquarium/bubble.png"},
+ Sprite::Data {
+ .sorting_in_layer = SORT_IN_LAY_BACK_BACKGROUND,
+ .order_in_layer = order_in_layer,
+ .size = vec2(0, 7.5),
+ .scale_offset = scale,
+ }
+ );
+ obj.add_component<ParticleEmitter>(
+ sprite_small,
+ ParticleEmitter::Data {
+ .offset = offset,
+ .max_particles = 20,
+ .emission_rate = 0.8,
+ .min_speed = 50,
+ .max_speed = 100,
+ .min_angle = 265,
+ .max_angle = 275,
+ .force_over_time = vec2(0, -50),
+ }
+ );
+}
diff --git a/game/background/AquariumSubScene.h b/game/background/AquariumSubScene.h
index 2a188bc..9dbb04e 100644
--- a/game/background/AquariumSubScene.h
+++ b/game/background/AquariumSubScene.h
@@ -1,8 +1,11 @@
#pragma once
+#include <crepe/types.h>
+
namespace crepe {
class Scene;
-}
+class GameObject;
+} // namespace crepe
class AquariumSubScene {
public:
@@ -10,4 +13,6 @@ public:
private:
void add_background(crepe::Scene & scn, float begin_x);
+ void
+ add_bubbles(crepe::GameObject & obj, crepe::vec2 offset, int order_in_layer, float scale);
};
diff --git a/game/coins/CoinScript.cpp b/game/coins/CoinScript.cpp
index 90150b6..514f4de 100644
--- a/game/coins/CoinScript.cpp
+++ b/game/coins/CoinScript.cpp
@@ -5,6 +5,8 @@
#include "../Config.h"
#include "../hud/HudScript.h"
+#include <crepe/api/Animator.h>
+#include <crepe/api/AudioSource.h>
#include <crepe/api/CircleCollider.h>
#include <crepe/api/Sprite.h>
@@ -29,6 +31,24 @@ bool CoinScript::on_collision(const CollisionEvent & collisionData) {
.active
= false;
this->amount++;
+
+ AudioSource & audio = this->get_components_by_id<AudioSource>(
+ collisionData.info.other.metadata.game_object_id
+ )
+ .front();
+ audio.play();
+
+ this->get_components_by_name<Sprite>(collisionData.info.other.metadata.name)
+ .back()
+ .get()
+ .active
+ = true;
+ this->get_components_by_name<Animator>(collisionData.info.other.metadata.name)
+ .back()
+ .get()
+ .active
+ = true;
+
return false;
}
diff --git a/game/coins/CoinSubScene.cpp b/game/coins/CoinSubScene.cpp
index 2c9feb6..d154819 100644
--- a/game/coins/CoinSubScene.cpp
+++ b/game/coins/CoinSubScene.cpp
@@ -39,6 +39,26 @@ int CoinSubScene::create(Scene & scn, int coin_counter) {
.looping = true,
}
);
- coin.add_component<AudioSource>(Asset {"asset/sfx/coin_pickup_1.ogg"});
+ coin.add_component<AudioSource>(Asset {"asset/sfx/coin_pickup_1.ogg"}).volume = 3;
+
+ Sprite & pick_up = coin.add_component<Sprite>(
+ Asset {"asset/coin/coinCollect1_TVOS.png"},
+ Sprite::Data {
+ .sorting_in_layer = SORT_IN_LAY_COINS,
+ .order_in_layer = 1,
+ .size = size * 2,
+ }
+ );
+ pick_up.active = false;
+ coin.add_component<Animator>(
+ pick_up, ivec2 {64, 64}, uvec2 {5, 1},
+ Animator::Data {
+ .fps = 5,
+ .looping = false,
+ }
+ )
+ .active
+ = false;
+
return coin_counter;
}
diff --git a/game/coins/CoinSystemScript.cpp b/game/coins/CoinSystemScript.cpp
index 1634aa9..f9816c9 100644
--- a/game/coins/CoinSystemScript.cpp
+++ b/game/coins/CoinSystemScript.cpp
@@ -209,6 +209,10 @@ void CoinSystemScript::spawn_coins() {
for (Sprite & coin_sprite : coin_sprites) {
// Skip this sprite if it is already active
if (coin_sprite.active) continue;
+ if (coin_sprite.data.order_in_layer == 1) {
+ coin_sprite.active = false;
+ continue;
+ }
// Found an available (inactive) coin sprite
// Retrieve its associated components