Menu items can be selected
[ghostsoverboard] / seascene.cpp
index 0940694..81e4ace 100644 (file)
@@ -49,16 +49,28 @@ SeaScene::SeaScene(QObject *parent) :
 
     qsrand(QTime::currentTime().msec()+2);  //+2 to avoid setting it to 1
 
+    //connect selecting to menu handling (only menu items selectable)
+
+    connect(this,SIGNAL(selectionChanged()),this,SLOT(menuClicked()));
+
+
+
+
+
+
+
 
 
 }
 
-void SeaScene::setupMap(int ghosts, int rocks, int octopuses)
+void SeaScene::setupMap(int ghosts, int rocks, int octopuses, int octopusSpeed)
 {
     //empty the map
 
     clear();
 
+    createMenuItems();
+
     //empty the list of moving items
 
     movingItems_.clear();
@@ -121,7 +133,7 @@ void SeaScene::setupMap(int ghosts, int rocks, int octopuses)
             break;
 
     QPixmap octopusPixmap (":/pix/tursas.png");
-    Octopus * pOctopus = new Octopus(octopusPixmap,100);
+    Octopus * pOctopus = new Octopus(octopusPixmap,octopusSpeed);
     pOctopus->setData(0,"octopus");
     pOctopus->setPos(*pPosition);
     addItem(pOctopus);
@@ -177,6 +189,10 @@ void SeaScene::setupMap(int ghosts, int rocks, int octopuses)
     delete pPosition;
 }
 
+void SeaScene::setupMap(Level level)
+{
+    setupMap(level.getNumberOfGhosts(),level.getNumberOfRocks(),level.getNumberOfOctopuses(),level.getOctopusSpeed());
+}
 
 void SeaScene::spreadGhosts(int ghosts)
 {
@@ -300,13 +316,22 @@ void SeaScene::pause(bool paused)
      //       qDebug() << "starting to move again";
             emit pauseOff();
             screenLitKeeper_.keepScreenLit(true);
+            if (pPausetextItem_)
+                pPausetextItem_->hide();
         }
 
         else
         {
-     //       qDebug("about to stop movement");
+         qDebug("about to stop movement");
             emit pauseOn();
             screenLitKeeper_.keepScreenLit(false);
+            if (pPausetextItem_ != NULL)
+            {
+                qDebug() << "about to show the pause text";
+                pPausetextItem_->show();
+                qDebug() << "showing pause text";
+            }
+                else qDebug() << "No pause text available";
         }
 }
 
@@ -314,3 +339,91 @@ void SeaScene::vibrationActivate(bool on)
 {
     emit vibrationActivated(on);
 }
+
+void SeaScene::menuClicked()
+{
+    QList<QGraphicsItem *> items = selectedItems();
+
+    //if nothing selected (selection was removed) do nothing
+
+    if (items.isEmpty())
+        return;
+
+    //Tapping the screen unpaused the game, pause it again!
+
+
+
+    //Menu functions
+
+    QGraphicsItem* pItem = items.at(0);
+
+
+    if (pItem == pRestartGameItem_)
+    {
+        qDebug() << "game restart requested";
+    }
+
+    else if (pItem == pRestartLevelItem_)
+    {
+        qDebug() << "Level restart requested";
+
+    }
+
+    else if (pItem == pVibrateItem_)
+    {
+
+    }
+
+    else if (pItem == pAboutItem_)
+    {
+
+    }
+
+
+    //Selection is just used to get notice of being clicked, removed after use
+
+    clearSelection();
+
+}
+
+void SeaScene::showMenu()
+{
+    menuItems_.show();
+}
+
+void::SeaScene::hideMenu()
+{
+    menuItems_.hide();
+}
+
+void SeaScene::createMenuItems()
+{
+
+    pPausetextItem_ =  addSimpleText("Game paused. Tap to continue.");
+    pPausetextItem_->setZValue(1000);
+
+    //Menu items have pause text item as their parent and are thus added to scene automatically
+    //They are also shown and hidden with it, resulting in the menu being visble when the game is paused
+
+    pRestartGameItem_ = new QGraphicsSimpleTextItem("Restart game",pPausetextItem_);
+    pRestartGameItem_->setPos(0,200);
+    pRestartGameItem_->setZValue(1000);
+    pRestartGameItem_->setFlag(QGraphicsItem::ItemIsSelectable);
+
+    pRestartLevelItem_ = new QGraphicsSimpleTextItem("Restart level",pPausetextItem_);
+    pRestartLevelItem_->setPos(150,200);
+    pRestartLevelItem_->setZValue(1000);
+    pRestartLevelItem_->setFlag(QGraphicsItem::ItemIsSelectable);
+
+    QGraphicsRectItem * item = new QGraphicsRectItem(100,100,50,50,pPausetextItem_);
+    item->setFlag(QGraphicsItem::ItemIsSelectable);
+    QBrush brush;
+    brush.setStyle(Qt::SolidPattern);
+    item->setBrush(brush);
+
+
+
+
+
+
+}