Imports P3D.BattleSystem Public Class World Private Shared _regionWeather As Weathers = Weathers.Clear Private Shared _regionWeatherSet As Boolean = False Public Shared setSeason As Seasons = Nothing Public Shared setDaytime As DayTimes = Nothing Public Shared IsMainMenu As Boolean = False Public Shared IsAurora As Boolean = False Public Enum Seasons As Integer Winter = 0 Spring = 1 Summer = 2 Fall = 3 End Enum Public Enum Weathers As Integer Clear = 0 Rain = 1 Snow = 2 Underwater = 3 Sunny = 4 Fog = 5 Thunderstorm = 6 Sandstorm = 7 Ash = 8 Blizzard = 9 End Enum Public Enum EnvironmentTypes As Integer Outside = 0 Inside = 1 Cave = 2 Dark = 3 Underwater = 4 Forest = 5 End Enum Public Enum DayTimes As Integer Day = 0 Night = 1 Morning = 2 Evening = 3 End Enum Public Shared ReadOnly Property WeekOfYear() As Integer Get Return CInt(((My.Computer.Clock.LocalTime.DayOfYear - (My.Computer.Clock.LocalTime.DayOfWeek - 1)) / 7) + 1) End Get End Property Public Shared ReadOnly Property CurrentSeason() As Seasons Get If IsMainMenu Then Return Seasons.Summer End If If setSeason <> Nothing Then Return setSeason Else If NeedServerObject() = True Then Return ServerSeason End If Select Case WeekOfYear Mod 4 Case 1 Return Seasons.Winter Case 2 Return Seasons.Spring Case 3 Return Seasons.Summer Case 0 Return Seasons.Fall End Select End If Return Seasons.Summer End Get End Property Public Shared ReadOnly Property GetTime() As DayTimes Get If IsMainMenu Then Return DayTimes.Day End If If setDaytime <> Nothing Then Return setDaytime Else Dim time As DayTimes = DayTimes.Day Dim Hour As Integer = My.Computer.Clock.LocalTime.Hour If NeedServerObject() = True Then Dim data() As String = ServerTimeData.Split(CChar(",")) Hour = CInt(data(0)) End If Select Case CurrentSeason Case Seasons.Winter If Hour > 18 Or Hour < 7 Then time = DayTimes.Night ElseIf Hour > 6 And Hour < 11 Then time = DayTimes.Morning ElseIf Hour > 10 And Hour < 17 Then time = DayTimes.Day ElseIf Hour > 16 And Hour < 19 Then time = DayTimes.Evening End If Case Seasons.Spring If Hour > 19 Or Hour < 5 Then time = DayTimes.Night ElseIf Hour > 4 And Hour < 10 Then time = DayTimes.Morning ElseIf Hour > 9 And Hour < 17 Then time = DayTimes.Day ElseIf Hour > 16 And Hour < 20 Then time = DayTimes.Evening End If Case Seasons.Summer If Hour > 20 Or Hour < 4 Then time = DayTimes.Night ElseIf Hour > 3 And Hour < 9 Then time = DayTimes.Morning ElseIf Hour > 8 And Hour < 19 Then time = DayTimes.Day ElseIf Hour > 18 And Hour < 21 Then time = DayTimes.Evening End If Case Seasons.Fall If Hour > 19 Or Hour < 6 Then time = DayTimes.Night ElseIf Hour > 5 And Hour < 10 Then time = DayTimes.Morning ElseIf Hour > 9 And Hour < 18 Then time = DayTimes.Day ElseIf Hour > 17 And Hour < 20 Then time = DayTimes.Evening End If End Select Return time End If End Get End Property Public Shared Sub SetRenderDistance(ByVal EnvironmentType As EnvironmentTypes, ByVal Weather As Weathers) If Weather = Weathers.Fog Then Screen.Effect.FogStart = -40 Screen.Effect.FogEnd = 12 Screen.Camera.FarPlane = 15 GoTo endsub End If If Weather = Weathers.Blizzard Then Screen.Effect.FogStart = -40 Screen.Effect.FogEnd = 20 Screen.Camera.FarPlane = 24 GoTo endsub End If If Weather = Weathers.Thunderstorm Then Screen.Effect.FogStart = -40 Screen.Effect.FogEnd = 20 Screen.Camera.FarPlane = 24 GoTo endsub End If Select Case EnvironmentType Case EnvironmentTypes.Cave, EnvironmentTypes.Dark, EnvironmentTypes.Forest Select Case Core.GameOptions.RenderDistance Case 0 Screen.Effect.FogStart = -2 Screen.Effect.FogEnd = 19 Screen.Camera.FarPlane = 20 Case 1 Screen.Effect.FogStart = -2 Screen.Effect.FogEnd = 39 Screen.Camera.FarPlane = 40 Case 2 Screen.Effect.FogStart = -2 Screen.Effect.FogEnd = 59 Screen.Camera.FarPlane = 60 Case 3 Screen.Effect.FogStart = -5 Screen.Effect.FogEnd = 79 Screen.Camera.FarPlane = 80 Case 4 Screen.Effect.FogStart = -20 Screen.Effect.FogEnd = 99 Screen.Camera.FarPlane = 100 End Select Case EnvironmentTypes.Inside Select Case Core.GameOptions.RenderDistance Case 0 Screen.Effect.FogStart = 16 Screen.Effect.FogEnd = 19 Screen.Camera.FarPlane = 20 Case 1 Screen.Effect.FogStart = 36 Screen.Effect.FogEnd = 39 Screen.Camera.FarPlane = 40 Case 2 Screen.Effect.FogStart = 56 Screen.Effect.FogEnd = 59 Screen.Camera.FarPlane = 60 Case 3 Screen.Effect.FogStart = 76 Screen.Effect.FogEnd = 79 Screen.Camera.FarPlane = 80 Case 4 Screen.Effect.FogStart = 96 Screen.Effect.FogEnd = 99 Screen.Camera.FarPlane = 100 End Select Case EnvironmentTypes.Outside Select Case World.GetTime Case DayTimes.Night Select Case Core.GameOptions.RenderDistance Case 0 Screen.Effect.FogStart = -2 Screen.Effect.FogEnd = 19 Screen.Camera.FarPlane = 20 Case 1 Screen.Effect.FogStart = -2 Screen.Effect.FogEnd = 39 Screen.Camera.FarPlane = 40 Case 2 Screen.Effect.FogStart = -2 Screen.Effect.FogEnd = 59 Screen.Camera.FarPlane = 60 Case 3 Screen.Effect.FogStart = -5 Screen.Effect.FogEnd = 79 Screen.Camera.FarPlane = 80 Case 4 Screen.Effect.FogStart = -20 Screen.Effect.FogEnd = 99 Screen.Camera.FarPlane = 100 End Select Case DayTimes.Morning Select Case Core.GameOptions.RenderDistance Case 0 Screen.Effect.FogStart = 16 Screen.Effect.FogEnd = 19 Screen.Camera.FarPlane = 20 Case 1 Screen.Effect.FogStart = 36 Screen.Effect.FogEnd = 39 Screen.Camera.FarPlane = 40 Case 2 Screen.Effect.FogStart = 56 Screen.Effect.FogEnd = 59 Screen.Camera.FarPlane = 60 Case 3 Screen.Effect.FogStart = 76 Screen.Effect.FogEnd = 79 Screen.Camera.FarPlane = 80 Case 4 Screen.Effect.FogStart = 96 Screen.Effect.FogEnd = 99 Screen.Camera.FarPlane = 100 End Select Case DayTimes.Day Select Case Core.GameOptions.RenderDistance Case 0 Screen.Effect.FogStart = 16 Screen.Effect.FogEnd = 19 Screen.Camera.FarPlane = 20 Case 1 Screen.Effect.FogStart = 36 Screen.Effect.FogEnd = 39 Screen.Camera.FarPlane = 40 Case 2 Screen.Effect.FogStart = 56 Screen.Effect.FogEnd = 59 Screen.Camera.FarPlane = 60 Case 3 Screen.Effect.FogStart = 76 Screen.Effect.FogEnd = 79 Screen.Camera.FarPlane = 80 Case 4 Screen.Effect.FogStart = 96 Screen.Effect.FogEnd = 99 Screen.Camera.FarPlane = 100 End Select Case DayTimes.Evening Select Case Core.GameOptions.RenderDistance Case 0 Screen.Effect.FogStart = 0 Screen.Effect.FogEnd = 19 Screen.Camera.FarPlane = 20 Case 1 Screen.Effect.FogStart = 0 Screen.Effect.FogEnd = 39 Screen.Camera.FarPlane = 40 Case 2 Screen.Effect.FogStart = 0 Screen.Effect.FogEnd = 59 Screen.Camera.FarPlane = 60 Case 3 Screen.Effect.FogStart = 0 Screen.Effect.FogEnd = 79 Screen.Camera.FarPlane = 80 Case 4 Screen.Effect.FogStart = 0 Screen.Effect.FogEnd = 99 Screen.Camera.FarPlane = 100 End Select End Select Case EnvironmentTypes.Underwater Select Case Core.GameOptions.RenderDistance Case 0 Screen.Effect.FogStart = 0 Screen.Effect.FogEnd = 19 Screen.Camera.FarPlane = 20 Case 1 Screen.Effect.FogStart = 0 Screen.Effect.FogEnd = 39 Screen.Camera.FarPlane = 40 Case 2 Screen.Effect.FogStart = 0 Screen.Effect.FogEnd = 59 Screen.Camera.FarPlane = 60 Case 3 Screen.Effect.FogStart = 0 Screen.Effect.FogEnd = 79 Screen.Camera.FarPlane = 80 Case 4 Screen.Effect.FogStart = 0 Screen.Effect.FogEnd = 99 Screen.Camera.FarPlane = 100 End Select End Select If Core.GameOptions.RenderDistance >= 4 Then Screen.Effect.FogStart = 999 Screen.Effect.FogEnd = 1000 Screen.Camera.FarPlane = 1000 End If endsub: Screen.Camera.CreateNewProjection(Screen.Camera.FOV) End Sub Public Shared Function GetRegionWeather(ByVal Season As Seasons) As Weathers If IsMainMenu Then Return Weathers.Clear End If Dim r As Integer = Core.Random.Next(0, 100) Select Case Season Case Seasons.Winter If r < 30 Then Return Weathers.Clear ElseIf r >= 30 And r < 40 Then Return Weathers.Rain Else Return Weathers.Snow End If Case Seasons.Spring If r < 45 Then Return Weathers.Clear ElseIf r >= 45 And r < 95 Then Return Weathers.Rain Else Return Weathers.Snow End If Case Seasons.Summer If r < 90 Then Return Weathers.Clear Else Return Weathers.Rain End If Case Seasons.Fall If r < 50 Then Return Weathers.Clear ElseIf r >= 50 And r < 85 Then Return Weathers.Rain Else Return Weathers.Snow End If End Select Return Weathers.Clear End Function Public CurrentMapWeather As Weathers = Weathers.Clear Public EnvironmentType As EnvironmentTypes = EnvironmentTypes.Outside Public UseLighting As Boolean = False Public Sub New(ByVal EnvironmentType As Integer, ByVal WeatherType As Integer) Initialize(EnvironmentType, WeatherType) End Sub Public Shared Function GetWeatherFromWeatherType(ByVal WeatherType As Integer) As Weathers If IsMainMenu Then Return Weathers.Clear End If Select Case WeatherType Case 0 ' Region Weather Return World.GetCurrentRegionWeather() Case 1 ' Clear Return Weathers.Clear Case 2 ' Rain Return Weathers.Rain Case 3 ' Snow Return Weathers.Snow Case 4 ' Underwater Return Weathers.Underwater Case 5 ' Sunny Return Weathers.Sunny Case 6 ' Fog Return Weathers.Fog Case 7 ' Sandstorm Return Weathers.Sandstorm Case 8 ' Ash Return Weathers.Ash Case 9 ' Blizzard Return Weathers.Blizzard Case 10 ' Thunderstorm Return Weathers.Thunderstorm End Select Return Weathers.Clear End Function Public Shared Function GetWeatherTypeFromWeather(ByVal Weather As Weathers) As Integer If IsMainMenu Then Return 1 End If Select Case Weather Case Weathers.Clear Return 1 Case Weathers.Rain Return 2 Case Weathers.Snow Return 3 Case Weathers.Underwater Return 4 Case Weathers.Sunny Return 5 Case Weathers.Fog Return 6 Case Weathers.Sandstorm Return 7 Case Weathers.Ash Return 8 Case Weathers.Blizzard Return 9 Case Weathers.Thunderstorm Return 10 Case Else Return 0 End Select End Function Public Sub Initialize(ByVal EnvironmentType As Integer, ByVal WeatherType As Integer) If _regionWeatherSet = False Then World._regionWeather = World.GetRegionWeather(World.CurrentSeason) World._regionWeatherSet = True End If Me.CurrentMapWeather = GetWeatherFromWeatherType(WeatherType) Select Case EnvironmentType Case 0 ' Overworld Me.EnvironmentType = EnvironmentTypes.Outside Me.UseLighting = True Case 1 ' Permanent Day Me.EnvironmentType = EnvironmentTypes.Inside Me.UseLighting = False Case 2 ' Cave Me.EnvironmentType = EnvironmentTypes.Cave If WeatherType = 0 Then Me.CurrentMapWeather = Weathers.Clear End If Me.UseLighting = False Case 3 ' Permanent Night Me.EnvironmentType = EnvironmentTypes.Dark If WeatherType = 0 Then Me.CurrentMapWeather = Weathers.Clear End If Me.UseLighting = False Case 4 ' Underwater Me.EnvironmentType = EnvironmentTypes.Underwater If WeatherType = 0 Then Me.CurrentMapWeather = Weathers.Underwater End If Me.UseLighting = True Case 5 ' Forest Me.EnvironmentType = EnvironmentTypes.Forest Me.UseLighting = True End Select SetWeatherLevelColor() ChangeEnvironment() SetRenderDistance(Me.EnvironmentType, Me.CurrentMapWeather) End Sub Private Sub SetWeatherLevelColor() Select Case CurrentMapWeather Case Weathers.Clear Screen.Effect.DiffuseColor = New Vector3(1) Case Weathers.Rain, Weathers.Thunderstorm Screen.Effect.DiffuseColor = New Vector3(0.4, 0.4, 0.7) Case Weathers.Snow Screen.Effect.DiffuseColor = New Vector3(0.8) Case Weathers.Underwater Screen.Effect.DiffuseColor = New Vector3(0.1, 0.3, 0.9) Case Weathers.Sunny Screen.Effect.DiffuseColor = New Vector3(1.6, 1.3, 1.3) Case Weathers.Fog Screen.Effect.DiffuseColor = New Vector3(0.5, 0.5, 0.6) Case Weathers.Sandstorm Screen.Effect.DiffuseColor = New Vector3(0.8, 0.5, 0.2) Case Weathers.Ash Screen.Effect.DiffuseColor = New Vector3(0.5, 0.5, 0.5) Case Weathers.Blizzard Screen.Effect.DiffuseColor = New Vector3(0.6, 0.6, 0.6) End Select Screen.Effect.DiffuseColor = Screen.SkyDome.GetWeatherColorMultiplier(Screen.Effect.DiffuseColor) End Sub Private Function GetWeatherBackgroundColor(ByVal defaultColor As Color) As Color Dim v As Vector3 = Vector3.One Select Case CurrentMapWeather Case World.Weathers.Clear, Weathers.Sunny v = New Vector3(1) Case World.Weathers.Rain, Weathers.Thunderstorm v = New Vector3(0.7) Case World.Weathers.Snow v = New Vector3(0.8) Case World.Weathers.Underwater v = New Vector3(0.1, 0.3, 0.9) Case World.Weathers.Fog v = New Vector3(0.7) Case World.Weathers.Sandstorm v = New Vector3(0.8, 0.5, 0.2) Case World.Weathers.Ash v = New Vector3(0.5) Case World.Weathers.Blizzard v = New Vector3(0.6) End Select Dim colorV As Vector3 = defaultColor.ToVector3 * Screen.SkyDome.GetWeatherColorMultiplier(v) Return colorV.ToColor() End Function Private Sub ChangeEnvironment() Select Case Me.EnvironmentType Case EnvironmentTypes.Outside Dim multiplier As Vector3 = New Vector3(1.0F) Select Case CurrentMapWeather Case World.Weathers.Clear, Weathers.Sunny multiplier = New Vector3(1.0F) Case World.Weathers.Rain, Weathers.Thunderstorm, World.Weathers.Fog multiplier = New Vector3(0.7F) Case World.Weathers.Snow multiplier = New Vector3(0.8F) End Select Screen.Effect.FogColor = Lighting.GetEnvironmentColor(2) * multiplier Screen.SkyDome.TextureDown = TextureManager.GetTexture("SkyDomeResource\Stars") Case EnvironmentTypes.Inside Screen.Effect.FogColor = Lighting.GetEnvironmentColor(2) Screen.SkyDome.TextureUp = TextureManager.GetTexture("SkyDomeResource\Inside") Screen.SkyDome.TextureDown = Nothing Case EnvironmentTypes.Dark Screen.Effect.FogColor = Lighting.GetEnvironmentColor(2) Screen.SkyDome.TextureUp = TextureManager.GetTexture("SkyDomeResource\Dark") Screen.SkyDome.TextureDown = Nothing Case EnvironmentTypes.Cave Screen.Effect.FogColor = Lighting.GetEnvironmentColor(2) Screen.SkyDome.TextureUp = TextureManager.GetTexture("SkyDomeResource\Cave") Screen.SkyDome.TextureDown = Nothing Case EnvironmentTypes.Underwater Screen.Effect.FogColor = Lighting.GetEnvironmentColor(2) Screen.SkyDome.TextureUp = TextureManager.GetTexture("SkyDomeResource\Underwater") Screen.SkyDome.TextureDown = Nothing Case EnvironmentTypes.Forest Screen.Effect.FogColor = Lighting.GetEnvironmentColor(2) Screen.SkyDome.TextureUp = TextureManager.GetTexture("SkyDomeResource\Forest") Screen.SkyDome.TextureDown = Nothing End Select End Sub Private Shared WeatherOffset As New Vector2(0, 0) Private Shared ObjectsList As New List(Of Rectangle) Public Shared NoParticlesList() As Weathers = {Weathers.Clear, Weathers.Sunny, Weathers.Fog} Public Shared Sub DrawWeather(ByVal MapWeather As Weathers) If NoParticlesList.Contains(MapWeather) = False Then If Core.GameOptions.GraphicStyle = 1 Then Dim identifications() As Screen.Identifications = {Screen.Identifications.OverworldScreen, Screen.Identifications.MainMenuScreen, Screen.Identifications.BattleScreen, Screen.Identifications.BattleCatchScreen} If identifications.Contains(Core.CurrentScreen.Identification) = True Then If Core.CurrentScreen.Identification = Screen.Identifications.OverworldScreen Then If Screen.TextBox.Showing = False Then GenerateParticles(0, MapWeather) End If Else GenerateParticles(0, MapWeather) End If End If Else Dim T As Texture2D = Nothing Dim size As Integer = 128 Dim opacity As Integer = 30 Select Case MapWeather Case Weathers.Rain T = TextureManager.GetTexture("Textures\Weather\rain") WeatherOffset.X += 8 WeatherOffset.Y += 16 Case Weathers.Thunderstorm T = TextureManager.GetTexture("Textures\Weather\rain") WeatherOffset.X += 12 WeatherOffset.Y += 20 opacity = 50 Case Weathers.Snow T = TextureManager.GetTexture("Textures\Weather\snow") WeatherOffset.X += 1 WeatherOffset.Y += 1 Case Weathers.Blizzard T = TextureManager.GetTexture("Textures\Weather\snow") WeatherOffset.X += 8 WeatherOffset.Y += 2 opacity = 80 Case Weathers.Sandstorm T = TextureManager.GetTexture("Textures\Weather\sand") WeatherOffset.X += 4 WeatherOffset.Y += 1 opacity = 80 size = 48 Case Weathers.Underwater T = TextureManager.GetTexture("Textures\Weather\bubble") If Core.Random.Next(0, 100) = 0 Then ObjectsList.Add(New Rectangle(Core.Random.Next(0, Core.windowSize.Width - 32), Core.windowSize.Height, 32, 32)) End If For i = 0 To ObjectsList.Count - 1 Dim r As Rectangle = ObjectsList(i) ObjectsList(i) = New Rectangle(r.X, r.Y - 2, r.Width, r.Height) Core.SpriteBatch.Draw(T, ObjectsList(i), New Color(255, 255, 255, 150)) Next Case Weathers.Ash T = TextureManager.GetTexture("Textures\Weather\ash2") WeatherOffset.Y += 1 opacity = 65 size = 48 End Select If WeatherOffset.X >= size Then WeatherOffset.X = 0 End If If WeatherOffset.Y >= size Then WeatherOffset.Y = 0 End If Select Case MapWeather Case Weathers.Rain, Weathers.Snow, Weathers.Sandstorm, Weathers.Ash, Weathers.Blizzard, Weathers.Thunderstorm For x = -size To Core.windowSize.Width Step size For y = -size To Core.windowSize.Height Step size Core.SpriteBatch.Draw(T, New Rectangle(CInt(x + WeatherOffset.X), CInt(y + WeatherOffset.Y), size, size), New Color(255, 255, 255, opacity)) Next Next End Select End If End If End Sub Public Shared Sub GenerateParticles(ByVal chance As Integer, ByVal MapWeather As Weathers) If MapWeather = Weathers.Thunderstorm Then If Core.Random.Next(0, 250) = 0 Then Dim pitch As Single = -(Core.Random.Next(8, 11) / 10.0F) Debug.Print(pitch.ToString()) SoundManager.PlaySound("Battle\Attacks\Electric\Thunderbolt", pitch, 0F, SoundManager.Volume, False) End If End If If LevelLoader.IsBusy = False Then Dim validScreen() As Screen.Identifications = {Screen.Identifications.OverworldScreen, Screen.Identifications.BattleScreen, Screen.Identifications.BattleCatchScreen, Screen.Identifications.MainMenuScreen} If validScreen.Contains(Core.CurrentScreen.Identification) = True Then If Core.CurrentScreen.Identification = Screen.Identifications.OverworldScreen Then If CType(Core.CurrentScreen, OverworldScreen).ActionScript.IsReady = False Then Exit Sub End If End If Dim T As Texture2D = Nothing Dim speed As Single Dim scale As New Vector3(1) Dim range As Integer = 3 Select Case MapWeather Case Weathers.Rain speed = 0.1F T = TextureManager.GetTexture("Textures\Weather\rain3") If chance > -1 Then chance = 3 scale = New Vector3(0.03F, 0.06F, 0.1F) Case Weathers.Thunderstorm speed = 0.15F Select Case Core.Random.Next(0, 4) Case 0 T = TextureManager.GetTexture("Textures\Weather\rain2") scale = New Vector3(0.1F, 0.1F, 0.1F) Case Else T = TextureManager.GetTexture("Textures\Weather\rain3") scale = New Vector3(0.03F, 0.06F, 0.1F) End Select If chance > -1 Then chance = 1 Case Weathers.Snow speed = 0.02F T = TextureManager.GetTexture("Textures\Weather\snow2") If chance > -1 Then chance = 5 scale = New Vector3(0.03F, 0.03F, 0.1F) Case Weathers.Underwater speed = -0.02F T = TextureManager.GetTexture("Textures\Weather\bubble") If chance > -1 Then chance = 60 scale = New Vector3(0.5F) range = 1 Case Weathers.Sandstorm speed = 0.1F T = TextureManager.GetTexture("Textures\Weather\sand") If chance > -1 Then chance = 4 scale = New Vector3(0.03F, 0.03F, 0.1F) Case Weathers.Ash speed = 0.02F T = TextureManager.GetTexture("Textures\Weather\ash") If chance > -1 Then chance = 20 scale = New Vector3(0.03F, 0.03F, 0.1F) Case Weathers.Blizzard speed = 0.1F T = TextureManager.GetTexture("Textures\Weather\snow") If chance > -1 Then chance = 1 scale = New Vector3(0.12F, 0.12F, 0.1F) End Select If chance = -1 Then chance = 1 End If Dim cameraPosition As Vector3 = Screen.Camera.Position If Core.CurrentScreen.Identification = Screen.Identifications.OverworldScreen Then cameraPosition = CType(Screen.Camera, OverworldCamera).CPosition ElseIf Core.CurrentScreen.Identification = Screen.Identifications.BattleScreen Then cameraPosition = CType(Screen.Camera, BattleCamera).CPosition End If If Core.Random.Next(0, chance) = 0 Then For x = cameraPosition.X - range To cameraPosition.X + range For z = cameraPosition.Z - range To cameraPosition.Z + range If z <> 0 Or x <> 0 Then Dim rY As Single = CSng(Core.Random.Next(0, 40) / 10) - 2.0F Dim rX As Single = CSng(Core.Random.NextDouble()) - 0.5F Dim rZ As Single = CSng(Core.Random.NextDouble()) - 0.5F Dim p As Particle = New Particle(New Vector3(x + rX, cameraPosition.Y + 1.8F + rY, z + rZ), {T}, {0, 0}, Core.Random.Next(0, 2), scale, BaseModel.BillModel, New Vector3(1)) p.MoveSpeed = speed If MapWeather = Weathers.Rain Then p.Opacity = 0.7F End If If MapWeather = Weathers.Thunderstorm Then p.Opacity = 1.0F End If If MapWeather = Weathers.Underwater Then p.Position.Y = 0.0F p.Destination = 10 p.Behavior = Particle.Behaviors.Rising End If If MapWeather = Weathers.Sandstorm Then p.Behavior = Particle.Behaviors.LeftToRight p.Destination = cameraPosition.X + 5 p.Position.X -= 2 End If If MapWeather = Weathers.Blizzard Then p.Opacity = 1.0F End If Screen.Level.Entities.Add(p) End If Next Next End If End If End If End Sub Private Shared SeasonTextureBuffer As New Dictionary(Of Texture2D, Texture2D) Private Shared BufferSeason As Seasons = Seasons.Fall Public Shared Function GetSeasonTexture(ByVal seasonTexture As Texture2D, ByVal T As Texture2D) As Texture2D If BufferSeason <> CurrentSeason Then BufferSeason = CurrentSeason SeasonTextureBuffer.Clear() End If If T IsNot Nothing Then If SeasonTextureBuffer.ContainsKey(T) = True Then Return SeasonTextureBuffer(T) End If Dim x As Integer = 0 Dim y As Integer = 0 Select Case CurrentSeason Case Seasons.Winter x = 0 y = 0 Case Seasons.Spring x = 2 y = 0 Case Seasons.Summer x = 0 y = 2 Case Seasons.Fall x = 2 y = 2 End Select Dim inputColors() As Color = {New Color(0, 0, 0), New Color(85, 85, 85), New Color(170, 170, 170), New Color(255, 255, 255)}.Reverse().ToArray() Dim outputColors As New List(Of Color) Dim Data(3) As Color seasonTexture.GetData(0, New Rectangle(x, y, 2, 2), Data, 0, 4) SeasonTextureBuffer.Add(T, T.ReplaceColors(inputColors, Data)) Return SeasonTextureBuffer(T) End If Return Nothing End Function Public Shared ServerSeason As Seasons = Seasons.Spring Public Shared ServerWeather As Weathers = Weathers.Clear Public Shared ServerTimeData As String = "0,0,0" ' Format: Hours,Minutes,Seconds Public Shared LastServerDataReceived As Date = Date.Now Public Shared ReadOnly Property SecondsOfDay() As Integer Get If NeedServerObject() = True Then Dim data() As String = ServerTimeData.Split(CChar(",")) Dim hours As Integer = CInt(data(0)) Dim minutes As Integer = CInt(data(1)) Dim seconds As Integer = CInt(data(2)) seconds += CInt(Math.Abs((Date.Now - LastServerDataReceived).Seconds)) Return hours * 3600 + minutes * 60 + seconds Else Return My.Computer.Clock.LocalTime.Hour * 3600 + My.Computer.Clock.LocalTime.Minute * 60 + My.Computer.Clock.LocalTime.Second End If End Get End Property Public Shared ReadOnly Property MinutesOfDay() As Integer Get If NeedServerObject() = True Then Dim data() As String = ServerTimeData.Split(CChar(",")) Dim hours As Integer = CInt(data(0)) Dim minutes As Integer = CInt(data(1)) minutes += CInt(Math.Abs((Date.Now - LastServerDataReceived).Minutes)) Return hours * 60 + minutes Else Return My.Computer.Clock.LocalTime.Hour * 60 + My.Computer.Clock.LocalTime.Minute End If End Get End Property Private Shared Function NeedServerObject() As Boolean Return JoinServerScreen.Online = True And ConnectScreen.Connected = True End Function ''' ''' Returns the region weather and gets the server weather if needed. ''' Public Shared Function GetCurrentRegionWeather() As Weathers If NeedServerObject() = True Then Return ServerWeather Else Return _regionWeather End If End Function Public Shared Property RegionWeather() As Weathers Get Return _regionWeather End Get Set(value As Weathers) _regionWeather = value End Set End Property Public Shared Property RegionWeatherSet() As Boolean Get Return _regionWeatherSet End Get Set(value As Boolean) _regionWeatherSet = value End Set End Property End Class