725 lines
31 KiB
VB.net
725 lines
31 KiB
VB.net
Imports System.IO
|
|
Imports System.Net.Sockets
|
|
Imports System.Net
|
|
|
|
''' <summary>
|
|
''' This is the game screen that displays the online server listing.
|
|
''' </summary>
|
|
|
|
Public Class JoinServerScreen
|
|
|
|
Inherits Screen
|
|
|
|
Friend Shared BarAnimationState As Integer = 0
|
|
|
|
Dim mainTexture As Texture2D
|
|
|
|
Dim ServerList As New List(Of Server)
|
|
|
|
Dim selectIndex As Integer = 0
|
|
Dim scrollIndex As Integer = 0
|
|
Dim buttonIndex As Integer = 0
|
|
|
|
Dim LoadOnlineServers As Boolean = True
|
|
|
|
Public Shared SelectedServer As Server = Nothing
|
|
Public Shared Online As Boolean = False
|
|
|
|
Public Shared ClearThreadList As New List(Of Threading.Thread)
|
|
|
|
Public Sub New(ByVal currentScreeen As Screen)
|
|
mainTexture = TextureManager.GetTexture("GUI\Menus\Menu")
|
|
|
|
Me.PreScreen = currentScreeen
|
|
Me.Identification = Identifications.JoinServerScreen
|
|
Me.MouseVisible = True
|
|
Me.CanBePaused = False
|
|
Me.CanChat = False
|
|
End Sub
|
|
|
|
Private Sub LoadServers()
|
|
Me.ServerList.Clear()
|
|
|
|
Dim localServer As New Server("Local Server", "127.0.0.1")
|
|
localServer.IsLocal = True
|
|
|
|
Me.ServerList.Add(localServer)
|
|
|
|
If System.IO.File.Exists(GameController.GamePath & "\Save\server_list.dat") = False Then
|
|
System.IO.File.WriteAllText(GameController.GamePath & "\Save\server_list.dat", "Official Pokémon3D Server,karp.pokemon3d.net:15134")
|
|
End If
|
|
|
|
If LoadOnlineServers = True Then
|
|
Dim data() As String = System.IO.File.ReadAllLines(GameController.GamePath & "\Save\server_list.dat")
|
|
If data.Length > 0 Then
|
|
For Each line As String In data
|
|
If line.CountSeperators(",") = 1 Then
|
|
Dim Name As String = line.Split(CChar(","))(0)
|
|
Dim address As String = line.Split(CChar(","))(1)
|
|
Me.ServerList.Add(New Server(Name, address))
|
|
End If
|
|
Next
|
|
End If
|
|
End If
|
|
|
|
For Each s As Server In Me.ServerList
|
|
s.Ping()
|
|
Next
|
|
End Sub
|
|
|
|
Public Overrides Sub Draw()
|
|
Dim Tx As Integer = CInt(World.CurrentSeason)
|
|
Dim Ty As Integer = 0
|
|
If Tx > 1 Then
|
|
Tx -= 2
|
|
Ty += 1
|
|
End If
|
|
|
|
Dim ServersToDisplay As Integer = GetServersToDisplay()
|
|
|
|
Dim pattern As Texture2D = TextureManager.GetTexture("GUI\Menus\Menu", New Rectangle(160 + Tx * 16, Ty * 16, 16, 16), "")
|
|
For Dx = 0 To Core.ScreenSize.Width Step 128
|
|
For Dy = 0 To Core.ScreenSize.Height Step 128
|
|
Dim c As Color = Color.White
|
|
|
|
Core.SpriteBatch.DrawInterface(pattern, New Rectangle(Dx, Dy, 128, 128), c)
|
|
Next
|
|
Next
|
|
|
|
Canvas.DrawRectangle(New Rectangle(0, 72, Core.ScreenSize.Width, Core.ScreenSize.Height - 240), New Color(0, 0, 0, 128), True)
|
|
|
|
Core.SpriteBatch.DrawInterfaceString(FontManager.MainFont, "Join a server:", New Vector2(CInt(Core.ScreenSize.Width / 2 - FontManager.MainFont.MeasureString("Join A Server").X) + 4, 14 + 4), Color.Black, 0.0F, New Vector2(0), 2.0F, SpriteEffects.None, 0.0F)
|
|
Core.SpriteBatch.DrawInterfaceString(FontManager.MainFont, "Join a server:", New Vector2(CInt(Core.ScreenSize.Width / 2 - FontManager.MainFont.MeasureString("Join A Server").X), 14), Color.White, 0.0F, New Vector2(0), 2.0F, SpriteEffects.None, 0.0F)
|
|
|
|
Dim endX As Integer = ServerList.Count - 1
|
|
endX = CInt(MathHelper.Clamp(endX, 0, ServersToDisplay - 1))
|
|
|
|
If ServerList.Count > ServersToDisplay Then
|
|
Canvas.DrawScrollBar(New Vector2(CSng(Core.ScreenSize.Width / 2 + 266), 100), Me.ServerList.Count, 1, selectIndex, New Size(8, Core.ScreenSize.Height - 300), False, Color.Black, Color.Gray, True)
|
|
End If
|
|
|
|
' Draw default first.
|
|
For i = 0 To endX
|
|
Dim index As Integer = i + scrollIndex
|
|
|
|
If ServerList.Count - 1 >= index Then
|
|
ServerList(index).Draw(New Vector2(0, i * 100 + 100), index = selectIndex)
|
|
End If
|
|
Next
|
|
|
|
Dim CanvasTexture As Texture2D
|
|
Dim FontColor As Color
|
|
Dim FontShadow As Color = New Color(0, 0, 0, 0)
|
|
For i = 0 To 5
|
|
If i = Me.buttonIndex Then
|
|
CanvasTexture = TextureManager.GetTexture("GUI\Menus\Menu", New Rectangle(0, 48, 48, 48), "")
|
|
FontColor = Color.White
|
|
FontShadow.A = 255
|
|
Else
|
|
CanvasTexture = TextureManager.GetTexture("GUI\Menus\Menu", New Rectangle(0, 0, 48, 48), "")
|
|
FontColor = Color.Black
|
|
FontShadow.A = 0
|
|
End If
|
|
|
|
Dim Text As String = ""
|
|
Select Case i
|
|
Case 0
|
|
Text = Localization.GetString("join_server_screen_button_join", "Join")
|
|
Dim s As Server = ServerList(selectIndex)
|
|
|
|
If s.IsLocal = True Then
|
|
Text = Localization.GetString("join_server_screen_button_play", "Play")
|
|
Else
|
|
If s.CanJoin() = False Then
|
|
CanvasTexture = TextureManager.GetTexture("GUI\Menus\Menu", New Rectangle(48, 0, 48, 48), "")
|
|
End If
|
|
End If
|
|
Case 1
|
|
Text = Localization.GetString("join_server_screen_button_refresh", "Refresh")
|
|
Case 2
|
|
Text = Localization.GetString("join_server_screen_button_add", "Add")
|
|
Case 3
|
|
Text = Localization.GetString("join_server_screen_button_edit", "Edit")
|
|
Dim s As Server = ServerList(selectIndex)
|
|
|
|
If s.IsLocal = True Then
|
|
CanvasTexture = TextureManager.GetTexture("GUI\Menus\Menu", New Rectangle(48, 0, 48, 48), "")
|
|
End If
|
|
Case 4
|
|
Text = Localization.GetString("join_server_screen_button_remove", "Remove")
|
|
Dim s As Server = ServerList(selectIndex)
|
|
|
|
If s.IsLocal = True Then
|
|
CanvasTexture = TextureManager.GetTexture("GUI\Menus\Menu", New Rectangle(48, 0, 48, 48), "")
|
|
End If
|
|
Case 5
|
|
Text = Localization.GetString("global_back", "Back")
|
|
End Select
|
|
|
|
Canvas.DrawImageBorder(CanvasTexture, 2, New Rectangle(CInt(Core.ScreenSize.Width / 2) - 560 + i * 192, Core.ScreenSize.Height - 136, 128, 64), True)
|
|
Core.SpriteBatch.DrawInterfaceString(FontManager.InGameFont, Text, New Vector2(CInt(Core.ScreenSize.Width / 2) - 542 + i * 192 + 2, Core.ScreenSize.Height - 104 + 2), FontShadow)
|
|
Core.SpriteBatch.DrawInterfaceString(FontManager.InGameFont, Text, New Vector2(CInt(Core.ScreenSize.Width / 2) - 542 + i * 192, Core.ScreenSize.Height - 104), FontColor)
|
|
Next
|
|
|
|
Dim vS As String = "Protocol version: " & Servers.ServersManager.PROTOCOLVERSION
|
|
Core.SpriteBatch.DrawInterfaceString(FontManager.MiniFont, vS, New Vector2(Core.ScreenSize.Width - FontManager.MiniFont.MeasureString(vS).X - 4, Core.ScreenSize.Height - FontManager.MiniFont.MeasureString(vS).Y - 1), Color.White)
|
|
|
|
' Draw player list tooltip after everything else.
|
|
For i = 0 To endX
|
|
Dim index As Integer = i + scrollIndex
|
|
|
|
If ServerList.Count - 1 >= index Then
|
|
ServerList(index).DrawPlayerListToolTip(New Vector2(0, i * 100 + 100))
|
|
End If
|
|
Next
|
|
End Sub
|
|
|
|
Public Overrides Sub Update()
|
|
If LoadOnlineServers = False Then
|
|
JoinButton()
|
|
End If
|
|
|
|
Dim ServersToDisplay As Integer = GetServersToDisplay()
|
|
|
|
If Controls.Up(True, True, True) = True Then
|
|
selectIndex -= 1
|
|
If selectIndex - scrollIndex < 0 Then
|
|
scrollIndex -= 1
|
|
End If
|
|
End If
|
|
If Controls.Down(True, True, True) = True Then
|
|
selectIndex += 1
|
|
If selectIndex + scrollIndex > ServersToDisplay - 1 Then
|
|
scrollIndex += 1
|
|
End If
|
|
End If
|
|
|
|
If Core.GameInstance.IsMouseVisible = True Then
|
|
For i = 0 To 5
|
|
If Core.ScaleScreenRec(New Rectangle(CInt(Core.ScreenSize.Width / 2) - 560 + i * 192, Core.ScreenSize.Height - 138, 128 + 32, 64 + 32)).Contains(MouseHandler.MousePosition) = True Then
|
|
Me.buttonIndex = i
|
|
|
|
If MouseHandler.ButtonPressed(MouseHandler.MouseButtons.LeftButton) = True AndAlso MouseHandler.ButtonPressed(MouseHandler.MouseButtons.RightButton) = False Then
|
|
Select Case Me.buttonIndex
|
|
Case 0
|
|
SoundManager.PlaySound("select")
|
|
JoinButton()
|
|
Case 1
|
|
SoundManager.PlaySound("select")
|
|
RefreshButton()
|
|
Case 2
|
|
SoundManager.PlaySound("select")
|
|
AddServerButton()
|
|
Case 3
|
|
SoundManager.PlaySound("select")
|
|
EditServerButton()
|
|
Case 4
|
|
SoundManager.PlaySound("select")
|
|
RemoveServerButton()
|
|
Case 5
|
|
SoundManager.PlaySound("select")
|
|
CancelButton()
|
|
End Select
|
|
End If
|
|
End If
|
|
Next
|
|
End If
|
|
|
|
For i = 0 To ServersToDisplay - 1
|
|
If Core.ScaleScreenRec(New Rectangle(CInt(Core.ScreenSize.Width / 2) - 354, i * 100 + 100, 500, 80)).Contains(MouseHandler.MousePosition) = True Then
|
|
If MouseHandler.ButtonPressed(MouseHandler.MouseButtons.LeftButton) = True Then
|
|
Me.selectIndex = i + scrollIndex
|
|
End If
|
|
End If
|
|
Next
|
|
|
|
If Controls.Right(True, True, False) = True Then
|
|
Me.buttonIndex += 1
|
|
End If
|
|
If Controls.Left(True, True, False) = True Then
|
|
Me.buttonIndex -= 1
|
|
End If
|
|
|
|
Me.buttonIndex = CInt(MathHelper.Clamp(Me.buttonIndex, 0, 5))
|
|
|
|
If Controls.Accept(False, True) = True Then
|
|
Select Case Me.buttonIndex
|
|
Case 0
|
|
SoundManager.PlaySound("select")
|
|
JoinButton()
|
|
Case 1
|
|
SoundManager.PlaySound("select")
|
|
RefreshButton()
|
|
Case 2
|
|
SoundManager.PlaySound("select")
|
|
AddServerButton()
|
|
Case 3
|
|
SoundManager.PlaySound("select")
|
|
EditServerButton()
|
|
Case 4
|
|
SoundManager.PlaySound("select")
|
|
RemoveServerButton()
|
|
Case 5
|
|
SoundManager.PlaySound("select")
|
|
CancelButton()
|
|
End Select
|
|
End If
|
|
|
|
If Controls.Dismiss() = True Then
|
|
''CType(Me.PreScreen, NewMainMenuScreen)._menuIndex = 0
|
|
Core.Player.Unload()
|
|
Core.SetScreen(Me.PreScreen)
|
|
SoundManager.PlaySound("select")
|
|
End If
|
|
|
|
BarAnimationState += 1
|
|
If BarAnimationState > 49 Then
|
|
BarAnimationState = 0
|
|
End If
|
|
|
|
selectIndex = CInt(MathHelper.Clamp(selectIndex, 0, ServerList.Count - 1))
|
|
scrollIndex = CInt(MathHelper.Clamp(scrollIndex, 0, ServerList.Count - ServersToDisplay))
|
|
End Sub
|
|
|
|
#Region "Buttons"
|
|
|
|
Private Sub JoinButton()
|
|
If Me.selectIndex = 0 Then
|
|
Online = False
|
|
SelectedServer = Nothing
|
|
Core.SetScreen(New OverworldScreen())
|
|
Else
|
|
If ServerList(selectIndex).CanJoin() = True Then
|
|
SelectedServer = Me.ServerList(selectIndex)
|
|
ServerList.Move(selectIndex, 1)
|
|
SaveServerlist()
|
|
Core.SetScreen(New OverworldScreen())
|
|
Core.SetScreen(New ConnectScreen(ConnectScreen.Modes.Connect, "Connecting to server", "Please wait...", Core.CurrentScreen))
|
|
End If
|
|
End If
|
|
End Sub
|
|
|
|
Private Sub AddServerButton()
|
|
Core.SetScreen(New AddServerScreen(Me, Me.ServerList, True, Nothing))
|
|
End Sub
|
|
|
|
Private Sub EditServerButton()
|
|
Dim s As Server = ServerList(selectIndex)
|
|
|
|
If s.IsLocal = False Then
|
|
ServerList.RemoveAt(selectIndex)
|
|
SaveServerlist()
|
|
Core.SetScreen(New AddServerScreen(Me, Me.ServerList, False, s))
|
|
End If
|
|
End Sub
|
|
|
|
Private Sub RemoveServerButton()
|
|
Dim s As Server = ServerList(selectIndex)
|
|
|
|
If s.IsLocal = False Then
|
|
ServerList.RemoveAt(selectIndex)
|
|
SaveServerlist()
|
|
LoadServers()
|
|
End If
|
|
End Sub
|
|
|
|
Private Sub CancelButton()
|
|
Core.SetScreen(Me.PreScreen)
|
|
End Sub
|
|
|
|
Private Sub RefreshButton()
|
|
For Each Server As Server In ServerList
|
|
Server.Refresh()
|
|
Next
|
|
End Sub
|
|
|
|
#End Region
|
|
|
|
Private Function GetServersToDisplay() As Integer
|
|
Dim contentHeight As Integer = Core.ScreenSize.Height - 300
|
|
Dim serverHeight As Integer = 80
|
|
Dim serverCount As Integer = 1
|
|
|
|
While contentHeight > serverHeight + 80
|
|
serverHeight += 100
|
|
serverCount += 1
|
|
End While
|
|
|
|
Return serverCount
|
|
End Function
|
|
|
|
Public Overrides Sub ChangeTo()
|
|
If Controls.ShiftDown() = True Then
|
|
LoadOnlineServers = False
|
|
Else
|
|
LoadOnlineServers = True
|
|
End If
|
|
LoadServers()
|
|
End Sub
|
|
|
|
Class Server
|
|
|
|
Inherits Servers.Server
|
|
|
|
Public IsLocal As Boolean = False
|
|
Public IdentifierName As String = ""
|
|
Private Name As String = ""
|
|
Public PingResult As Integer = 0
|
|
Public Pinged As Boolean = False
|
|
Public StartedPing As Boolean = False
|
|
Public ServerMessage As String = ""
|
|
Public PlayerList As New List(Of String)
|
|
Public CurrentPlayersOnline As Integer = 0
|
|
Public MaxPlayersOnline As Integer = 0
|
|
Public ServerProtocolVersion As String = ""
|
|
|
|
Dim ReceivedError As Boolean = False
|
|
|
|
Public Sub Refresh()
|
|
Me.Name = IdentifierName
|
|
Me.Pinged = False
|
|
Me.StartedPing = False
|
|
Me.ReceivedError = False
|
|
Me.CurrentPlayersOnline = 0
|
|
Me.MaxPlayersOnline = 0
|
|
Me.ServerProtocolVersion = ""
|
|
Me.ServerMessage = ""
|
|
|
|
Me.Ping()
|
|
End Sub
|
|
|
|
Public Function GetName() As String
|
|
If Name = "" Then
|
|
Return IdentifierName
|
|
End If
|
|
Return Name
|
|
End Function
|
|
|
|
Public Sub New(ByVal name As String, ByVal Address As String)
|
|
MyBase.New(Address)
|
|
|
|
Me.IdentifierName = name
|
|
|
|
Me.Pinged = False
|
|
Me.StartedPing = False
|
|
End Sub
|
|
|
|
Public Sub Ping()
|
|
If IsLocal = True Then
|
|
Me.Name = Localization.GetString("join_server_screen_local_server_title", "Local")
|
|
Me.PingResult = 0
|
|
Me.StartedPing = True
|
|
Me.Pinged = True
|
|
Me.CurrentPlayersOnline = 0
|
|
Me.MaxPlayersOnline = 1
|
|
Me.IP = "127.0.0.1"
|
|
Me.Port = "15124"
|
|
Me.ServerMessage = Localization.GetString("join_server_screen_local_server_description", "Single-player: Play on your local computer.")
|
|
Me.ServerProtocolVersion = Servers.ServersManager.PROTOCOLVERSION
|
|
Else
|
|
Dim t As New Threading.Thread(AddressOf StartPing)
|
|
t.IsBackground = True
|
|
t.Start()
|
|
JoinServerScreen.ClearThreadList.Add(t)
|
|
Me.StartedPing = True
|
|
Dim cT As New Threading.Thread(AddressOf CheckServerConnectTimeout)
|
|
cT.IsBackground = True
|
|
cT.Start(t)
|
|
JoinServerScreen.ClearThreadList.Add(cT)
|
|
End If
|
|
End Sub
|
|
|
|
Private Sub CheckServerConnectTimeout(ByVal t As Object)
|
|
Dim sw As New Stopwatch()
|
|
sw.Start()
|
|
|
|
' TTL: 10000 ticks, usually at 60 Hz => 10000/60 seconds.
|
|
While sw.ElapsedMilliseconds < 10000 And Me.Pinged = False
|
|
' Wait for server connection in the main thread.
|
|
Threading.Thread.Sleep(1)
|
|
End While
|
|
|
|
sw.Stop()
|
|
|
|
If Me.Pinged = False Then
|
|
Try
|
|
CType(t, Threading.Thread).Abort()
|
|
Catch : End Try
|
|
Me.Pinged = True
|
|
Me.ReceivedError = True
|
|
End If
|
|
End Sub
|
|
|
|
Public Function CanJoin() As Boolean
|
|
If IsLocal = True Then
|
|
Return True
|
|
End If
|
|
If StartedPing = True And Pinged = True Then
|
|
If Me.ServerProtocolVersion = Servers.ServersManager.PROTOCOLVERSION Then
|
|
If CurrentPlayersOnline < MaxPlayersOnline Then
|
|
Return True
|
|
End If
|
|
End If
|
|
End If
|
|
Return False
|
|
End Function
|
|
|
|
Private Sub StartPing()
|
|
Dim sw As New Stopwatch()
|
|
|
|
Try
|
|
Dim client As New TcpClient()
|
|
|
|
Dim connectIP As IPAddress = Nothing
|
|
|
|
If Not IPAddress.TryParse(IP, connectIP) Then
|
|
For Each ipaddress In Dns.GetHostEntry(IP).AddressList
|
|
If ipaddress.AddressFamily = AddressFamily.InterNetwork Then
|
|
connectIP = ipaddress
|
|
Exit For
|
|
End If
|
|
Next
|
|
End If
|
|
|
|
sw.Start()
|
|
client.Connect(connectIP, CInt(Me.Port))
|
|
|
|
If client.Connected = True Then
|
|
Dim Stream As NetworkStream = client.GetStream()
|
|
|
|
Dim streamr As StreamReader = New StreamReader(Stream)
|
|
Dim streamw As StreamWriterLock = New StreamWriterLock(Stream)
|
|
|
|
streamw.WriteLine(New Servers.Package(Servers.Package.PackageTypes.ServerDataRequest, -1, Servers.Package.ProtocolTypes.TCP, "r").ToString())
|
|
streamw.Flush()
|
|
|
|
Dim p As New Servers.Package(streamr.ReadLine())
|
|
If p.IsValid = True Then
|
|
If p.PackageType = Servers.Package.PackageTypes.ServerInfoData Then
|
|
sw.Stop()
|
|
|
|
CurrentPlayersOnline = CInt(p.DataItems(0))
|
|
MaxPlayersOnline = CInt(p.DataItems(1))
|
|
Name = p.DataItems(2)
|
|
ServerMessage = p.DataItems(3)
|
|
|
|
Me.PlayerList.Clear()
|
|
If p.DataItems.Count > 4 Then
|
|
For i = 4 To p.DataItems.Count - 1
|
|
Me.PlayerList.Add(p.DataItems(i))
|
|
Next
|
|
End If
|
|
|
|
Me.PlayerList = (From playerName As String In PlayerList Order By playerName Ascending).ToList()
|
|
|
|
ServerProtocolVersion = p.ProtocolVersion
|
|
Logger.Debug("Received server data.")
|
|
Else
|
|
ReceivedError = True
|
|
End If
|
|
Else
|
|
ReceivedError = True
|
|
End If
|
|
Else
|
|
ReceivedError = True
|
|
End If
|
|
Catch ex As Exception
|
|
ReceivedError = True
|
|
|
|
Logger.Debug("JoinServerScreen.vb: Exception trying to ping server: " & ex.Message)
|
|
End Try
|
|
Me.Pinged = True
|
|
|
|
Me.PingResult = CInt(sw.ElapsedMilliseconds)
|
|
End Sub
|
|
|
|
Public Function GetPingTime() As Integer
|
|
If Me.Pinged = True And Me.StartedPing = True Then
|
|
If ReceivedError = True Then
|
|
Return 0
|
|
Else
|
|
Return Me.PingResult
|
|
End If
|
|
Else
|
|
Return 0
|
|
End If
|
|
End Function
|
|
|
|
Public Function GetServerStatus() As String
|
|
If ReceivedError = True Then
|
|
Return Localization.GetString("join_server_screen_server_unavailable", "Cannot reach server.")
|
|
End If
|
|
If Me.Pinged = True Then
|
|
Return Localization.GetString("join_server_screen_server_online", "Server online.")
|
|
Else
|
|
Return Localization.GetString("join_server_screen_server_polling", "Polling") & LoadingDots.Dots
|
|
End If
|
|
End Function
|
|
|
|
Public Sub Draw(ByVal startPos As Vector2, ByVal selected As Boolean)
|
|
Dim width As Integer = 500
|
|
startPos.X = CInt(Core.ScreenSize.Width / 2 - width / 2)
|
|
If selected = True Then
|
|
Canvas.DrawRectangle(New Rectangle(CInt(startPos.X), CInt(startPos.Y), width, 80), New Color(0, 0, 0, 200), True)
|
|
Canvas.DrawBorder(2, New Rectangle(CInt(startPos.X), CInt(startPos.Y), width, 80), Color.LightGray, True)
|
|
End If
|
|
Core.SpriteBatch.DrawInterfaceString(FontManager.InGameFont, Me.GetName(), New Vector2(CInt(startPos.X) + 4, CInt(startPos.Y) + 3), Color.White, 0.0F, Vector2.Zero, 1.0F, SpriteEffects.None, 0.0F)
|
|
|
|
If ReceivedError = True Then
|
|
Core.SpriteBatch.DrawInterfaceString(FontManager.InGameFont, GetServerStatus(), New Vector2(CInt(startPos.X) + 4, CInt(startPos.Y) + 30), New Color(190, 0, 0, 255), 0.0F, Vector2.Zero, 1.0F, SpriteEffects.None, 0.0F)
|
|
Core.SpriteBatch.DrawInterface(TextureManager.GetTexture("GUI\Menus\Menu", New Rectangle(150, 224, 14, 14), ""), New Rectangle(CInt(startPos.X) + width - 32, CInt(startPos.Y) + 3, 28, 28), Color.White)
|
|
|
|
If New Rectangle(CInt(startPos.X) + width - 32, CInt(startPos.Y) + 3, 28, 28).Contains(MouseHandler.MousePosition) = True Then
|
|
Canvas.DrawRectangle(New Rectangle(MouseHandler.MousePosition.X + 10, MouseHandler.MousePosition.Y + 10, 160, 32), Color.Black)
|
|
Canvas.DrawBorder(3, New Rectangle(MouseHandler.MousePosition.X + 10, MouseHandler.MousePosition.Y + 10, 160, 32), Color.Gray)
|
|
Core.SpriteBatch.DrawInterfaceString(FontManager.InGameFont, Localization.GetString("join_server_screen_no_connection", "(no connection)"), New Vector2(MouseHandler.MousePosition.X + 14, MouseHandler.MousePosition.Y + 16), Color.White)
|
|
End If
|
|
Else
|
|
If Pinged = True Then
|
|
Dim message As String = Me.ServerMessage
|
|
Dim color As Color = New Color(180, 180, 180, 255)
|
|
|
|
If CanJoin() = False Then
|
|
If CurrentPlayersOnline >= MaxPlayersOnline Then
|
|
message = Localization.GetString("join_server_screen_server_full", "The server is full.")
|
|
End If
|
|
If ServerProtocolVersion <> Servers.ServersManager.PROTOCOLVERSION Then
|
|
message = Localization.GetString("join_server_screen_version_mismatch", "Version doesn't match the server's version.")
|
|
End If
|
|
|
|
color = New Color(190, 0, 0, 255)
|
|
End If
|
|
|
|
Core.SpriteBatch.DrawInterfaceString(FontManager.InGameFont, message, New Vector2(CInt(startPos.X) + 4, CInt(startPos.Y) + 30), color, 0.0F, Vector2.Zero, 1.0F, SpriteEffects.None, 0.0F)
|
|
|
|
Core.SpriteBatch.DrawInterfaceString(FontManager.InGameFont, Me.CurrentPlayersOnline & "/" & Me.MaxPlayersOnline, New Vector2(CInt(startPos.X) + width - 36 - FontManager.InGameFont.MeasureString(Me.CurrentPlayersOnline & "/" & Me.MaxPlayersOnline).X, CInt(startPos.Y) + 9), Color.LightGray)
|
|
Core.SpriteBatch.DrawInterface(TextureManager.GetTexture("GUI\Menus\Menu", New Rectangle(80 + 14 * (4 - GetPingLevel()), 238, 14, 14), ""), New Rectangle(CInt(startPos.X) + width - 30, CInt(startPos.Y) + 3, 28, 28), Color.White)
|
|
|
|
' Ping result tool tip.
|
|
If New Rectangle(CInt(startPos.X) + width - 32, CInt(startPos.Y) + 3, 28, 28).Contains(MouseHandler.MousePosition) = True Then
|
|
Canvas.DrawRectangle(New Rectangle(MouseHandler.MousePosition.X + 10, MouseHandler.MousePosition.Y + 10, 160, 32), Color.Black)
|
|
Canvas.DrawBorder(3, New Rectangle(MouseHandler.MousePosition.X + 10, MouseHandler.MousePosition.Y + 10, 160, 32), Color.Gray)
|
|
Core.SpriteBatch.DrawInterfaceString(FontManager.InGameFont, Localization.GetString("join_server_screen_ping", "Ping:") & " " & PingResult & " ms", New Vector2(MouseHandler.MousePosition.X + 14, MouseHandler.MousePosition.Y + 16), Color.White)
|
|
End If
|
|
Else
|
|
Core.SpriteBatch.DrawInterface(TextureManager.GetTexture("GUI\Menus\Menu", New Rectangle(80 + 14 * CInt(Math.Floor(JoinServerScreen.BarAnimationState / 10)), 224, 14, 14), ""), New Rectangle(CInt(startPos.X) + width - 32, CInt(startPos.Y) + 3, 28, 28), Color.White)
|
|
If New Rectangle(CInt(startPos.X) + width - 32, CInt(startPos.Y) + 3, 28, 28).Contains(MouseHandler.MousePosition) = True Then
|
|
Canvas.DrawRectangle(New Rectangle(MouseHandler.MousePosition.X + 10, MouseHandler.MousePosition.Y + 10, 160, 32), Color.Black)
|
|
Canvas.DrawBorder(3, New Rectangle(MouseHandler.MousePosition.X + 10, MouseHandler.MousePosition.Y + 10, 160, 32), Color.Gray)
|
|
Core.SpriteBatch.DrawInterfaceString(FontManager.InGameFont, Localization.GetString("join_server_screen_server_polling", "Polling") & LoadingDots.Dots, New Vector2(MouseHandler.MousePosition.X + 14, MouseHandler.MousePosition.Y + 16), Color.White)
|
|
End If
|
|
|
|
Core.SpriteBatch.DrawInterfaceString(FontManager.InGameFont, Localization.GetString("join_server_screen_server_polling", "Polling") & LoadingDots.Dots, New Vector2(CInt(startPos.X) + 4, CInt(startPos.Y) + 30), New Color(180, 180, 180, 255), 0.0F, Vector2.Zero, 1.0F, SpriteEffects.None, 0.0F)
|
|
End If
|
|
End If
|
|
|
|
Core.SpriteBatch.DrawInterfaceString(FontManager.InGameFont, GetAddressString(), New Vector2(CInt(startPos.X) + 4, CInt(startPos.Y) + 53), New Color(180, 180, 180, 255), 0.0F, Vector2.Zero, 1.0F, SpriteEffects.None, 0.0F)
|
|
End Sub
|
|
|
|
Public Sub DrawPlayerListToolTip(ByVal startPos As Vector2)
|
|
If ReceivedError = False And Pinged = True And IsLocal = False Then
|
|
Dim width As Integer = 500
|
|
startPos.X = CInt(Core.ScreenSize.Width / 2 - width / 2)
|
|
|
|
If Core.ScaleScreenRec(New Rectangle(CInt(startPos.X) + width - 36 - FontManager.MiniFont.MeasureString(Me.CurrentPlayersOnline & "/" & Me.MaxPlayersOnline).X.ToInteger(), CInt(startPos.Y) + 3, FontManager.MiniFont.MeasureString(Me.CurrentPlayersOnline & "/" & Me.MaxPlayersOnline).X.ToInteger(), 28)).Contains(MouseHandler.MousePosition) = True Then
|
|
Dim tooltipText As String = Localization.GetString("join_server_screen_tooltip_no_players", "No players on the server.")
|
|
|
|
If PlayerList.Count > 0 Then
|
|
tooltipText = PlayerList.ToArray().ArrayToString(True)
|
|
End If
|
|
|
|
Dim v = FontManager.MiniFont.MeasureString(Localization.GetString("join_server_screen_tooltip_player_list", "Player List") & Environment.NewLine & tooltipText)
|
|
|
|
Dim drawY As Integer = MouseHandler.MousePosition.Y + 10
|
|
If drawY + v.Y + 12 > Core.windowSize.Height Then
|
|
drawY = CInt(Core.windowSize.Height - v.Y - 22)
|
|
End If
|
|
If drawY < 0 Then
|
|
drawY = 0
|
|
End If
|
|
|
|
Canvas.DrawRectangle(New Rectangle(MouseHandler.MousePosition.X + 10, drawY, CInt(v.X + 10), CInt(v.Y + 22)), Color.Black, True)
|
|
Canvas.DrawBorder(3, New Rectangle(MouseHandler.MousePosition.X + 10, drawY, CInt(v.X + 10), CInt(v.Y + 22)), Color.Gray, True)
|
|
|
|
Core.SpriteBatch.DrawInterfaceString(FontManager.MiniFont, Localization.GetString("join_server_screen_tooltip_player_list", "Player List"), New Vector2(MouseHandler.MousePosition.X + 14, drawY + 6), Color.LightBlue)
|
|
Core.SpriteBatch.DrawInterfaceString(FontManager.MiniFont, tooltipText, New Vector2(MouseHandler.MousePosition.X + 14, drawY + 6 + 34), Color.White)
|
|
End If
|
|
End If
|
|
End Sub
|
|
|
|
Public Function GetAddressString() As String
|
|
'If IsLocal = True Then
|
|
'Return ""
|
|
' Else
|
|
Return Me.IP & ":" & Me.Port
|
|
'End If
|
|
End Function
|
|
|
|
Private Function GetPingLevel() As Integer
|
|
If Me.PingResult < 500 Then
|
|
Return 0
|
|
ElseIf PingResult >= 500 And PingResult < 1000 Then
|
|
Return 1
|
|
ElseIf PingResult >= 1000 And PingResult < 2000 Then
|
|
Return 2
|
|
ElseIf PingResult >= 2000 And PingResult < 5000 Then
|
|
Return 3
|
|
Else
|
|
Return 4
|
|
End If
|
|
End Function
|
|
|
|
Public Overrides Function ToString() As String
|
|
Return Me.IdentifierName & "," & Me.GetAddressString()
|
|
End Function
|
|
|
|
End Class
|
|
|
|
Public Shared Sub AddServerMessage(ByVal m As String, ByVal server_name As String)
|
|
If System.IO.File.Exists(GameController.GamePath & "\Save\server_list.dat") = False Then
|
|
System.IO.File.WriteAllText(GameController.GamePath & "\Save\server_list.dat", "")
|
|
End If
|
|
|
|
Dim newData As String = ""
|
|
|
|
Dim data() As String = System.IO.File.ReadAllLines(GameController.GamePath & "\Save\server_list.dat")
|
|
For Each line As String In data
|
|
If newData <> "" Then
|
|
newData &= Environment.NewLine
|
|
End If
|
|
If line.StartsWith(server_name & ",") = True Then
|
|
Dim lineData() As String = line.Split(CChar(","))
|
|
newData &= lineData(0) & "," & lineData(1) & "," & m
|
|
Else
|
|
newData &= line
|
|
End If
|
|
Next
|
|
|
|
System.IO.File.WriteAllText(GameController.GamePath & "\Save\server_list.dat", newData)
|
|
End Sub
|
|
|
|
Public Overrides Sub ChangeFrom()
|
|
For Each t As Threading.Thread In ClearThreadList
|
|
Try
|
|
If t.IsAlive = True Then
|
|
t.Abort()
|
|
End If
|
|
Catch : End Try
|
|
Next
|
|
ClearThreadList.Clear()
|
|
End Sub
|
|
|
|
Private Sub SaveServerlist()
|
|
Dim data As String = ""
|
|
For Each s As Server In Me.ServerList
|
|
If s.IsLocal = False Then
|
|
If data <> "" Then
|
|
data &= Environment.NewLine
|
|
End If
|
|
data &= s.ToString()
|
|
End If
|
|
Next
|
|
System.IO.File.WriteAllText(GameController.GamePath & "\Save\server_list.dat", data)
|
|
End Sub
|
|
|
|
End Class |