Network Bandwidth Monitor [VB.NET]
Network Bandwidth Monitor
Download Source Code Link
NetworkBandwidth.vb
| Screen Shot | 
NetworkBandwidth.vb
Imports System.Text.RegularExpressions
Imports System.Net.NetworkInformation
Public Class NetworkBandwidth
    Private Adapters As NetworkInterface()
    Public Sub New() 'Constructer
    End Sub
    Public Function GetNetInteface() As List(Of NetworkInterface)
        Adapters = NetworkInterface.GetAllNetworkInterfaces
        Dim NetList As New List(Of NetworkInterface)
        Dim NetInterfaceFilter As NetworkInterfaceType() = {NetworkInterfaceType.Ethernet, NetworkInterfaceType.Ppp, NetworkInterfaceType.Wireless80211}
        For Each adapter As NetworkInterface In Adapters
            If inArrayNetType(NetInterfaceFilter, adapter.NetworkInterfaceType) Then
                NetList.Add(adapter)
            End If
        Next
        Return NetList
    End Function
    Private Function inArrayNetType(ByVal arr As NetworkInterfaceType(), ByVal match As NetworkInterfaceType) As Boolean
        For Each nettype As NetworkInterfaceType In arr
            If nettype = match Then
                Return True
            End If
        Next
        Return False
    End Function
    Public Function GetExtIpAddr() As String
        Try
            Dim ExternalIP As String
            ExternalIP = (New Net.WebClient()).DownloadString("http://checkip.dyndns.org/")
            ExternalIP = (New Regex("\d{1,3}\.\d{1,3}\.\d{1,3}\.\d{1,3}")) _
                         .Matches(ExternalIP)(0).ToString()
            Return ExternalIP
        Catch
            Return "No Connection"
        End Try
    End Function
End Class
mainForm.vb
Imports System.Net.NetworkInformation
Imports System.Text.RegularExpressions
Imports System.Net
Public Class mainForm
    Dim Adapters As NetworkInterface() = NetworkInterface.GetAllNetworkInterfaces()
    Private CurrentNetworkInterface As NetworkInterface
    Private InitNicStats As Boolean = False
    Delegate Sub FuncCallback(ByRef obj As Object, ByVal text As String)
    Dim Thread As Threading.Thread = Nothing
    Dim NetworkBW As New NetworkBandwidth
    Event NetChangedHandler As NetworkInformation.NetworkAvailabilityChangedEventHandler
    Private Sub mainForm_FormClosing(ByVal sender As Object, ByVal e As System.Windows.Forms.FormClosingEventArgs) Handles Me.FormClosing
        Try
            Thread.Abort()
        Catch ex As Exception
        End Try
    End Sub
    Private Sub mainForm_Load(ByVal sender As System.Object, ByVal e As System.EventArgs) Handles MyBase.Load
        LoadNicComboBox()
        Thread = New Threading.Thread(AddressOf UpdateExtIpAddr)
        Thread.IsBackground = True
        Thread.Start()
        AddHandler NetworkChange.NetworkAvailabilityChanged, AddressOf OnNetWorkChanged_Event
        AddHandler NetworkChange.NetworkAddressChanged, AddressOf OnNetworkAddrChanged_Event
    End Sub
    Private Sub LoadNicComboBox()
        Adapters = NetworkInterface.GetAllNetworkInterfaces
        Dim NetInterfaceFilter As NetworkInterfaceType() = {NetworkInterfaceType.Ethernet, NetworkInterfaceType.Ppp, NetworkInterfaceType.Wireless80211}
        If NICComboBox.InvokeRequired Then
            Dim d As New FuncCallback(AddressOf LoadNicComboBox)
            Me.Invoke(d, New Object() {Nothing, Nothing})
            'Invoke(New MethodInvoker(AddressOf LoadNicComboBox))
        Else
            NICComboBox.DataSource = NetworkBW.GetNetInteface
            NICComboBox.DisplayMember = "Name"
            NICComboBox.ValueMember = "Id"
        End If
    End Sub
    Private Function inArrayNetType(ByVal arr As NetworkInterfaceType(), ByVal match As NetworkInterfaceType) As Boolean
        For Each nettype As NetworkInterfaceType In arr
            If nettype = match Then
                Return True
            End If
        Next
        Return False
    End Function
    Private Sub NICComboBox_SelectedIndexChanged(ByVal sender As System.Object, ByVal e As System.EventArgs) Handles NICComboBox.SelectedIndexChanged
        CurrentNetworkInterface = NICComboBox.SelectedItem
        Dim IpInterface As IPInterfaceProperties = CurrentNetworkInterface.GetIPProperties
        Dim UnicastIpaddr As UnicastIPAddressInformationCollection = IpInterface.UnicastAddresses
        If UnicastIpaddr.Count > 1 Then
            IpaddrLabel.Text = UnicastIpaddr(1).Address.ToString
        Else
            IpaddrLabel.Text = UnicastIpaddr(0).Address.ToString
        End If
        'UploadLabel.Text = BytesConverter(NicStats.BytesSent)
        'DownloadLabel.Text = BytesConverter(NicStats.BytesReceived)
        InitNicStats = False
    End Sub
    Public Function BytesConverter(ByVal bytes As Integer) As String
        Dim KB As Integer = 1024
        Dim MB As Integer = KB * KB
        Dim GB As Integer = KB * KB * KB
        Dim returnVal As String = "0 Bytes"
        Select Case bytes
            Case Is <= KB
                returnVal = bytes & " Bytes"
            Case Is > GB
                returnVal = (bytes / KB / KB / KB).ToString("0.00") & " KB"
            Case Is > MB
                returnVal = (bytes / KB / KB).ToString("0.00") & " MB"
            Case Is > KB
                returnVal = (bytes / KB).ToString("0.00") & " KB"
        End Select
        Return returnVal.ToString
    End Function
    Private Sub BandwidthPerSec()
        Try
            Dim NicStats As IPv4InterfaceStatistics = NICComboBox.SelectedItem.GetIPv4Statistics
            Static LastUpload As Integer = NicStats.BytesSent
            Static LastDownload As Integer = NicStats.BytesReceived
            If InitNicStats = True Then
                Dim Up = NicStats.BytesSent - LastUpload
                Dim Down = NicStats.BytesReceived - LastDownload
                UploadLabel.Text = BytesConverter(If(Up < 0, 0, Up)) & "/s"
                DownloadLabel.Text = BytesConverter(If(Down < 0, 0, Down)) & "/s"
            End If
            LastUpload = NicStats.BytesSent
            LastDownload = NicStats.BytesReceived
            TotalUploadLabel.Text = BytesConverter(NicStats.BytesSent)
            TotalDLLabel.Text = BytesConverter(NicStats.BytesReceived)
            InitNicStats = True
        Catch ex As Exception
            'BandwidthUpdateTimer.Stop()
            'MsgBox(ex.ToString)
        End Try
    End Sub
    Private Sub BandwidthUpdateTimer_Tick(ByVal sender As System.Object, ByVal e As System.EventArgs) Handles BandwidthUpdateTimer.Tick
        If NICComboBox.SelectedIndex >= 0 Then
            BandwidthPerSec()
        End If
    End Sub
    Private Sub OnNetWorkChanged_Event(ByVal sender As Object, ByVal e As NetworkInformation.NetworkAvailabilityEventArgs) Handles Me.NetChangedHandler
        LoadNicComboBox()
    End Sub
    Private Sub OnNetworkAddrChanged_Event(ByVal sender As Object, ByVal e As EventArgs)
        LoadNicComboBox()
        'SetTextLabelDelegate(IpaddrLabel, "")
        Invoke(New MethodInvoker(Sub()
                                     Dim ip = (CType(NICComboBox.SelectedItem, NetworkInterface)).GetIPProperties.UnicastAddresses(0).Address.ToString
                                     IpaddrLabel.Text = ip
                                 End Sub))
    End Sub
    Private Sub UpdateExtIpAddr()
        'Dim ipaddr As String = NetworkBW.GetExtIpAddr
        If ExtIpLabel.InvokeRequired Then
            'Me.Invoke(New Action(Of String)(AddressOf UpdateExtIpAddr), IPAddr)
            Me.Invoke(New MethodInvoker(AddressOf UpdateExtIpAddr))
        Else
            ExtIpLabel.Text = NetworkBW.GetExtIpAddr
        End If
    End Sub
    Private Sub Button1_Click(ByVal sender As System.Object, ByVal e As System.EventArgs)
        NICComboBox.DataSource = NetworkBW.GetNetInteface
    End Sub
    Private Sub RefreshIpLinkLabel_LinkClicked(ByVal sender As System.Object, ByVal e As System.Windows.Forms.LinkLabelLinkClickedEventArgs) Handles RefreshIpLinkLabel.LinkClicked
        Try
            If Not Thread.IsAlive Then
                Thread = New Threading.Thread(AddressOf UpdateExtIpAddr)
                Thread.IsBackground = True
                Thread.Start()
            End If
        Catch ex As Exception
        End Try
    End Sub
End Class
 

 
  
  
  
 



