Skip to content

Commit

Permalink
melee: Render unselected pilot portraits properly
Browse files Browse the repository at this point in the history
  • Loading branch information
Nopey committed Dec 2, 2024
1 parent b1f19fb commit 762e17c
Showing 1 changed file with 24 additions and 8 deletions.
32 changes: 24 additions & 8 deletions src/game/scenes/melee.c
Original file line number Diff line number Diff line change
Expand Up @@ -65,6 +65,7 @@ typedef struct {
object big_portrait_1;
object big_portrait_2;
object player2_placeholder;
object unselected_pilot_portraits;
object unselected_har_portraits;

portrait pilot_portraits[10];
Expand Down Expand Up @@ -123,6 +124,7 @@ void melee_free(scene *scene) {
}

object_free(&local->player2_placeholder);
object_free(&local->unselected_pilot_portraits);
object_free(&local->unselected_har_portraits);
object_free(&local->big_portrait_1);
if(player2->selectable) {
Expand All @@ -147,6 +149,20 @@ static void set_cursor_colors(int offset, bool a_done, bool b_done) {
vga_state_set_base_palette_index(VIOLET_CURSOR_INDEX, &violet_cursor_color);
}

static void load_pilot_portraits_palette(scene *scene) {
vga_palette *bk_pal = bk_get_palette(scene->bk_data, 0);
// copy and dim for unselected pilot portraits
for(uint8_t idx = 0x01; idx < 0x60; idx++) {
uint8_t src_idx = idx + 0xA0;
vga_color src = bk_pal->colors[src_idx];
src.r /= 2;
src.g /= 2;
src.b /= 2;
bk_pal->colors[idx] = src;
}
vga_state_set_base_palette_from_range(bk_pal, 0x00, 0x00, 0x60);
}

void melee_tick(scene *scene, int paused) {
melee_local *local = scene_get_userdata(scene);
game_player *player1 = game_state_get_player(scene->gs, 0);
Expand Down Expand Up @@ -419,6 +435,7 @@ void melee_input_tick(scene *scene) {
local->cursor[1].row = local->pilot_id_b / 5;
local->cursor[1].done = 0;
local->page = PILOT_SELECT;
load_pilot_portraits_palette(scene);
} else {
game_state_set_next(scene->gs, SCENE_MENU);
}
Expand Down Expand Up @@ -461,13 +478,6 @@ static void render_highlights(const melee_local *local, bool player2_is_selectab
}
}

static void render_disabled_portraits(const portrait *portraits) {
for(int i = 0; i < 10; i++) {
const portrait *p = &portraits[i];
video_draw_offset(&p->disabled, p->x, p->y, p->disabled_offset, 255);
}
}

static void render_enabled_portrait(const portrait *portraits, cursor_data *cursor, int player) {
const portrait *p = &portraits[5 * cursor->row + cursor->column];
if(player < 0) {
Expand Down Expand Up @@ -539,8 +549,8 @@ static void render_pilot_select(melee_local *local, bool player2_is_selectable)
// player 1 name
text_render(&tconf_black, TEXT_DEFAULT, 0, 52, 66, 6, lang_get(20 + current_a));

object_render(&local->unselected_pilot_portraits);
render_highlights(local, player2_is_selectable);
render_disabled_portraits(local->pilot_portraits);
render_enabled_portrait(local->pilot_portraits, &local->cursor[0], -1);
object_render(&local->big_portrait_1);
if(player2_is_selectable) {
Expand Down Expand Up @@ -651,6 +661,11 @@ static void load_pilot_portraits(scene *scene, melee_local *local) {
surface_compress_index_blocks(&target->disabled, 0xE0, 0xF0, 8, 2);
surface_compress_remap(&target->disabled, 0xF0, 0xF7, 0xB6, 3);
}

animation *har_portraits = &bk_get_info(scene->bk_data, 0)->ani;
object_create_static(&local->unselected_pilot_portraits, scene->gs);
object_set_animation(&local->unselected_pilot_portraits, har_portraits);
object_select_sprite(&local->unselected_pilot_portraits, 0);
}

static void load_har_portraits(scene *scene, melee_local *local) {
Expand Down Expand Up @@ -742,6 +757,7 @@ int melee_create(scene *scene) {

// Load HAR and Pilot face portraits and har sprites for the selection grid
load_pilot_portraits(scene, local);
load_pilot_portraits_palette(scene);
load_har_portraits(scene, local);
load_hars(scene, local, player2->selectable);

Expand Down

0 comments on commit 762e17c

Please sign in to comment.