summaryrefslogtreecommitdiff
Side-by-side diff
Diffstat (more/less context) (ignore whitespace changes)
-rw-r--r--noncore/games/tictac/tictac.cpp282
1 files changed, 143 insertions, 139 deletions
diff --git a/noncore/games/tictac/tictac.cpp b/noncore/games/tictac/tictac.cpp
index 20cc942..3d727ac 100644
--- a/noncore/games/tictac/tictac.cpp
+++ b/noncore/games/tictac/tictac.cpp
@@ -1,12 +1,12 @@
/****************************************************************************
-** $Id$
-**
-** Copyright (C) 1992-2000 Trolltech AS. All rights reserved.
-**
-** This file is part of an example program for Qt. This example
-** program may be used, distributed and modified without limitation.
-**
-*****************************************************************************/
+ ** $Id$
+ **
+ ** Copyright (C) 1992-2000 Trolltech AS. All rights reserved.
+ **
+ ** This file is part of an example program for Qt. This example
+ ** program may be used, distributed and modified without limitation.
+ **
+ *****************************************************************************/
#include "tictac.h"
#include <qpe/qpeapplication.h>
@@ -16,8 +16,9 @@
#include <qcheckbox.h>
#include <qlabel.h>
#include <qlayout.h>
-#include <stdlib.h> // rand() function
-#include <qdatetime.h> // seed for rand()
+#include <stdlib.h> // rand() function
+#include <qdatetime.h> // seed for rand()
+#include <qstringlist.h> //needed for proper internationalization
//***************************************************************************
@@ -30,7 +31,7 @@
TicTacButton::TicTacButton( QWidget *parent ) : QPushButton( parent )
{
- t = Blank; // initial type
+ t = Blank; // initial type
}
// --------------------------------------------------------------------------
@@ -40,12 +41,12 @@ TicTacButton::TicTacButton( QWidget *parent ) : QPushButton( parent )
void TicTacButton::drawButtonLabel( QPainter *p )
{
QRect r = rect();
- p->setPen( QPen( white,2 ) ); // set fat pen
+ p->setPen( QPen( white,2 ) ); // set fat pen
if ( t == Circle ) {
- p->drawEllipse( r.left()+4, r.top()+4, r.width()-8, r.height()-8 );
- } else if ( t == Cross ) { // draw cross
- p->drawLine( r.topLeft() +QPoint(4,4), r.bottomRight()-QPoint(4,4));
- p->drawLine( r.bottomLeft()+QPoint(4,-4),r.topRight() -QPoint(4,-4));
+ p->drawEllipse( r.left()+4, r.top()+4, r.width()-8, r.height()-8 );
+ } else if ( t == Cross ) { // draw cross
+ p->drawLine( r.topLeft() +QPoint(4,4), r.bottomRight()-QPoint(4,4));
+ p->drawLine( r.bottomLeft()+QPoint(4,-4),r.topRight() -QPoint(4,-4));
}
}
@@ -60,27 +61,27 @@ void TicTacButton::drawButtonLabel( QPainter *p )
//
TicTacGameBoard::TicTacGameBoard( int n, QWidget *parent, const char *name )
- : QWidget( parent, name )
+ : QWidget( parent, name )
{
-showMaximized();
- st = Init; // initial state
+ showMaximized();
+ st = Init; // initial state
nBoard = n;
- n *= n; // make square
- comp_starts = FALSE; // human starts
- buttons = new TicTacButtons(n); // create real buttons
- btArray = new TicTacArray(n); // create button model
+ n *= n; // make square
+ comp_starts = FALSE; // human starts
+ buttons = new TicTacButtons(n); // create real buttons
+ btArray = new TicTacArray(n); // create button model
QGridLayout * grid = new QGridLayout( this, 3, 3, 4 );
QPalette p( blue );
- for ( int i=0; i<n; i++ ) { // create and connect buttons
- TicTacButton *ttb = new TicTacButton( this );
- ttb->setPalette( p );
- ttb->setEnabled( FALSE );
- connect( ttb, SIGNAL(clicked()), SLOT(buttonClicked()) );
- grid->addWidget( ttb, i%3, i/3 );
- buttons->insert( i, ttb );
- btArray->at(i) = TicTacButton::Blank; // initial button type
+ for ( int i=0; i<n; i++ ) { // create and connect buttons
+ TicTacButton *ttb = new TicTacButton( this );
+ ttb->setPalette( p );
+ ttb->setEnabled( FALSE );
+ connect( ttb, SIGNAL(clicked()), SLOT(buttonClicked()) );
+ grid->addWidget( ttb, i%3, i/3 );
+ buttons->insert( i, ttb );
+ btArray->at(i) = TicTacButton::Blank; // initial button type
}
- QTime t = QTime::currentTime(); // set random seed
+ QTime t = QTime::currentTime(); // set random seed
srand( t.hour()*12+t.minute()*60+t.second()*60 );
}
@@ -113,16 +114,16 @@ void TicTacGameBoard::newGame()
{
st = HumansTurn;
for ( int i=0; i<nBoard*nBoard; i++ )
- btArray->at(i) = TicTacButton::Blank;
+ btArray->at(i) = TicTacButton::Blank;
if ( comp_starts )
- computerMove();
+ computerMove();
else
- updateButtons();
+ updateButtons();
}
// --------------------------------------------------------------------------
-// TicTacGameBoard::buttonClicked() - SLOT
+// TicTacGameBoard::buttonClicked() - SLOT
//
// This slot is activated when a TicTacButton emits the signal "clicked()",
// i.e. the user has clicked on a TicTacButton.
@@ -130,20 +131,20 @@ void TicTacGameBoard::newGame()
void TicTacGameBoard::buttonClicked()
{
- if ( st != HumansTurn ) // not ready
- return;
+ if ( st != HumansTurn ) // not ready
+ return;
int i = buttons->findRef( (TicTacButton*)sender() );
- TicTacButton *b = buttons->at(i); // get piece that was pressed
- if ( b->type() == TicTacButton::Blank ) { // empty piece?
- btArray->at(i) = TicTacButton::Circle;
- updateButtons();
- if ( checkBoard( btArray ) == 0 ) // not a winning move?
- computerMove();
- int s = checkBoard( btArray );
- if ( s ) { // any winners yet?
- st = s == TicTacButton::Circle ? HumanWon : ComputerWon;
- emit finished();
- }
+ TicTacButton *b = buttons->at(i); // get piece that was pressed
+ if ( b->type() == TicTacButton::Blank ) { // empty piece?
+ btArray->at(i) = TicTacButton::Circle;
+ updateButtons();
+ if ( checkBoard( btArray ) == 0 ) // not a winning move?
+ computerMove();
+ int s = checkBoard( btArray );
+ if ( s ) { // any winners yet?
+ st = s == TicTacButton::Circle ? HumanWon : ComputerWon;
+ emit finished();
+ }
}
}
@@ -157,10 +158,10 @@ void TicTacGameBoard::buttonClicked()
void TicTacGameBoard::updateButtons()
{
for ( int i=0; i<nBoard*nBoard; i++ ) {
- if ( buttons->at(i)->type() != btArray->at(i) )
- buttons->at(i)->setType( (TicTacButton::Type)btArray->at(i) );
- buttons->at(i)->setEnabled( buttons->at(i)->type() ==
- TicTacButton::Blank );
+ if ( buttons->at(i)->type() != btArray->at(i) )
+ buttons->at(i)->setType( (TicTacButton::Type)btArray->at(i) );
+ buttons->at(i)->setEnabled( buttons->at(i)->type() ==
+ TicTacButton::Blank );
}
}
@@ -181,51 +182,51 @@ int TicTacGameBoard::checkBoard( TicTacArray *a )
int t = 0;
int row, col;
bool won = FALSE;
- for ( row=0; row<nBoard && !won; row++ ) { // check horizontal
- t = a->at(row*nBoard);
- if ( t == TicTacButton::Blank )
- continue;
- col = 1;
- while ( col<nBoard && a->at(row*nBoard+col) == t )
- col++;
- if ( col == nBoard )
- won = TRUE;
+ for ( row=0; row<nBoard && !won; row++ ) { // check horizontal
+ t = a->at(row*nBoard);
+ if ( t == TicTacButton::Blank )
+ continue;
+ col = 1;
+ while ( col<nBoard && a->at(row*nBoard+col) == t )
+ col++;
+ if ( col == nBoard )
+ won = TRUE;
}
- for ( col=0; col<nBoard && !won; col++ ) { // check vertical
- t = a->at(col);
- if ( t == TicTacButton::Blank )
- continue;
- row = 1;
- while ( row<nBoard && a->at(row*nBoard+col) == t )
- row++;
- if ( row == nBoard )
- won = TRUE;
+ for ( col=0; col<nBoard && !won; col++ ) { // check vertical
+ t = a->at(col);
+ if ( t == TicTacButton::Blank )
+ continue;
+ row = 1;
+ while ( row<nBoard && a->at(row*nBoard+col) == t )
+ row++;
+ if ( row == nBoard )
+ won = TRUE;
}
- if ( !won ) { // check diagonal top left
- t = a->at(0); // to bottom right
- if ( t != TicTacButton::Blank ) {
- int i = 1;
- while ( i<nBoard && a->at(i*nBoard+i) == t )
- i++;
- if ( i == nBoard )
- won = TRUE;
- }
+ if ( !won ) { // check diagonal top left
+ t = a->at(0); // to bottom right
+ if ( t != TicTacButton::Blank ) {
+ int i = 1;
+ while ( i<nBoard && a->at(i*nBoard+i) == t )
+ i++;
+ if ( i == nBoard )
+ won = TRUE;
+ }
}
- if ( !won ) { // check diagonal bottom left
- int j = nBoard-1; // to top right
- int i = 0;
- t = a->at(i+j*nBoard);
- if ( t != TicTacButton::Blank ) {
- i++; j--;
- while ( i<nBoard && a->at(i+j*nBoard) == t ) {
- i++; j--;
- }
- if ( i == nBoard )
- won = TRUE;
- }
+ if ( !won ) { // check diagonal bottom left
+ int j = nBoard-1; // to top right
+ int i = 0;
+ t = a->at(i+j*nBoard);
+ if ( t != TicTacButton::Blank ) {
+ i++; j--;
+ while ( i<nBoard && a->at(i+j*nBoard) == t ) {
+ i++; j--;
+ }
+ if ( i == nBoard )
+ won = TRUE;
+ }
}
- if ( !won ) // no winner
- t = 0;
+ if ( !won ) // no winner
+ t = 0;
return t;
}
@@ -239,41 +240,41 @@ int TicTacGameBoard::checkBoard( TicTacArray *a )
void TicTacGameBoard::computerMove()
{
int numButtons = nBoard*nBoard;
- int *altv = new int[numButtons]; // buttons alternatives
+ int *altv = new int[numButtons]; // buttons alternatives
int altc = 0;
int stopHuman = -1;
TicTacArray a = btArray->copy();
int i;
- for ( i=0; i<numButtons; i++ ) { // try all positions
- if ( a[i] != TicTacButton::Blank ) // already a piece there
- continue;
- a[i] = TicTacButton::Cross; // test if computer wins
- if ( checkBoard(&a) == a[i] ) { // computer will win
- st = ComputerWon;
- stopHuman = -1;
- break;
- }
- a[i] = TicTacButton::Circle; // test if human wins
- if ( checkBoard(&a) == a[i] ) { // oops...
- stopHuman = i; // remember position
- a[i] = TicTacButton::Blank; // restore button
- continue; // computer still might win
- }
- a[i] = TicTacButton::Blank; // restore button
- altv[altc++] = i; // remember alternative
+ for ( i=0; i<numButtons; i++ ) { // try all positions
+ if ( a[i] != TicTacButton::Blank ) // already a piece there
+ continue;
+ a[i] = TicTacButton::Cross; // test if computer wins
+ if ( checkBoard(&a) == a[i] ) { // computer will win
+ st = ComputerWon;
+ stopHuman = -1;
+ break;
+ }
+ a[i] = TicTacButton::Circle; // test if human wins
+ if ( checkBoard(&a) == a[i] ) { // oops...
+ stopHuman = i; // remember position
+ a[i] = TicTacButton::Blank; // restore button
+ continue; // computer still might win
+ }
+ a[i] = TicTacButton::Blank; // restore button
+ altv[altc++] = i; // remember alternative
}
- if ( stopHuman >= 0 ) // must stop human from winning
- a[stopHuman] = TicTacButton::Cross;
- else if ( i == numButtons ) { // tried all alternatives
- if ( altc > 0 ) // set random piece
- a[altv[rand()%(altc--)]] = TicTacButton::Cross;
- if ( altc == 0 ) { // no more blanks
- st = NobodyWon;
- emit finished();
- }
+ if ( stopHuman >= 0 ) // must stop human from winning
+ a[stopHuman] = TicTacButton::Cross;
+ else if ( i == numButtons ) { // tried all alternatives
+ if ( altc > 0 ) // set random piece
+ a[altv[rand()%(altc--)]] = TicTacButton::Cross;
+ if ( altc == 0 ) { // no more blanks
+ st = NobodyWon;
+ emit finished();
+ }
}
- *btArray = a; // update model
- updateButtons(); // update buttons
+ *btArray = a; // update model
+ updateButtons(); // update buttons
delete[] altv;
}
@@ -288,40 +289,40 @@ void TicTacGameBoard::computerMove()
//
TicTacToe::TicTacToe( int boardSize, QWidget *parent, const char *name )
- : QWidget( parent, name )
+ : QWidget( parent, name )
{
QVBoxLayout * l = new QVBoxLayout( this, 6 );
- // Create a message label
+ // Create a message label
message = new QLabel( this );
message->setFrameStyle( QFrame::WinPanel | QFrame::Sunken );
message->setAlignment( AlignCenter );
l->addWidget( message );
- // Create the game board and connect the signal finished() to this
- // gameOver() slot
+ // Create the game board and connect the signal finished() to this
+ // gameOver() slot
board = new TicTacGameBoard( boardSize, this );
connect( board, SIGNAL(finished()), SLOT(gameOver()) );
l->addWidget( board );
- // Create a horizontal frame line
+ // Create a horizontal frame line
QFrame *line = new QFrame( this );
line->setFrameStyle( QFrame::HLine | QFrame::Sunken );
l->addWidget( line );
- // Create the combo box for deciding who should start, and
- // connect its clicked() signals to the buttonClicked() slot
+ // Create the combo box for deciding who should start, and
+ // connect its clicked() signals to the buttonClicked() slot
whoStarts = new QComboBox( this );
whoStarts->insertItem( tr( "Computer starts" ) );
whoStarts->insertItem( tr( "Human starts" ) );
l->addWidget( whoStarts );
- // Create the push buttons and connect their clicked() signals
- // to this right slots.
+ // Create the push buttons and connect their clicked() signals
+ // to this right slots.
newGame = new QPushButton( tr( "Play!" ), this );
connect( newGame, SIGNAL(clicked()), SLOT(newGameClicked()) );
@@ -331,13 +332,13 @@ TicTacToe::TicTacToe( int boardSize, QWidget *parent, const char *name )
l->addLayout( b );
b->addWidget( newGame );
b->addWidget( quit );
-showMaximized();
+ showMaximized();
newState();
}
// --------------------------------------------------------------------------
-// TicTacToe::newGameClicked() - SLOT
+// TicTacToe::newGameClicked() - SLOT
//
// This slot is activated when the new game button is clicked.
//
@@ -351,7 +352,7 @@ void TicTacToe::newGameClicked()
// --------------------------------------------------------------------------
-// TicTacToe::gameOver() - SLOT
+// TicTacToe::gameOver() - SLOT
//
// This slot is activated when the TicTacGameBoard emits the signal
// "finished()", i.e. when a player has won or when it is a draw.
@@ -359,7 +360,7 @@ void TicTacToe::newGameClicked()
void TicTacToe::gameOver()
{
- newState(); // update text box
+ newState(); // update text box
}
@@ -369,9 +370,12 @@ void TicTacToe::gameOver()
void TicTacToe::newState()
{
- static const char *msg[] = { // TicTacGameBoard::State texts
- "Click Play to start", "Make your move",
- "You won!", "Computer won!", "It's a draw" };
+ QStringList msg;
+ msg << tr( "Click Play to start")
+ << tr("Make your move")
+ << tr("You won!")
+ << tr("Computer won!")
+ << tr("It's a draw");
message->setText( msg[board->state()] );
return;
}