diff options
| -rw-r--r-- | MainWindow.cpp | 33 | ||||
| -rw-r--r-- | MainWindow.h | 6 | 
2 files changed, 37 insertions, 2 deletions
| diff --git a/MainWindow.cpp b/MainWindow.cpp index fa1efa8..063b22b 100644 --- a/MainWindow.cpp +++ b/MainWindow.cpp @@ -25,6 +25,7 @@ FXDEFMAP(MainWindow) MainWindow_Map[]=  	FXMAPFUNC(SEL_COMMAND, MainWindow::UI_Tile, MainWindow::on_Tile_Click),  	FXMAPFUNC(SEL_COMMAND, MainWindow::UI_New, MainWindow::on_New_Click),  	FXMAPFUNC(SEL_RIGHTBUTTONPRESS, MainWindow::UI_Tile, MainWindow::on_Tile_Right_Click), +	FXMAPFUNC(SEL_TIMEOUT, MainWindow::UI_Timer_Tick, MainWindow::on_Timer_Tick),  };  FXIMPLEMENT(MainWindow, FXMainWindow, MainWindow_Map, ARRAYNUMBER(MainWindow_Map)) @@ -47,6 +48,15 @@ MainWindow::~MainWindow()  	delete board;  } +long +MainWindow::on_Timer_Tick(FXObject *sender, FXSelector sel, void *data) +{ +	seconds++; +	time_label->setText(FXStringVal(seconds)); +	getApp()->addTimeout(this, UI_Timer_Tick, 1000, nullptr); +	return 1; +} +  void  MainWindow::create()  { @@ -75,6 +85,7 @@ MainWindow::create_ui()  	// Label above the canvas  	new FXLabel(canvasFrame,"foxminesweeper", NULL, JUSTIFY_CENTER_X|LAYOUT_FILL_X); +	time_label = new FXLabel(canvasFrame, "0", nullptr, LAYOUT_CENTER_X);  	// Horizontal divider line  	new FXHorizontalSeparator(canvasFrame, SEPARATOR_GROOVE|LAYOUT_FILL_X); @@ -109,6 +120,8 @@ MainWindow::create_ui()  void  MainWindow::new_game(int width, int height, int minecount)  { +	seconds = 0; +	ticking = false;  	if (board)  		delete board;  	puts("starting new game.."); @@ -196,6 +209,11 @@ MainWindow::draw_buttons()  long  MainWindow::on_Tile_Click(FXObject *sender, FXSelector sel, void *data)  { +	if (!ticking) +	{ +		app->addTimeout(this, UI_Timer_Tick, 1000); +		ticking = true; +	}  	if (game_over == true)  		return 1;  	int x = 0, y = 0; @@ -216,20 +234,26 @@ MainWindow::on_Tile_Click(FXObject *sender, FXSelector sel, void *data)  	if (!board->is_game_running() && !board->is_game_won())  	{  		/* lost */ +		app->removeTimeout(this, UI_Timer_Tick);  		puts("you lose the game"); -		FXMessageBox *msgbox = new FXMessageBox(app, "Game Over", "You lost", nullptr, FX::MBOX_OK); +		std::string message = "You lost in: " + std::to_string(seconds) + " seconds"; +		FXMessageBox *msgbox = new FXMessageBox(app, "Game Over", FXString(message.c_str()), nullptr, FX::MBOX_OK);  		msgbox->create();  		msgbox->show();  		game_over = true; +		ticking = false;  	}  	else if (!board->is_game_running() && board->is_game_won())  	{  		/* won */ +		app->removeTimeout(this, UI_Timer_Tick);  		puts("you won the game"); -		FXMessageBox *msgbox = new FXMessageBox(app, "Game Over", "You win", nullptr, FX::MBOX_OK); +		std::string message = "You won in: " + std::to_string(seconds) + " seconds"; +		FXMessageBox *msgbox = new FXMessageBox(app, "Game Over", FXString(message.c_str()), nullptr, FX::MBOX_OK);  		msgbox->create();  		msgbox->show();  		game_over = true; +		ticking = false;  	}  	button->setFrameStyle(0);  	draw_buttons(); @@ -239,6 +263,11 @@ MainWindow::on_Tile_Click(FXObject *sender, FXSelector sel, void *data)  long  MainWindow::on_Tile_Right_Click(FXObject *sender, FXSelector sel, void *data)  { +	if (!ticking) +	{ +		app->addTimeout(this, UI_Timer_Tick, 1000); +		ticking = true; +	}  	if (game_over == true)  		return 1;  	int x = 0, y = 0; diff --git a/MainWindow.h b/MainWindow.h index 0cc0841..29e998c 100644 --- a/MainWindow.h +++ b/MainWindow.h @@ -20,6 +20,7 @@  #include <FXScrollArea.h>  #include <FXMessageBox.h>  #include <algorithm> +#include <string>  #include "Board.h"  #include "icons.h" @@ -37,12 +38,14 @@ class MainWindow : public FXMainWindow  		enum {  			UI_Tile       = FXMainWindow::ID_LAST,  			UI_New, +			UI_Timer_Tick,  		};  		/* Event handlers */  		long on_Tile_Click(FXObject *sender, FXSelector sel, void *data);  		long on_New_Click(FXObject *sender, FXSelector sel, void *data);  		long on_Tile_Right_Click(FXObject *sender, FXSelector sel, void *data); +		long on_Timer_Tick(FXObject *sender, FXSelector sel, void *data);  		FXApp *get_app(){ return app; }; @@ -55,6 +58,8 @@ class MainWindow : public FXMainWindow  		void new_game(int width, int height, int minecount);  		void draw_buttons();  		bool game_over; +		long unsigned int seconds; +		bool ticking;  		FXHorizontalFrame *contents;                // Content frame  		FXVerticalFrame   *canvasFrame;             // Canvas frame  		FXVerticalFrame   *buttonFrame;             // Button frame @@ -62,6 +67,7 @@ class MainWindow : public FXMainWindow  		FXApp *app;  		Board *board;  		FXMatrix *matrix; +		FXLabel *time_label;  		std::vector<std::shared_ptr<FXButton>> tile_buttons;  		/* icons */  		FXIcon *bomb_icon; | 
