#include "top10scorescreen.h"
#include "fonts.h"
+#define RANK_X 30
+#define PLAYER_X 70
+#define SONG_X 370
+#define SCORE_X (LOGICAL_SCREEN_WIDTH - 72)
+#define SONG_MAX_WIDTH (LOGICAL_SCREEN_WIDTH - 480)
+
Top10ScoreScreen::Top10ScoreScreen(pqxx::connection &conn, unsigned tournament)
: conn(conn), tournament(tournament), scores_changed(conn, "scores"), valid(false)
{
}
// simple headings
- my_draw_text("Player", buf, 12.0, 70, 100);
- my_draw_text("Song", buf, 12.0, 370, 100);
- my_draw_text("Score", buf, 12.0, 710, 100);
+ my_draw_text("Player", buf, 12.0, PLAYER_X, 100);
+ my_draw_text("Song", buf, 12.0, SONG_X, 100);
+ my_draw_text("Score", buf, 12.0, SCORE_X - 18, 100);
unsigned row = 1, y = 140;
for (std::vector<TopScore>::const_iterator i = scores.begin(); i != scores.end(); ++i) {
std::sprintf(str, "%u", row++);
unsigned width = my_draw_text(str, NULL, 24.0);
- my_draw_text(str, buf, 24.0, 30 - width/2, y);
+ my_draw_text(str, buf, 24.0, RANK_X - width/2, y);
- my_draw_text(i->nick, buf, 24.0, 70, y, r, g, b);
+ my_draw_text(i->nick, buf, 24.0, PLAYER_X, y, r, g, b);
- if (my_draw_text(i->title, NULL, 24.0) > 320 &&
+ if (my_draw_text(i->title, NULL, 24.0) > SONG_MAX_WIDTH &&
!i->shorttitle.empty()) {
- my_draw_text(i->shorttitle, buf, 24.0, 370, y, r, g, b);
+ my_draw_text(i->shorttitle, buf, 24.0, SONG_X, y, r, g, b);
} else {
- my_draw_text(i->title, buf, 24.0, 370, y, r, g, b);
+ my_draw_text(i->title, buf, 24.0, SONG_X, y, r, g, b);
}
std::sprintf(str, "%u", i->score);
width = my_draw_text(str, NULL, 24.0);
- my_draw_text(str, buf, 24.0, 728 - width/2, y, r, g, b);
+ my_draw_text(str, buf, 24.0, SCORE_X - width/2, y, r, g, b);
y += 40;
}