add text a the bottom fr this time

This commit is contained in:
Mylloon 2023-12-28 17:09:00 +01:00
parent f63d9f8705
commit 6b6afa76b2
Signed by: Anri
GPG key ID: A82D63DFF8D1317F
5 changed files with 36 additions and 3 deletions

Binary file not shown.

View file

@ -4,7 +4,9 @@
#include <functional> #include <functional>
class Ecran { class Ecran {
static const uint bottomTxtPadding = 20; static const uint bottomTxtPadding = 30;
std::string message;
public: public:
// Fenêtre // Fenêtre
@ -32,4 +34,10 @@ public:
static uint hauteur() { static uint hauteur() {
return window.getSize().y - bottomTxtPadding; return window.getSize().y - bottomTxtPadding;
} }
// Ecrire un message en bas de l'écran
void printMessage(std::string msg);
// Efface le message en bas de l'écran
void cleanMessage();
}; };

View file

@ -28,4 +28,8 @@ std::ostream &operator<<(std::ostream &out, const Butin &data) {
void Butin::init() { void Butin::init() {
plateau.initialiserPlateau(); plateau.initialiserPlateau();
// Demander à J1 de retirer une pièce jaune
// Demander à J2 de retirer une pièce jaune
} }

View file

@ -2,7 +2,7 @@
sf::RenderWindow Ecran::window; sf::RenderWindow Ecran::window;
Ecran::Ecran(const uint w, const uint h, const std::string n) { Ecran::Ecran(const uint w, const uint h, const std::string n) : message("") {
// Création de la fenêtre SFML // Création de la fenêtre SFML
window.create(sf::VideoMode(w, h + bottomTxtPadding), n); window.create(sf::VideoMode(w, h + bottomTxtPadding), n);
} }
@ -12,6 +12,15 @@ Ecran::~Ecran() {}
void Ecran::afficher( void Ecran::afficher(
const std::function<void()> dessin, const std::function<void()> dessin,
const std::function<void(const int, const int)> onLeftClick) const { const std::function<void(const int, const int)> onLeftClick) const {
sf::Font font;
font.loadFromFile("assets/open-sans-latin-400-normal.ttf");
sf::Text text;
text.setFont(font);
text.setCharacterSize(24);
text.setPosition(0, hauteur());
text.setFillColor(sf::Color::White);
while (window.isOpen()) { while (window.isOpen()) {
sf::Event event; sf::Event event;
while (window.pollEvent(event)) { while (window.pollEvent(event)) {
@ -32,6 +41,18 @@ void Ecran::afficher(
// Appel d'une fonction dessin // Appel d'une fonction dessin
dessin(); dessin();
// Ecriture du message
text.setString(message);
window.draw(text);
window.display(); window.display();
} }
} }
void Ecran::printMessage(std::string msg) {
message = msg;
}
void Ecran::cleanMessage() {
message = "";
}

View file

@ -29,7 +29,7 @@ void Plateau::afficherPlateau(std::ostream &out, const bool d) const {
// Adapte la vue pour le redimensionnement // Adapte la vue pour le redimensionnement
const float tailleFenetre = taille * tailleCellule; const float tailleFenetre = taille * tailleCellule;
Ecran::window.setView( Ecran::window.setView(
sf::View(sf::FloatRect(0, 0, tailleFenetre, tailleFenetre))); sf::View(sf::FloatRect(0, 0, tailleFenetre, Ecran::window.getSize().y)));
// Cellule // Cellule
sf::RectangleShape cell(sf::Vector2f(tailleCellule, tailleCellule)); sf::RectangleShape cell(sf::Vector2f(tailleCellule, tailleCellule));