Click here to Skip to main content
13,597,610 members
Click here to Skip to main content
Add your own
alternative version


16 bookmarked
Posted 30 May 2004
Licenced CPOL

Minesweeper and MinsweeperFlags (a multiplayer version) in one for PocketPC

, 30 May 2004
Rate this:
Please Sign up or sign in to vote.
Pocket PC .NET Compact Framework version of Minesweeper and MinsweeperFlags (multiplayer) game in one


This is my version of an old, well known game and a contribution to the CodeProject Mobile Developer competition. This is my second .NET Compact Framework based application (The first was of course a HelloWorld.) and this is also my first CodeProject article.

One thing I always missed on my PocketPC was our old sweet Minesweeper. So I have decided to invest a couple evenings to play with Visual Studio .NET. After one week I had a normal single player version.

The second step was a multiplayer modification of this game (like MinsweeperFlags from MSN Messenger). A hot seat version (both players on the same Pocket PC) was ready very soon, but my goal was a game over a Network or an IrDA. I have written the network layer and ... that's where I am staying now.

Game rules

Single player

Everyone knows simple rules of Minesweeper. My single player mode works the same way.


Because MinesweeperFlags is not so well known as the classical Minesweeper I'd like to say some words about its rules. There are two players Red and Blue one. Game objective is to find and flag mines that are concealed on the board. The first player to flag more than half of the mines wins. Click your left mouse button on a square to see if a mine is there. If a mine is there it will be revealed and your colored flag will be planted on it. You will then get another turn. If the square does not contain a mine, your turn will be over. Each player receives one point for each mine they flagged.

Using the code

In fact the whole Program can be divided into three layers.

  • The first layers is implemented in the Field class. It describes location of mines on the field and a current state of each cell. So this class is only design as data storage structure.

  • The game logic and rules are implemented in SinglePlayerGame and MultiplayerGame classes. These classes are derived from an abstract class GameBase, which implements common behaviour for both game versions. All these classes implement the IGame interface. It makes possible to operate with them from GUI without exactly knowing (in most cases) which version is currently running.

I use events to simplify the intaraction between layers. For example OnCellChanged event will be thrown to notify the presentation layer that content of a specific cell was changed and it must be redrawn.

public class SinglePlayerGame: GameBase

  public SinglePlayerGame(byte aWidth, byte aHeight,
   byte aBombCount): base(aWidth, aHeight, aBombCount)

  public override void ClickCell(byte x, byte y)
    // Open a cell and open all neigbors whenn needed.
    // This all is implemented in our base class.

    // The condition to loose, because it is game version secific.
    if (_field.Bombs[x,y]==Field.ISBOMB) GameOver(Player.None);
    // The condition to win, because it is game version secific.
    if (ClosedCount==_field.BombCount ) GameOver(CurrentPlayer);

  // The SetFlag behavior is different in both versions
  // that is why it must be implemented here.
  public override void SetFlag(byte x, byte y)
    // When cell is already opened do nothing
    if (_field.CellStates[x,y]==CellState.Open) return;
    // remember cell state before changes are made
    CellState BeforeState = _field.CellStates[x,y];
    // Unmark when already marked
    if (_field.CellStates[x,y]==GetFlagColorOfCurrentPlayer())
    // Mark when not marked
    else _field.CellStates[x,y]=GetFlagColorOfCurrentPlayer();
    // Inform others that this cell was modified.
    CellChanged(x,y, BeforeState, _field.CellStates[x,y]);
  • The GamePresentation class is responsible for drawing the game field and the interaction with the main form. The whole user interaction, sound effects and other stuff like that are concentrated in frmMain.
  • There is in fact one more layer (UdpComm class) to implement network communication. In the current version of this program it will be used only in frmStartMultiplayer form to detect existence of a network, and to perform a handshake.

Points of Interest

There are some interesting issues I'd like to share with you.

  • Application Icon on Pocket PC - When a windows application has only one large icon (32 × 32 pixels) and it must be shown small icon view it will be scaled automatically. To my surprise it was not a case with my Pocket PC 2002, it showed only left top 16 × 16 pixel rectangle. That is why I had to create both 32 × 32 and 16 × 16 icons.
  • ImageButton - As you probably know there is no ImageButton in Compact Framework. My initial idea was to present cells as ImageButtons and change image when necessary. I found a Microsoft article How to Create a Microsoft .NET Compact Framework-based Image Button and used their implementation of ImageButton. To increase the performance by drawing the field I switched to manual drawing using Graphics. This way it works considerably faster.
  • Threading in Compact Framework - To simplify the development I wrote and tested almost all modules (except GUI of course) in a Windows application. Then I have transferred this code into Mobile application. In most cases it worked without any changes, but for instance I have discovered that Thread in Compact Framework has for instance no IsAlive property and no Abort method. So when programming Compact Framework always think about it's limitations.
  • Moreover there are number of useful things you can find in the source code. For example working with embedded resources or playing a WAV file asynchronously. To my surprise the 2002 emulator plays normal system sounds but not my WAVs. On the other hand 2003 emulator does both.


This article, along with any associated source code and files, is licensed under The Code Project Open License (CPOL)


About the Author

George Mamaladze
Software Developer
Germany Germany
Tweeter: @gmamaladze
Google+: gmamaladze

You may also be interested in...


Comments and Discussions

GeneralI hate to be such a nitpick Pin
Jörgen Sigvardsson31-May-04 9:35
memberJörgen Sigvardsson31-May-04 9:35 
GeneralRe: I hate to be such a nitpick Pin
George Mamaladze31-May-04 11:37
memberGeorge Mamaladze31-May-04 11:37 
GeneralRe: I hate to be such a nitpick Pin
Vladimir Ralev31-May-04 19:02
memberVladimir Ralev31-May-04 19:02 

General General    News News    Suggestion Suggestion    Question Question    Bug Bug    Answer Answer    Joke Joke    Praise Praise    Rant Rant    Admin Admin   

Use Ctrl+Left/Right to switch messages, Ctrl+Up/Down to switch threads, Ctrl+Shift+Left/Right to switch pages.

Permalink | Advertise | Privacy | Cookies | Terms of Use | Mobile
Web01 | 2.8.180621.3 | Last Updated 31 May 2004
Article Copyright 2004 by George Mamaladze
Everything else Copyright © CodeProject, 1999-2018
Layout: fixed | fluid