-rw-r--r-- | noncore/games/tetrix/qtetrix.cpp | 58 | ||||
-rw-r--r-- | noncore/games/tetrix/qtetrix.h | 8 | ||||
-rw-r--r-- | noncore/games/tetrix/qtetrixb.cpp | 4 |
3 files changed, 58 insertions, 12 deletions
diff --git a/noncore/games/tetrix/qtetrix.cpp b/noncore/games/tetrix/qtetrix.cpp index 20cf1a7..a6a5f34 100644 --- a/noncore/games/tetrix/qtetrix.cpp +++ b/noncore/games/tetrix/qtetrix.cpp @@ -23,12 +23,13 @@ #include <qpe/resource.h> #include <qlabel.h> #include <qdatetime.h> #include <qlayout.h> +#include <qtimer.h> #include "ohighscoredlg.h" void drawTetrixButton( QPainter *p, int x, int y, int w, int h, const QColor *color ) @@ -104,12 +105,14 @@ QTetrix::QTetrix( QWidget *parent, const char *name, WFlags f ) (24+60+60) ); QWidget *gameArea = new QWidget( this ); setCentralWidget( gameArea ); QGridLayout *gl = new QGridLayout( gameArea, 5, 3, 8 ); + gl->setColStretch( 1, 5 ); + gl->setColStretch( 2, 10 ); QLabel *l; l = new QLabel( tr("Next"), gameArea ); gl->addWidget( l, 0, 0 ); showNext = new ShowNextPiece(gameArea); showNext->setBackgroundColor(QColor(0,0,0)); @@ -127,39 +130,39 @@ QTetrix::QTetrix( QWidget *parent, const char *name, WFlags f ) gl->addWidget( l, 3, 0 ); showLines = new QLabel(gameArea); gl->addWidget( showLines, 3, 1 ); board = new QTetrixBoard(gameArea); board->setBackgroundColor(QColor(0,0,0)); - board->setFixedWidth( 124 ); gl->addMultiCellWidget( board, 0, 4, 2, 2 ); - gl->addColSpacing( 2, 100 ); - gl->addColSpacing( 1, 35 ); - gl->addRowSpacing( 0, 35 ); QPushButton *pb = new QPushButton( tr("Start"), gameArea ); pb->setFocusPolicy( NoFocus ); connect( pb, SIGNAL( clicked() ), board, SLOT( start() ) ); gl->addMultiCellWidget( pb, 4, 4, 0, 1 ); connect( board, SIGNAL(gameOverSignal()), SLOT(gameOver()) ); - connect( board, SIGNAL(drawNextSquareSignal(int,int,QColor*)), showNext, - SLOT(drawNextSquare(int,int,QColor*)) ); + connect( board, SIGNAL(drawNextSquareSignal(int,int,QColor*)), this, + SLOT(setNext(int,int,QColor*)) ); connect( showNext, SIGNAL(update()), board, SLOT(updateNext()) ); - connect( board, SIGNAL(updateScoreSignal(int)), showScore, - SLOT(setNum(int)) ); - connect( board, SIGNAL(updateLevelSignal(int)), showLevel, - SLOT(setNum(int))); - connect( board, SIGNAL(updateRemovedSignal(int)), showLines, - SLOT(setNum(int))); + connect( board, SIGNAL(updateScoreSignal(int)), showScore, SLOT(setNum(int)) ); + connect( board, SIGNAL(updateLevelSignal(int)), showLevel, SLOT(setNum(int)) ); + connect( board, SIGNAL(updateRemovedSignal(int)), showLines, SLOT(setNum(int)) ); showScore->setNum( 0 ); showLevel->setNum( 0 ); showLines->setNum( 0 ); board->revealNextPiece(TRUE); board->setFocusPolicy( StrongFocus ); + + QTimer::singleShot( -1, this, SLOT(setup()) ); +} + +void QTetrix::setup() +{ + resizeEvent( 0x0 ); } void QTetrix::gameOver() { OHighscore *hs = new OHighscore( showScore->text().toInt() , showLevel->text().toInt() ); if ( hs->isNewhighscore ) @@ -169,6 +172,37 @@ void QTetrix::gameOver() } void QTetrix::quit() { close(); } + +void QTetrix::setNext( int x, int y, QColor *color ) +{ + resizeEvent( 0x0 ); + showNext->drawNextSquare( x, y, color ); +} + +void QTetrix::resizeEvent( QResizeEvent * ) +{ + // Set size of board + int widthFactor = board->QFrame::width() / board->boardWidth(); + if ( widthFactor < 1 ) + widthFactor = 1; + int heightFactor = board->QFrame::height() / board->boardHeight(); + if ( heightFactor < 1 ) + heightFactor = 1; + widthFactor > heightFactor ? board->resize( heightFactor * board->boardWidth() + 2, + heightFactor * board->boardHeight() + 2 ) + : board->resize( widthFactor * board->boardWidth() + 2, + widthFactor * board->boardHeight() + 2 ); + + // Set size of preview widget + widthFactor = showNext->width() / 5; + if ( widthFactor < 1 ) + widthFactor = 1; + heightFactor = showNext->height() / 6; + if ( heightFactor < 1 ) + heightFactor = 1; + widthFactor > heightFactor ? showNext->resize( heightFactor * 5 + 2, heightFactor * 6 + 2 ) + : showNext->resize( widthFactor * 5 + 2, widthFactor * 6 + 2 ); +} diff --git a/noncore/games/tetrix/qtetrix.h b/noncore/games/tetrix/qtetrix.h index c8959c5..8c44b77 100644 --- a/noncore/games/tetrix/qtetrix.h +++ b/noncore/games/tetrix/qtetrix.h @@ -54,16 +54,24 @@ class QTetrix : public QMainWindow public: static QString appName() { return QString::fromLatin1("tetrix"); } QTetrix( QWidget *parent=0, const char *name=0, WFlags f=0 ); void startGame() { board->startGame(); } public slots: + void setup(); void gameOver(); void quit(); + + void setNext( int x, int y, QColor *color ); +// void setScore( int score ); +// void setLevel( int level ); +// void setLines( int lines ); + private: void keyPressEvent( QKeyEvent *e ) { board->keyPressEvent(e); } + void resizeEvent( QResizeEvent * ); QTetrixBoard *board; ShowNextPiece *showNext; QLabel *showScore; QLabel *showLevel; QLabel *showLines; diff --git a/noncore/games/tetrix/qtetrixb.cpp b/noncore/games/tetrix/qtetrixb.cpp index 3c179df..8c41fb2 100644 --- a/noncore/games/tetrix/qtetrixb.cpp +++ b/noncore/games/tetrix/qtetrixb.cpp @@ -53,12 +53,13 @@ QTetrixBoard::QTetrixBoard( QWidget *p, const char *name ) void QTetrixBoard::startGame(int gameType,int fillRandomLines) { if ( isPaused ) return; // ignore if game is paused noGame = FALSE; + GenericTetrix::startGame( gameType, fillRandomLines ); // Note that the timer is started by updateLevel! } void QTetrixBoard::pause() @@ -203,14 +204,17 @@ void QTetrixBoard::drawContents( QPainter *p ) return; } void QTetrixBoard::resizeEvent(QResizeEvent *e) { QSize sz = e->size(); + blockWidth = (sz.width() - 2)/10; blockHeight = (sz.height() - 2)/22; +/* blockWidth > blockHeight ? blockWidth = blockHeight + : blockHeight = blockWidth;*/ xOffset = 1; //yOffset = 1; yOffset = (sz.height() - 2) - (blockHeight *22); } void QTetrixBoard::keyPressEvent( QKeyEvent *e ) |