summaryrefslogtreecommitdiff
Unidiff
Diffstat (more/less context) (ignore whitespace changes)
-rw-r--r--noncore/games/solitaire/patiencecardgame.cpp3
1 files changed, 3 insertions, 0 deletions
diff --git a/noncore/games/solitaire/patiencecardgame.cpp b/noncore/games/solitaire/patiencecardgame.cpp
index 1501d2f..fc91b26 100644
--- a/noncore/games/solitaire/patiencecardgame.cpp
+++ b/noncore/games/solitaire/patiencecardgame.cpp
@@ -69,189 +69,192 @@ PatienceCardGame::~PatienceCardGame()
69 delete faceUpDealingPile; 69 delete faceUpDealingPile;
70} 70}
71 71
72 72
73void PatienceCardGame::deal(void) 73void PatienceCardGame::deal(void)
74{ 74{
75 highestZ = 1; 75 highestZ = 1;
76 int t = 0; 76 int t = 0;
77 77
78 beginDealing(); 78 beginDealing();
79 79
80 for (int i = 0; i < 7; i++) { 80 for (int i = 0; i < 7; i++) {
81 cards[t]->setFace(TRUE); 81 cards[t]->setFace(TRUE);
82 for (int k = i; k < 7; k++, t++) { 82 for (int k = i; k < 7; k++, t++) {
83 Card *card = cards[t]; 83 Card *card = cards[t];
84 workingPiles[k]->addCardToTop(card); 84 workingPiles[k]->addCardToTop(card);
85 card->setCardPile( workingPiles[k] ); 85 card->setCardPile( workingPiles[k] );
86 QPoint p = workingPiles[k]->getCardPos( card ); 86 QPoint p = workingPiles[k]->getCardPos( card );
87 card->setPos( p.x(), p.y(), highestZ ); 87 card->setPos( p.x(), p.y(), highestZ );
88 card->showCard(); 88 card->showCard();
89 highestZ++; 89 highestZ++;
90 } 90 }
91 } 91 }
92 92
93 for ( ; t < 52; t++) { 93 for ( ; t < 52; t++) {
94 Card *card = cards[t]; 94 Card *card = cards[t];
95 faceDownDealingPile->addCardToTop(card); 95 faceDownDealingPile->addCardToTop(card);
96 card->setCardPile( faceDownDealingPile ); 96 card->setCardPile( faceDownDealingPile );
97 QPoint p = faceDownDealingPile->getCardPos( card ); 97 QPoint p = faceDownDealingPile->getCardPos( card );
98 card->setPos( p.x(), p.y(), highestZ ); 98 card->setPos( p.x(), p.y(), highestZ );
99 card->showCard(); 99 card->showCard();
100 highestZ++; 100 highestZ++;
101 } 101 }
102 102
103 endDealing(); 103 endDealing();
104} 104}
105 105
106 106
107void PatienceCardGame::readConfig( Config& cfg ) 107void PatienceCardGame::readConfig( Config& cfg )
108{ 108{
109 cfg.setGroup("GameState"); 109 cfg.setGroup("GameState");
110 110
111 // Do we have a config file to read in? 111 // Do we have a config file to read in?
112 if ( !cfg.hasKey("numberOfTimesThroughDeck") ) { 112 if ( !cfg.hasKey("numberOfTimesThroughDeck") ) {
113 // if not, create a new game 113 // if not, create a new game
114 newGame(); 114 newGame();
115 return; 115 return;
116 } 116 }
117 // We have a config file, lets read it in and use it 117 // We have a config file, lets read it in and use it
118 118
119 // Create Cards, but don't shuffle or deal them yet 119 // Create Cards, but don't shuffle or deal them yet
120 createDeck(); 120 createDeck();
121 121
122 // How many times through the deck have we been 122 // How many times through the deck have we been
123 numberOfTimesThroughDeck = cfg.readNumEntry("NumberOfTimesThroughDeck"); 123 numberOfTimesThroughDeck = cfg.readNumEntry("NumberOfTimesThroughDeck");
124 124
125 // restore state to the circle/cross under the dealing pile 125 // restore state to the circle/cross under the dealing pile
126 if ( canTurnOverDeck() ) 126 if ( canTurnOverDeck() )
127 circleCross->setCircle(); 127 circleCross->setCircle();
128 else 128 else
129 circleCross->setCross(); 129 circleCross->setCross();
130 130
131 // Move the cards to their piles (deal them to their previous places) 131 // Move the cards to their piles (deal them to their previous places)
132 beginDealing(); 132 beginDealing();
133 133
134 highestZ = 1; 134 highestZ = 1;
135 135
136 for (int k = 0; k < 7; k++) { 136 for (int k = 0; k < 7; k++) {
137 QString pile; 137 QString pile;
138 pile.sprintf( "WorkingPile%i", k ); 138 pile.sprintf( "WorkingPile%i", k );
139 readPile( cfg, workingPiles[k], pile, highestZ ); 139 readPile( cfg, workingPiles[k], pile, highestZ );
140 } 140 }
141 141
142 for (int k = 0; k < 4; k++) { 142 for (int k = 0; k < 4; k++) {
143 QString pile; 143 QString pile;
144 pile.sprintf( "DiscardPile%i", k ); 144 pile.sprintf( "DiscardPile%i", k );
145 readPile( cfg, discardPiles[k], pile, highestZ ); 145 readPile( cfg, discardPiles[k], pile, highestZ );
146 } 146 }
147 147
148 readPile( cfg, faceDownDealingPile, "FaceDownDealingPile", highestZ ); 148 readPile( cfg, faceDownDealingPile, "FaceDownDealingPile", highestZ );
149 readPile( cfg, faceUpDealingPile, "FaceUpDealingPile", highestZ ); 149 readPile( cfg, faceUpDealingPile, "FaceUpDealingPile", highestZ );
150 150
151 highestZ++; 151 highestZ++;
152 152
153 endDealing(); 153 endDealing();
154} 154}
155 155
156 156
157void PatienceCardGame::writeConfig( Config& cfg ) 157void PatienceCardGame::writeConfig( Config& cfg )
158{ 158{
159 cfg.setGroup("GameState"); 159 cfg.setGroup("GameState");
160 cfg.writeEntry("numberOfTimesThroughDeck", numberOfTimesThroughDeck); 160 cfg.writeEntry("numberOfTimesThroughDeck", numberOfTimesThroughDeck);
161 161
162 for ( int i = 0; i < 7; i++ ) { 162 for ( int i = 0; i < 7; i++ ) {
163 QString pile; 163 QString pile;
164 pile.sprintf( "WorkingPile%i", i ); 164 pile.sprintf( "WorkingPile%i", i );
165 workingPiles[i]->writeConfig( cfg, pile ); 165 workingPiles[i]->writeConfig( cfg, pile );
166 } 166 }
167 for ( int i = 0; i < 4; i++ ) { 167 for ( int i = 0; i < 4; i++ ) {
168 QString pile; 168 QString pile;
169 pile.sprintf( "DiscardPile%i", i ); 169 pile.sprintf( "DiscardPile%i", i );
170 discardPiles[i]->writeConfig( cfg, pile ); 170 discardPiles[i]->writeConfig( cfg, pile );
171 } 171 }
172 faceDownDealingPile->writeConfig( cfg, "FaceDownDealingPile" ); 172 faceDownDealingPile->writeConfig( cfg, "FaceDownDealingPile" );
173 faceUpDealingPile->writeConfig( cfg, "FaceUpDealingPile" ); 173 faceUpDealingPile->writeConfig( cfg, "FaceUpDealingPile" );
174} 174}
175 175
176 176
177bool PatienceCardGame::mousePressCard( Card *card, QPoint p ) 177bool PatienceCardGame::mousePressCard( Card *card, QPoint p )
178{ 178{
179 Q_UNUSED(p); 179 Q_UNUSED(p);
180 180
181 CanvasCard *item = (CanvasCard *)card; 181 CanvasCard *item = (CanvasCard *)card;
182 if (item->isFacing() != TRUE) { 182 if (item->isFacing() != TRUE) {
183 // From facedown stack 183 // From facedown stack
184 if ((item->x() == 5) && ((int)item->y() == 10)) { 184 if ((item->x() == 5) && ((int)item->y() == 10)) {
185 item->setZ(highestZ); 185 item->setZ(highestZ);
186 highestZ++; 186 highestZ++;
187 187
188 // Added Code 188 // Added Code
189 faceDownDealingPile->removeCard(item); 189 faceDownDealingPile->removeCard(item);
190 faceUpDealingPile->addCardToTop(item); 190 faceUpDealingPile->addCardToTop(item);
191 item->setCardPile( faceUpDealingPile ); 191 item->setCardPile( faceUpDealingPile );
192 192
193 if ( qt_screen->deviceWidth() < 200 ) 193 if ( qt_screen->deviceWidth() < 200 )
194 item->flipTo( 30, (int)item->y() ); 194 item->flipTo( 30, (int)item->y() );
195 else 195 else
196 item->flipTo( 35, (int)item->y() ); 196 item->flipTo( 35, (int)item->y() );
197 } else {
198 // fix from cmader by tille
199 return false;
197 } 200 }
198 moving = NULL; 201 moving = NULL;
199 moved = FALSE; 202 moved = FALSE;
200 203
201 // move two other cards if we flip three at a time 204 // move two other cards if we flip three at a time
202 int flipped = 1; 205 int flipped = 1;
203 QCanvasItemList l = canvas()->collisions( p ); 206 QCanvasItemList l = canvas()->collisions( p );
204 for (QCanvasItemList::Iterator it = l.begin(); (it != l.end()) && (flipped != cardsDrawn()); ++it) { 207 for (QCanvasItemList::Iterator it = l.begin(); (it != l.end()) && (flipped != cardsDrawn()); ++it) {
205 if ( (*it)->rtti() == canvasCardId ) { 208 if ( (*it)->rtti() == canvasCardId ) {
206 CanvasCard *item = (CanvasCard *)*it; 209 CanvasCard *item = (CanvasCard *)*it;
207 if (item->animated()) 210 if (item->animated())
208 continue; 211 continue;
209 item->setZ(highestZ); 212 item->setZ(highestZ);
210 highestZ++; 213 highestZ++;
211 flipped++; 214 flipped++;
212 215
213 // Added Code 216 // Added Code
214 faceDownDealingPile->removeCard(item); 217 faceDownDealingPile->removeCard(item);
215 faceUpDealingPile->addCardToTop(item); 218 faceUpDealingPile->addCardToTop(item);
216 item->setCardPile( faceUpDealingPile ); 219 item->setCardPile( faceUpDealingPile );
217 220
218 if ( qt_screen->deviceWidth() < 200 ) 221 if ( qt_screen->deviceWidth() < 200 )
219 item->flipTo( 30, (int)item->y(), 8 * flipped ); 222 item->flipTo( 30, (int)item->y(), 8 * flipped );
220 else 223 else
221 item->flipTo( 35, (int)item->y(), 8 * flipped ); 224 item->flipTo( 35, (int)item->y(), 8 * flipped );
222 } 225 }
223 } 226 }
224 227
225 return TRUE; 228 return TRUE;
226 } 229 }
227 230
228 return FALSE; 231 return FALSE;
229} 232}
230 233
231 234
232void PatienceCardGame::mousePress(QPoint p) 235void PatienceCardGame::mousePress(QPoint p)
233{ 236{
234 if ( canTurnOverDeck() && 237 if ( canTurnOverDeck() &&
235 (p.x() > 5) && (p.x() < 28) && 238 (p.x() > 5) && (p.x() < 28) &&
236 (p.y() > 10) && (p.y() < 46) ) { 239 (p.y() > 10) && (p.y() < 46) ) {
237 240
238 beginDealing(); 241 beginDealing();
239 Card *card = faceUpDealingPile->cardOnTop(); 242 Card *card = faceUpDealingPile->cardOnTop();
240 while ( card ) { 243 while ( card ) {
241 card->setPos( 5, 10, highestZ ); 244 card->setPos( 5, 10, highestZ );
242 card->setFace( FALSE ); 245 card->setFace( FALSE );
243 faceUpDealingPile->removeCard( card ); 246 faceUpDealingPile->removeCard( card );
244 faceDownDealingPile->addCardToTop( card ); 247 faceDownDealingPile->addCardToTop( card );
245 card->setCardPile( faceDownDealingPile ); 248 card->setCardPile( faceDownDealingPile );
246 card = faceUpDealingPile->cardOnTop(); 249 card = faceUpDealingPile->cardOnTop();
247 highestZ++; 250 highestZ++;
248 } 251 }
249 endDealing(); 252 endDealing();
250 253
251 throughDeck(); 254 throughDeck();
252 255
253 moved = TRUE; 256 moved = TRUE;
254 } 257 }
255} 258}
256 259
257 260