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
KUDAT: Sekurang-kurangnya dua penumpang parah apabila sebuah pesawat Twin Otters terhempas di Lapangan Terbang Kudat berhampiran Kampung Sin San dekat sini, jam 3.30 petang tadi.
Menurut Balai Bomba dan Penyelamat Kudat, kesemua 16 mangsa berjaya dikeluarkan daripada pesawat.
Menurut ketua misi menyelamat, Abd Mujun, seramai 10 anggota dikerahkan ke lokasi kejadian sejurus menerima panggilan kira-kira jam 2.54 petang.
Dilaporkan terdapat tumpahan minyak susulan nahas itu - bharian.com.my
Actor Aaron Aziz is reported to have died shortly after a snowboard accident earlier today - September 30, 2013.
The actor & novice snowboarder was vacationing at the Zermatt ski resort in Zermatt, Switzerland with family and friends. Witnesses indicate that Aaron Aziz lost control of his snowboard and struck a tree at a high rate of speed.
Aaron Aziz was air lifted by ski patrol teams to a local hospital, however, it is believed that the actor died instantly from the impact of the crash. The actor was wearing a helmet at the time of the accident and drugs and alcohol do not appear to have played any part in his death. - sumber http://aaron.aziz.mediafetcher.com/news/top_stories/actor_skiing.php
Sebelum ni cerita yang sama cuma nama berbeza Adam Sandler, tarikh 8 ogos 2013...
Minggu lepas Hacker Jerman menunjukkan bagaimana cara unlock iPhone 5s dengan Touch ID Fingerprint. Update terbaru iOS 7.0.2 Kumpulan dari Iran telah menunjukkan cara untuk Unlock dengan pelbagai cap jari.
Lelaki ini mengajar bola golf dan kepalanya ditimpa palang membuatkannya terjatuh dalam kesakitan. Dalam keadaan dia masih terlantar kerana sakit di kepala, kereta yang sedang menanti untuk masuk pula menggilis kakinya tidak lama kemudian.
Rasanya video ni fake!!
iPhone 5s sepatutnya ia begitu selamat dengan adanya sensor pengimbas cap jari(Touch ID fingerprint) tetapi hanya beberapa hari selepas telefon bimbit yang telah dijual ia telah digodam.
Sekumpulan penggodam Jerman dikenali sebagai Chaos Computer Club menemui cara mereka untuk menggodam peranti ini. Apa yang di perlukan adalah gam kayu, pencetak laser, dan kamera 5 megapiksel.
Untuk mengetahui prosedur sila lawat ke lamat ini - WMPoweruser