Particle sparcle when skill unlocks
Minor modification to dagger damage
This commit is contained in:
parent
7386b3d582
commit
9a3dd410ab
|
@ -495,7 +495,7 @@ run_game(void)
|
||||||
|
|
||||||
SDL_RenderSetViewport(gRenderer, &gameViewport);
|
SDL_RenderSetViewport(gRenderer, &gameViewport);
|
||||||
map_render(gMap, &gCamera);
|
map_render(gMap, &gCamera);
|
||||||
particle_engine_render(&gCamera);
|
particle_engine_render_game(&gCamera);
|
||||||
|
|
||||||
if (!is_player_dead())
|
if (!is_player_dead())
|
||||||
player_render(gPlayer, &gCamera);
|
player_render(gPlayer, &gCamera);
|
||||||
|
@ -518,6 +518,7 @@ run_game(void)
|
||||||
BOTTOM_GUI_HEIGHT, &gCamera);
|
BOTTOM_GUI_HEIGHT, &gCamera);
|
||||||
|
|
||||||
SDL_RenderSetViewport(gRenderer, NULL);
|
SDL_RenderSetViewport(gRenderer, NULL);
|
||||||
|
particle_engine_render_global(&gCamera);
|
||||||
if (gGameState == IN_GAME_MENU) {
|
if (gGameState == IN_GAME_MENU) {
|
||||||
SDL_Rect dimmer = { 0, 0, SCREEN_WIDTH, SCREEN_HEIGHT };
|
SDL_Rect dimmer = { 0, 0, SCREEN_WIDTH, SCREEN_HEIGHT };
|
||||||
SDL_SetRenderDrawColor(gRenderer, 0, 0, 0, 150);
|
SDL_SetRenderDrawColor(gRenderer, 0, 0, 0, 150);
|
||||||
|
|
|
@ -37,7 +37,8 @@ typedef struct Particle_t {
|
||||||
} Particle;
|
} Particle;
|
||||||
|
|
||||||
typedef struct Engine_t {
|
typedef struct Engine_t {
|
||||||
LinkedList *particles;
|
LinkedList *global_particles;
|
||||||
|
LinkedList *game_particles;
|
||||||
} Engine;
|
} Engine;
|
||||||
|
|
||||||
static Engine *engine = NULL;
|
static Engine *engine = NULL;
|
||||||
|
@ -71,7 +72,8 @@ particle_engine_init(void)
|
||||||
fatal("Engine already initiated");
|
fatal("Engine already initiated");
|
||||||
|
|
||||||
engine = ec_malloc(sizeof(Engine));
|
engine = ec_malloc(sizeof(Engine));
|
||||||
engine->particles = linkedlist_create();
|
engine->game_particles = linkedlist_create();
|
||||||
|
engine->global_particles = linkedlist_create();
|
||||||
}
|
}
|
||||||
|
|
||||||
void
|
void
|
||||||
|
@ -106,7 +108,7 @@ particle_engine_bloodspray(Position pos, Dimension dim, unsigned int count)
|
||||||
p->lifetime = lt;
|
p->lifetime = lt;
|
||||||
p->dim = (Dimension) { w, h };
|
p->dim = (Dimension) { w, h };
|
||||||
p->color = (SDL_Color) { 255, 0, 0, 255 };
|
p->color = (SDL_Color) { 255, 0, 0, 255 };
|
||||||
linkedlist_append(&engine->particles, p);
|
linkedlist_append(&engine->game_particles, p);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -142,7 +144,7 @@ create_explosion(Position pos, Dimension dim, unsigned int c_count, ...)
|
||||||
p->lifetime = lt;
|
p->lifetime = lt;
|
||||||
p->dim = (Dimension) { 2, 2 };
|
p->dim = (Dimension) { 2, 2 };
|
||||||
p->color = colors[get_random((unsigned int) c_count-1)];
|
p->color = colors[get_random((unsigned int) c_count-1)];
|
||||||
linkedlist_append(&engine->particles, p);
|
linkedlist_append(&engine->game_particles, p);
|
||||||
}
|
}
|
||||||
free(colors);
|
free(colors);
|
||||||
}
|
}
|
||||||
|
@ -195,22 +197,23 @@ particle_engine_speed_lines(Position pos, Dimension dim, bool horizontal)
|
||||||
else
|
else
|
||||||
p->dim = (Dimension) { 2, 20 };
|
p->dim = (Dimension) { 2, 20 };
|
||||||
p->color = color;
|
p->color = color;
|
||||||
linkedlist_append(&engine->particles, p);
|
linkedlist_append(&engine->game_particles, p);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
void
|
void
|
||||||
particle_engine_sparkle(Position pos, Dimension dim)
|
particle_engine_sparkle(Position pos, Dimension dim)
|
||||||
{
|
{
|
||||||
debug("Sparkling");
|
for (unsigned int i = 0; i < 10; ++i) {
|
||||||
for (unsigned int i = 0; i < 50; ++i) {
|
int x, y, yv, alpha;
|
||||||
int x, y, yv;
|
|
||||||
unsigned int lt;
|
unsigned int lt;
|
||||||
Particle *p;
|
Particle *p;
|
||||||
|
|
||||||
x = get_random(dim.width) + pos.x;
|
x = get_random(dim.width) + pos.x;
|
||||||
y = get_random(dim.height) + pos.y;
|
y = get_random(dim.height) + pos.y;
|
||||||
|
|
||||||
|
alpha = get_random(155) + 100;
|
||||||
|
|
||||||
yv = (get_random(100) + 100) * -1;
|
yv = (get_random(100) + 100) * -1;
|
||||||
|
|
||||||
lt = get_random(20);
|
lt = get_random(20);
|
||||||
|
@ -223,7 +226,9 @@ particle_engine_sparkle(Position pos, Dimension dim)
|
||||||
p->blend_mode = SDL_BLENDMODE_BLEND;
|
p->blend_mode = SDL_BLENDMODE_BLEND;
|
||||||
p->dim = (Dimension) { 2, 2 };
|
p->dim = (Dimension) { 2, 2 };
|
||||||
p->color = C_WHITE;
|
p->color = C_WHITE;
|
||||||
linkedlist_append(&engine->particles, p);
|
p->color.a = alpha;
|
||||||
|
p->fixed = true;
|
||||||
|
linkedlist_append(&engine->global_particles, p);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -263,7 +268,7 @@ particle_engine_wind(Vector2d direction)
|
||||||
p->dim = (Dimension) { w, h };
|
p->dim = (Dimension) { w, h };
|
||||||
p->color = color;
|
p->color = color;
|
||||||
p->fixed = true;
|
p->fixed = true;
|
||||||
linkedlist_append(&engine->particles, p);
|
linkedlist_append(&engine->game_particles, p);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -277,40 +282,34 @@ move_particle(Particle *particle, float deltaTime)
|
||||||
particle->pos.y += (int) (particle->velocity.y * deltaTime);
|
particle->pos.y += (int) (particle->velocity.y * deltaTime);
|
||||||
}
|
}
|
||||||
|
|
||||||
void
|
static void
|
||||||
particle_engine_update(float deltaTime)
|
update_particles(LinkedList **particles, float deltaTime)
|
||||||
{
|
{
|
||||||
check_engine();
|
LinkedList *cleared = linkedlist_create();
|
||||||
LinkedList *current, *last;
|
while (*particles) {
|
||||||
|
Particle *particle = linkedlist_pop(particles);
|
||||||
current = engine->particles;
|
|
||||||
last = NULL;
|
|
||||||
|
|
||||||
while (current) {
|
|
||||||
Particle *particle = current->data;
|
|
||||||
|
|
||||||
if (particle->movetime)
|
if (particle->movetime)
|
||||||
particle->movetime--;
|
particle->movetime--;
|
||||||
|
|
||||||
if (particle->lifetime > 0) {
|
if (particle->lifetime > 0) {
|
||||||
particle->lifetime--;
|
particle->lifetime--;
|
||||||
move_particle(current->data, deltaTime);
|
move_particle(particle, deltaTime);
|
||||||
last = current;
|
linkedlist_push(&cleared, particle);
|
||||||
current = current->next;
|
|
||||||
} else {
|
} else {
|
||||||
if (!last) {
|
free(particle);
|
||||||
engine->particles = current->next;
|
|
||||||
free(current->data);
|
|
||||||
free(current);
|
|
||||||
current = engine->particles;
|
|
||||||
} else {
|
|
||||||
last->next = current->next;
|
|
||||||
free(current->data);
|
|
||||||
free(current);
|
|
||||||
current = last->next;
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
*particles = cleared;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void
|
||||||
|
particle_engine_update(float deltaTime)
|
||||||
|
{
|
||||||
|
check_engine();
|
||||||
|
|
||||||
|
update_particles(&engine->global_particles, deltaTime);
|
||||||
|
update_particles(&engine->game_particles, deltaTime);
|
||||||
}
|
}
|
||||||
|
|
||||||
static void
|
static void
|
||||||
|
@ -322,7 +321,6 @@ render_particle(Particle *p, Camera *cam)
|
||||||
else
|
else
|
||||||
pos = camera_to_camera_position(cam, &p->pos);
|
pos = camera_to_camera_position(cam, &p->pos);
|
||||||
|
|
||||||
// Make the particles look visible on all surfaces
|
|
||||||
SDL_SetRenderDrawBlendMode(cam->renderer, p->blend_mode);
|
SDL_SetRenderDrawBlendMode(cam->renderer, p->blend_mode);
|
||||||
|
|
||||||
SDL_Rect box = { pos.x, pos.y, p->dim.width, p->dim.height };
|
SDL_Rect box = { pos.x, pos.y, p->dim.width, p->dim.height };
|
||||||
|
@ -337,24 +335,37 @@ render_particle(Particle *p, Camera *cam)
|
||||||
SDL_SetRenderDrawBlendMode(cam->renderer, SDL_BLENDMODE_BLEND);
|
SDL_SetRenderDrawBlendMode(cam->renderer, SDL_BLENDMODE_BLEND);
|
||||||
}
|
}
|
||||||
|
|
||||||
void
|
static void
|
||||||
particle_engine_render(Camera *cam)
|
render_particles(LinkedList *particles, Camera *cam)
|
||||||
{
|
{
|
||||||
check_engine();
|
check_engine();
|
||||||
LinkedList *particles = engine->particles;
|
|
||||||
|
|
||||||
while (particles) {
|
LinkedList *render_list = particles;
|
||||||
render_particle(particles->data, cam);
|
|
||||||
particles = particles->next;
|
while (render_list) {
|
||||||
|
render_particle(render_list->data, cam);
|
||||||
|
render_list = render_list->next;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void
|
||||||
|
particle_engine_render_game(Camera *cam)
|
||||||
|
{
|
||||||
|
render_particles(engine->game_particles, cam);
|
||||||
|
}
|
||||||
|
|
||||||
|
void
|
||||||
|
particle_engine_render_global(Camera *cam)
|
||||||
|
{
|
||||||
|
render_particles(engine->global_particles, cam);
|
||||||
|
}
|
||||||
|
|
||||||
void
|
void
|
||||||
particle_engine_clear(void)
|
particle_engine_clear(void)
|
||||||
{
|
{
|
||||||
check_engine();
|
check_engine();
|
||||||
while (engine->particles)
|
while (engine->game_particles)
|
||||||
free(linkedlist_pop(&engine->particles));
|
free(linkedlist_pop(&engine->game_particles));
|
||||||
}
|
}
|
||||||
|
|
||||||
void
|
void
|
||||||
|
@ -362,8 +373,8 @@ particle_engine_close(void)
|
||||||
{
|
{
|
||||||
check_engine();
|
check_engine();
|
||||||
|
|
||||||
while (engine->particles)
|
while (engine->game_particles)
|
||||||
free(linkedlist_pop(&engine->particles));
|
free(linkedlist_pop(&engine->game_particles));
|
||||||
|
|
||||||
free(engine);
|
free(engine);
|
||||||
engine = NULL;
|
engine = NULL;
|
||||||
|
|
|
@ -50,7 +50,10 @@ void
|
||||||
particle_engine_update(float deltatime);
|
particle_engine_update(float deltatime);
|
||||||
|
|
||||||
void
|
void
|
||||||
particle_engine_render(Camera*);
|
particle_engine_render_game(Camera*);
|
||||||
|
|
||||||
|
void
|
||||||
|
particle_engine_render_global(Camera*);
|
||||||
|
|
||||||
void
|
void
|
||||||
particle_engine_clear(void);
|
particle_engine_clear(void);
|
||||||
|
|
|
@ -90,13 +90,15 @@ projectile_update(Projectile *p, UpdateData *data)
|
||||||
return;
|
return;
|
||||||
|
|
||||||
if (space->monster) {
|
if (space->monster) {
|
||||||
Uint32 dmg = stats_fight(&data->player->stats, &space->monster->stats);
|
Stats tmpStats = data->player->stats;
|
||||||
|
tmpStats.dmg *= 2;
|
||||||
|
Uint32 dmg = stats_fight(&tmpStats, &space->monster->stats);
|
||||||
if (dmg > 0) {
|
if (dmg > 0) {
|
||||||
gui_log("Your dagger pierced %s for %u damage", space->monster->lclabel, dmg);
|
gui_log("Your dagger pierced %s for %u damage", space->monster->lclabel, dmg);
|
||||||
mixer_play_effect(SWORD_HIT);
|
mixer_play_effect(SWORD_HIT);
|
||||||
data->player->hits += 1;
|
data->player->hits += 1;
|
||||||
}
|
}
|
||||||
if (get_random(2) == 0) {
|
if (get_random(2) >= 1) {
|
||||||
Item *item = item_builder_build_item(DAGGER, 1);
|
Item *item = item_builder_build_item(DAGGER, 1);
|
||||||
item->sprite->pos = space->monster->sprite->pos;
|
item->sprite->pos = space->monster->sprite->pos;
|
||||||
linkedlist_append(&data->map->items, item);
|
linkedlist_append(&data->map->items, item);
|
||||||
|
|
|
@ -219,12 +219,12 @@ render_skill_unavailable(SkillBar *bar, Player *player, Camera *cam)
|
||||||
static void
|
static void
|
||||||
render_skill_sparkles(SkillBar *bar, Player *player)
|
render_skill_sparkles(SkillBar *bar, Player *player)
|
||||||
{
|
{
|
||||||
if (timer_get_ticks(bar->skillSparkleTimer) > 3000) {
|
if (timer_get_ticks(bar->skillSparkleTimer) > 1500) {
|
||||||
timer_stop(bar->skillSparkleTimer);
|
timer_stop(bar->skillSparkleTimer);
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
Position pos = { 0, 0 };
|
Position pos = { 0, GAME_VIEW_HEIGHT };
|
||||||
Dimension dim = { 32, 32 };
|
Dimension dim = { 32, 32 };
|
||||||
for (int i = 0; i < PLAYER_SKILL_COUNT; ++i) {
|
for (int i = 0; i < PLAYER_SKILL_COUNT; ++i) {
|
||||||
if (!player->skills[i])
|
if (!player->skills[i])
|
||||||
|
|
Loading…
Reference in New Issue