Click here to Skip to main content
65,938 articles
CodeProject is changing. Read more.
Articles / Languages / C#

A Vista Wireless Network Scanner

4.51/5 (21 votes)
26 Jun 20072 min read 1   11.6K  
A NetStumbler (sort of) for Vista

Screenshot - WifiScanner1.gif

Introduction

I recently got a new notebook and was routinely transferring all of my old, favourite utilities to it when I found that NetStumbler would not work with Vista. I saw some references to a poor-man's version with the following command line:

netsh wlan show networks mode=bssid

I decided to put it in a window, so here is my effort. For Microsoft documentation on netsh, see Windows Netsh.

The code

A timer on the Form calls the Scan() function every two seconds. The Scan() function first uses the Process() class to execute the netsh command with the command line parameters:

C#
Process proc = new Process();
proc.StartInfo.CreateNoWindow = true;
proc.StartInfo.FileName = "netsh";
proc.StartInfo.Arguments = "wlan show networks mode=bssid";
proc.StartInfo.RedirectStandardOutput = true;
proc.StartInfo.UseShellExecute = false;
proc.Start();
output = proc.StandardOutput.ReadToEnd();
proc.WaitForExit();

The output is then parsed line-by-line to build an array of currently active networks. This is presented in a listView using the MAC Address as the item text with sub-items for the rest of the information. Discovered networks that are not already in the listView are found using:

C#
ListViewItem SearchItem = new ListViewItem();
SearchItem = listView1.FindItemWithText(Networks[i, 0]);
if (SearchItem == null)
{
    // New discovery - add it to the list

Any networks already in the listView are updated. The signal level icon is generated by bitmaps on the listView:

C#
int SignalInt = Convert.ToInt32(Networks[i, 3].TrimEnd(' ').TrimEnd('%'));
if (SignalInt > 50) listView1.Items[listView1.Items.Count-1].ImageIndex = 0;
else . . .

The coloured icons represent the signal levels as:

Green Dot Greater than 50% Signal Level

Yellow Dot 41% to 50% Signal Level

Orange Dot 31% to 40% Signal Level

Red Dot 21% to 30% Signal Level

Dark Red Dot 1% to 20% Signal Level

Grey Dot No Signal

Points of interest

One annoyance with the listView control was flicker. Every Update() or Refresh() caused the whole list to be cleared and re-written. I used a tip from Don Koster and added his listViewNF class. Using this listViewNF class stopped the flicker by redrawing only the changed areas.

C#
class ListViewNF : System.Windows.Forms.ListView
{
    public ListViewNF()
    {
        //Activate double buffering
        this.SetStyle(ControlStyles.OptimizedDoubleBuffer | 
            ControlStyles.AllPaintingInWmPaint, true);

        //Enable the OnNotifyMessage event so we get a chance to filter out
        // Windows messages before they get to the Form's WndProc
        this.SetStyle(ControlStyles.EnableNotifyMessage, true);
    }

    protected override void OnNotifyMessage(Message m)
    {
        //Filter out the WM_ERASEBKGND message
        if (m.Msg != 0x14)
        {
            base.OnNotifyMessage(m);
        }
    }

Known issues

The netsh command can sometimes be slow at updating the real network state. If a network is connected, it seems that the signal level displayed by netsh is not updated. Being connected also seems to alter the signal level of the connected network and other networks. When a connected network is turned off, it can take more than a minute for netsh -- or possibly this is a driver issue -- to remove the network from the output. Turning the wireless off and back on seems to force a new signal level. Also, sometimes the netsh command seems to change signal levels at every update. Once it gets in this mode, it will update the signal level for every command when operating on main power, but if it's operating on battery power it doesn't! The normal signal update interval seems to be one minute. I tested this using a Dell 640m notebook with an Intel 3945ABG wireless adapter.

History

  • June 23, 2007: New article.
  • June 24, 2007: Whoops! Bitmaps were not included in the demo project. This is fixed now.

License

This article has no explicit license attached to it but may contain usage terms in the article text or the download files themselves. If in doubt please contact the author via the discussion board below.

A list of licenses authors might use can be found here