wxWidgets/demos/forty
Vadim Zeitlin 506e9b7ed2 rebaked using bakefile 0.2.5
git-svn-id: https://svn.wxwidgets.org/svn/wx/wxWidgets/trunk@56525 c3d73ce0-8a6f-49c7-b76d-6d57e0e08775
2008-10-27 16:40:51 +00:00
..
about.htm
canvas.cpp Better fix 2008-03-12 13:45:29 +00:00
canvas.h
card.cpp wxBLACK usage. 2006-06-07 13:26:00 +00:00
card.h Warning fixes found under hardest mode of OpenWatcom. Seems clean in Borland, MinGW and DMC. 2004-10-05 15:38:40 +00:00
cards.ico
forty_vc7.vcproj rebaked using bakefile 0.2.5 2008-10-27 16:40:51 +00:00
forty_vc8.vcproj rebaked using bakefile 0.2.5 2008-10-27 16:40:51 +00:00
forty_vc9.sln add VC9 project files (closes #9960) 2008-10-08 16:42:00 +00:00
forty_vc9.vcproj rebaked using bakefile 0.2.5 2008-10-27 16:40:51 +00:00
forty-icons.r
forty.bkl Add libs html and xml to bakefiles of samples/contribs/demos using lib adv 2005-10-23 21:52:24 +00:00
forty.cpp Better fix 2008-03-12 13:45:29 +00:00
forty.dsp regenerated makefiles with bkl-0.2.3 2008-01-23 12:13:07 +00:00
forty.h mark all dtors which are virtual because base class dtor is virtual explicitly virtual themselves 2006-09-05 20:47:48 +00:00
forty.r
forty.rc Use XPM for symbols and pictures on all platforms 2006-03-28 11:12:48 +00:00
forty.xpm made all XPM const to avoid warnings from mingw32 4.0 and adopt the code accordingly (patch 1872384) 2008-01-16 01:39:44 +00:00
fortyM5.xml
game.cpp replaced more int/longs with wxCoord 2007-05-10 01:46:57 +00:00
game.h mark all dtors which are virtual because base class dtor is virtual explicitly virtual themselves 2006-09-05 20:47:48 +00:00
makefile.bcc rebaked using bakefile 0.2.5 2008-10-27 16:40:51 +00:00
makefile.gcc rebaked using bakefile 0.2.5 2008-10-27 16:40:51 +00:00
Makefile.in rebaked using bakefile 0.2.5 2008-10-27 16:40:51 +00:00
makefile.unx
makefile.vc rebaked using bakefile 0.2.5 2008-10-27 16:40:51 +00:00
makefile.wat rebaked using bakefile 0.2.5 2008-10-27 16:40:51 +00:00
makemac6.mcp
pictures.xpm made all XPM const to avoid warnings from mingw32 4.0 and adopt the code accordingly (patch 1872384) 2008-01-16 01:39:44 +00:00
pile.cpp Nuke #pragma implementation/interface's 2005-09-23 12:56:45 +00:00
pile.h Warning fixes found under hardest mode of OpenWatcom. Seems clean in Borland, MinGW and DMC. 2004-10-05 15:38:40 +00:00
playerdg.cpp Fixed player dialog listbox size and app icon on wxGTK 2007-12-03 09:44:41 +00:00
playerdg.h Warning fixes found under hardest mode of OpenWatcom. Seems clean in Borland, MinGW and DMC. 2004-10-05 15:38:40 +00:00
readme.txt
scoredg.cpp GetBestFittingSize --> GetEffectiveMinSize 2006-10-31 08:50:17 +00:00
scoredg.h Warning fixes found under hardest mode of OpenWatcom. Seems clean in Borland, MinGW and DMC. 2004-10-05 15:38:40 +00:00
scorefil.cpp compilation fixes after string changes 2007-06-27 20:49:19 +00:00
scorefil.h
symbols.xpm made all XPM const to avoid warnings from mingw32 4.0 and adopt the code accordingly (patch 1872384) 2008-01-16 01:39:44 +00:00

Forty Thieves is a patience game played with two full packs of
cards. At the start of the game forty cards are dealt on the
eight 'bases' along the top of the window. The object of the
game is to place all the cards onto the eight 'foundations'. The
foundations are built starting with the ace and adding cards of
the same suit up to the king. Cards are dealt from the pack and
placed on the discard pile. Cards may be moved from the discard
pile or one of the bases to a base or a foundation. Only one
card can be moved at a time. Cards can only be placed on a base
if the top card of the base is of the same suit and is one
higher in pip value or the base is empty e.g. the eight of
spades can only be placed on top of the nine of spades.

When the mouse cursor is over a card which can be moved it
changes to the 'hand' cursor. The card can then be moved by
double clicking the left button.

The mouse cursor also changes to a hand when a card is dragged
by placing the cursor over the card and holding down the left
button. This feature can be enabled and disabled by selecting
the 'Helping hand' option from the Edit menu.

The 'foundations' are the eight piles of cards down the left
side of the window. When the game starts these piles are empty.
The object of the game is to place all the cards on the
foundations. An ace can be placed on any empty foundation. Other
cards can only be placed on a foundation if the top card is of
the same suit and is one lower in pip value e.g. the three of
clubs can be placed on the four of clubs.

The 'bases' are the ten piles of cards along the top of the
window. At the start of the game four cards are dealt face up on
each of the bases. A card can be added to a base if the base is
empty or if the top card is of the same suit and is one higher
in pip value e.g. the queen of hearts can be placed on the king
of hearts The top card of a base can be moved onto another base
or a foundation.

Cards can be only moved one at a time. The top card of the pack
can be dealt onto discard pile by placing the mouse cursor over
the pack and pressing the left button. The number of cards
remaining is displayed to the right of the pack.

Cards can be moved from the discard pile or the bases either by
'double-clicking' or by dragging. If the left button is
double-clicked when the mouse cursor is over a card and it can
move to another pile, it will do so. This is a quick way of
moving cards when their destination is unambiguous.

A card can be dragged by placing the mouse cursor over the card
and holding down the left button. The card will follow the mouse
cursor until the left button is released. If the card is over a
pile on which it can be placed it will be added to that pile,
otherwise it will be returned to the pile from which it was
dragged.

One point is scored for every card that is placed on a
foundation. Since there are two packs of 52 cards the maximum
score is 104. A record is kept of the number of games played,
the number of games won, the current score and the average
score. This information is displayed at bottom right of the
window and is stored on disk between games. A game is deemed to
have started if the cards have been dealt and any card has been
moved. If the game is abandoned before it is finished (i.e. by
starting a new game or closing window) it counts as a lost game.
New players can be added by selecting the 'Player' option from
the Game menu. A summary of players' scores can be displayed by
selecting the 'Scores...' option from the Game menu.

All moves are recorded and can be undone. To undo a move select
the undo menu item from the Edit menu. A quicker way of undoing
is to press the right mouse button (it doesn't matter where the
mouse cursor is). Right button undo can be enabled and disabled
by selecting the 'Right button undo' option from the Edit menu.
Pressing the right mouse button with the control key pressed
re-does a previously undone move.

An empty base or two is very useful as it gives the opportunity
to unscramble other bases. Try not to build onto kings which
obscure valuable cards as it will be difficult to get to them
later. The undo facility is very useful for going back and using
'hindsight'.

Don't be put off if you can't win every game. I reckon winning 1
in 10 is pretty good (winning 1 in 3 is excellent).