Adds controller button support for skillbar

This commit is contained in:
Linus Probert 2018-10-10 22:54:43 +02:00
parent c3b2b6f214
commit 2919ebf97f
2 changed files with 42 additions and 10 deletions

View File

@ -28,6 +28,26 @@
#include "update_data.h" #include "update_data.h"
#include "gui.h" #include "gui.h"
static bool controller_mode = false;
void
skillbar_set_controller_mode(bool ctrl_mode)
{
controller_mode = ctrl_mode;
}
static Sprite *
create_controller_button_sprite(Position pos, SDL_Rect clip)
{
Texture *t = texturecache_add("Extras/Controller.png");
Sprite *s = sprite_create();
sprite_set_texture(s, t, 0);
s->pos = pos;
s->clip = clip;
s->dim = DIM(16, 16);
return s;
}
static void static void
load_texture(SkillBar *bar, const char *path, SDL_Renderer *renderer) load_texture(SkillBar *bar, const char *path, SDL_Renderer *renderer)
{ {
@ -35,16 +55,25 @@ load_texture(SkillBar *bar, const char *path, SDL_Renderer *renderer)
t->dim.width = 16; t->dim.width = 16;
t->dim.height = 16; t->dim.height = 16;
for (unsigned int i = 0; i < 5; ++i) { if (!controller_mode) {
char buffer[4]; for (unsigned int i = 0; i < 5; ++i) {
Sprite *s = sprite_create(); char buffer[4];
s->pos = (Position) { i * 32 + 20, 20 }; Sprite *s = sprite_create();
s->dim = (Dimension) { 8, 8 }; s->pos = (Position) { i * 32 + 20, 20 };
s->fixed = true; s->dim = (Dimension) { 8, 8 };
sprite_load_text_texture(s, "GUI/SDS_8x8.ttf", 0, 8, 0); s->fixed = true;
m_sprintf(buffer, 4, "%u", i+1 < 10 ? i+1 : 0); sprite_load_text_texture(s, "GUI/SDS_8x8.ttf", 0, 8, 0);
texture_load_from_text(s->textures[0], buffer, C_YELLOW, C_BLACK, renderer); m_sprintf(buffer, 4, "%u", i + 1 < 10 ? i + 1 : 0);
linkedlist_append(&bar->sprites, s); texture_load_from_text(s->textures[0], buffer, C_YELLOW, C_BLACK, renderer);
linkedlist_append(&bar->sprites, s);
}
} else {
Uint8 i = 0;
linkedlist_append(&bar->sprites, create_controller_button_sprite(POS(i++ * 32 + 16, 16), CLIP16(0, 0)));
linkedlist_append(&bar->sprites, create_controller_button_sprite(POS(i++ * 32 + 16, 16), CLIP16(16, 0)));
linkedlist_append(&bar->sprites, create_controller_button_sprite(POS(i++ * 32 + 16, 16), CLIP16(32, 0)));
linkedlist_append(&bar->sprites, create_controller_button_sprite(POS(i++ * 32 + 16, 16), CLIP16(48, 0)));
linkedlist_append(&bar->sprites, create_controller_button_sprite(POS(i++ * 32 + 16, 20), CLIP16(48, 48)));
} }
} }

View File

@ -45,6 +45,9 @@ typedef struct SkillBar {
Uint32 lastActivation; Uint32 lastActivation;
} SkillBar; } SkillBar;
void
skillbar_set_controller_mode(bool ctrl_mode);
SkillBar * SkillBar *
skillbar_create(Camera*); skillbar_create(Camera*);