320 lines
13 KiB
VB.net
320 lines
13 KiB
VB.net
Public Class SkyDome
|
|
|
|
Private SkydomeModel As Model
|
|
Public TextureUp As Texture2D
|
|
Public TextureDown As Texture2D
|
|
Dim TextureSun As Texture2D
|
|
Dim TextureMoon As Texture2D
|
|
|
|
Public Yaw As Single = 0
|
|
|
|
Const FASTTIMECYCLE As Boolean = False
|
|
|
|
Public Sub New()
|
|
SkydomeModel = Core.Content.Load(Of Model)("SkyDomeResource\SkyDome")
|
|
|
|
TextureUp = TextureManager.GetTexture("SkyDomeResource\Sky_Day")
|
|
TextureDown = TextureManager.GetTexture("SkyDomeResource\Stars")
|
|
TextureSun = TextureManager.GetTexture("SkyDomeResource\sun")
|
|
TextureMoon = TextureManager.GetTexture("SkyDomeResource\moon")
|
|
|
|
SetLastColor()
|
|
End Sub
|
|
|
|
Public Sub Update()
|
|
Yaw += 0.0001F
|
|
While Yaw > MathHelper.TwoPi
|
|
Yaw -= MathHelper.TwoPi
|
|
End While
|
|
SetLastColor()
|
|
|
|
If FASTTIMECYCLE = True Then
|
|
Second += 60
|
|
If Second = 60 Then
|
|
Second = 0
|
|
Minute += 1
|
|
If Minute = 60 Then
|
|
Minute = 0
|
|
Hour += 1
|
|
If Hour = 24 Then
|
|
Hour = 0
|
|
End If
|
|
End If
|
|
End If
|
|
End If
|
|
End Sub
|
|
|
|
Dim Hour As Integer = 0
|
|
Dim Minute As Integer = 0
|
|
Dim Second As Integer = 0
|
|
|
|
Public Sub Draw(ByVal FOV As Single)
|
|
If Screen.Level.World.EnvironmentType = World.EnvironmentTypes.Outside Then
|
|
Dim DrawSky As Boolean
|
|
Select Case World.GetWeatherFromWeatherType(Screen.Level.WeatherType)
|
|
Case World.Weathers.Fog, World.Weathers.Blizzard, World.Weathers.Thunderstorm
|
|
DrawSky = False
|
|
Case Else
|
|
DrawSky = True
|
|
End Select
|
|
If DrawSky = True Then ' Don't render the sky if the weather is set to Fog.
|
|
RenderHalf(FOV, Yaw, 0.0F, True, GetSkyTexture(), 20, 1.0F) ' Draw the sky
|
|
RenderHalf(FOV, MathHelper.TwoPi, 0.0F, True, TextureDown, 18, GetStarsAlpha()) ' Draw the stars.
|
|
If GetSunAlpha() > 0 Then
|
|
RenderHalf(FOV, MathHelper.TwoPi, 0.0F, True, TextureSun, 16, 1.0F) ' Draw the Sun.
|
|
Else
|
|
RenderHalf(FOV, MathHelper.TwoPi, 0.0F, True, TextureMoon, 16, 1.0F) ' Draw the Moon.
|
|
End If
|
|
End If
|
|
If World.GetWeatherFromWeatherType(Screen.Level.WeatherType) <> World.Weathers.Fog Then
|
|
RenderHalf(FOV, MathHelper.TwoPi - Yaw * 2, 0.0F, True, GetCloudsTexture(), 12, GetCloudAlpha) ' Draw the clouds.
|
|
End If
|
|
Else
|
|
If Screen.Level.World.EnvironmentType = World.EnvironmentTypes.Cave Or Screen.Level.World.EnvironmentType = World.EnvironmentTypes.Forest Then
|
|
RenderHalf(FOV, MathHelper.TwoPi, 0.0F, True, TextureUp, 20, 1.0F) ' Draw the sky
|
|
Else
|
|
RenderHalf(FOV, Yaw, 0.0F, True, TextureUp, 16, 1.0F) ' Draw the sky
|
|
RenderHalf(FOV, MathHelper.TwoPi, 0.0F, True, TextureSun, 12, GetSunAlpha()) ' Draw the Sun.
|
|
RenderHalf(FOV, MathHelper.TwoPi - Yaw, 0.0F, True, TextureManager.GetTexture("SkyDomeResource\Clouds_Day"), 8, GetCloudAlpha()) ' Draw the clouds.
|
|
End If
|
|
If Not TextureDown Is Nothing Then
|
|
RenderHalf(FOV, Yaw, 0.0F, False, TextureDown, 16, 1.0F)
|
|
End If
|
|
End If
|
|
End Sub
|
|
|
|
Private Sub RenderHalf(ByVal FOV As Single, ByVal useYaw As Single, ByVal usePitch As Single, ByVal up As Boolean, ByVal texture As Texture2D, ByVal scale As Single, ByVal alpha As Single)
|
|
Dim Roll As Single = 0.0F
|
|
If up = False Then
|
|
Roll = Math.PI
|
|
End If
|
|
|
|
Dim previousBlendState = Core.GraphicsDevice.BlendState
|
|
Core.GraphicsDevice.BlendState = BlendState.NonPremultiplied
|
|
|
|
For Each ModelMesh As ModelMesh In SkydomeModel.Meshes
|
|
For Each BasicEffect As BasicEffect In ModelMesh.Effects
|
|
BasicEffect.World = Matrix.CreateScale(scale) * Matrix.CreateTranslation(New Vector3(Screen.Camera.Position.X, Screen.Camera.Position.Y - 2, Screen.Camera.Position.Z)) * Matrix.CreateFromYawPitchRoll(useYaw, usePitch, Roll)
|
|
|
|
BasicEffect.View = Screen.Camera.View
|
|
BasicEffect.Projection = Matrix.CreatePerspectiveFieldOfView(MathHelper.ToRadians(FOV), Core.GraphicsDevice.Viewport.AspectRatio, 0.01, 10000)
|
|
|
|
BasicEffect.TextureEnabled = True
|
|
BasicEffect.Texture = texture
|
|
BasicEffect.Alpha = alpha
|
|
|
|
If BasicEffect.Texture Is TextureDown Then
|
|
BasicEffect.DiffuseColor = New Vector3(1)
|
|
Else
|
|
Select Case Screen.Level.World.CurrentMapWeather
|
|
Case World.Weathers.Clear, World.Weathers.Sunny
|
|
BasicEffect.DiffuseColor = New Vector3(1)
|
|
Case World.Weathers.Rain
|
|
BasicEffect.DiffuseColor = New Vector3(0.4, 0.4, 0.7)
|
|
Case World.Weathers.Snow
|
|
BasicEffect.DiffuseColor = New Vector3(0.8)
|
|
Case World.Weathers.Underwater
|
|
BasicEffect.DiffuseColor = New Vector3(0.1, 0.3, 0.9)
|
|
Case World.Weathers.Fog
|
|
BasicEffect.DiffuseColor = New Vector3(0.7, 0.7, 0.8)
|
|
Case World.Weathers.Sandstorm
|
|
BasicEffect.DiffuseColor = New Vector3(0.8, 0.5, 0.2)
|
|
Case World.Weathers.Ash
|
|
BasicEffect.DiffuseColor = New Vector3(0.5, 0.5, 0.5)
|
|
Case World.Weathers.Blizzard
|
|
BasicEffect.DiffuseColor = New Vector3(0.6, 0.6, 0.6)
|
|
End Select
|
|
End If
|
|
|
|
If BasicEffect.DiffuseColor <> New Vector3(1) Then
|
|
BasicEffect.DiffuseColor = GetWeatherColorMultiplier(BasicEffect.DiffuseColor)
|
|
End If
|
|
Next
|
|
|
|
ModelMesh.Draw()
|
|
Next
|
|
|
|
Core.GraphicsDevice.BlendState = previousBlendState
|
|
|
|
End Sub
|
|
|
|
Shared DaycycleTextureData() As Color = Nothing
|
|
Shared DaycycleTexture As Texture2D = Nothing
|
|
Shared LastSkyColor As Color = New Color(0, 0, 0, 0)
|
|
Shared LastEntityColor As Color = New Color(0, 0, 0, 0)
|
|
|
|
Public Shared Function GetDaytimeColor(ByVal shader As Boolean) As Color
|
|
If shader = True Then
|
|
Return LastEntityColor
|
|
Else
|
|
If World.IsAurora = True Then
|
|
Return New Color(64, 101, 164)
|
|
End If
|
|
Select Case Screen.Level.DayTime
|
|
Case 1
|
|
Return New Color(40, 88, 136)
|
|
Case 2
|
|
Return New Color(168, 224, 248)
|
|
Case 3
|
|
Return New Color(48, 200, 248)
|
|
Case 4
|
|
Return New Color(192, 152, 184)
|
|
End Select
|
|
End If
|
|
End Function
|
|
|
|
Private Sub SetLastColor()
|
|
If DaycycleTextureData Is Nothing Then
|
|
Dim DaycycleTexture As Texture2D = TextureManager.GetTexture("SkyDomeResource\daycycle")
|
|
DaycycleTextureData = New Color(DaycycleTexture.Width * DaycycleTexture.Height - 1) {}
|
|
DaycycleTexture.GetData(DaycycleTextureData)
|
|
SkyDome.DaycycleTexture = DaycycleTexture
|
|
End If
|
|
|
|
Dim pixel As Integer = GetTimeValue()
|
|
|
|
Dim pixelColor As Color = DaycycleTextureData(pixel)
|
|
If pixelColor <> LastSkyColor Then
|
|
LastSkyColor = pixelColor
|
|
LastEntityColor = DaycycleTextureData((pixel + DaycycleTexture.Width).Clamp(0, DaycycleTexture.Width * DaycycleTexture.Height - 1))
|
|
End If
|
|
End Sub
|
|
|
|
Private Function GetCloudAlpha() As Single
|
|
If Screen.Level.World.EnvironmentType = World.EnvironmentTypes.Outside And World.IsAurora = False Then
|
|
Select Case World.GetWeatherFromWeatherType(Screen.Level.WeatherType)
|
|
Case World.Weathers.Blizzard, World.Weathers.Thunderstorm
|
|
Return 0.25F
|
|
Case Else
|
|
Return 1.0F
|
|
End Select
|
|
Else
|
|
Return 0.0F
|
|
End If
|
|
End Function
|
|
|
|
Private Function GetStarsAlpha() As Single
|
|
If Screen.Level.World.EnvironmentType = World.EnvironmentTypes.Outside And World.IsAurora = False Then
|
|
Select Case Screen.Level.DayTime
|
|
Case 1
|
|
Return 1.0F
|
|
Case 2
|
|
Return 0.0F
|
|
Case 3
|
|
Return 0.0F
|
|
Case 4
|
|
Return 0.0F
|
|
Case Else
|
|
Return 0.0F
|
|
End Select
|
|
Else
|
|
Return 0.0F
|
|
End If
|
|
End Function
|
|
|
|
Private Function GetSunAlpha() As Single
|
|
If Screen.Level.World.EnvironmentType = World.EnvironmentTypes.Outside And World.IsAurora = False Then
|
|
Select Case Screen.Level.DayTime
|
|
Case 1
|
|
Return 0.0F
|
|
Case 2
|
|
Return 1.0F
|
|
Case 3
|
|
Return 1.0F
|
|
Case 4
|
|
Return 0.0F
|
|
Case Else
|
|
Return 0.0F
|
|
End Select
|
|
Else
|
|
Return 0.0F
|
|
End If
|
|
End Function
|
|
|
|
Private Function GetCloudsTexture() As Texture2D
|
|
Dim time As World.DayTimes = World.GetTime
|
|
|
|
Select Case Screen.Level.World.CurrentMapWeather
|
|
Case World.Weathers.Rain, World.Weathers.Blizzard, World.Weathers.Thunderstorm, World.Weathers.Snow
|
|
Return TextureManager.GetTexture("SkyDomeResource\Clouds_Weather")
|
|
Case World.Weathers.Clear
|
|
Select Case Screen.Level.DayTime
|
|
Case 1
|
|
Return TextureManager.GetTexture("SkyDomeResource\Clouds_Night")
|
|
Case 2
|
|
Return TextureManager.GetTexture("SkyDomeResource\Clouds_Morning")
|
|
Case 3
|
|
Return TextureManager.GetTexture("SkyDomeResource\Clouds_Day")
|
|
Case 4
|
|
Return TextureManager.GetTexture("SkyDomeResource\Clouds_Evening")
|
|
End Select
|
|
If time = World.DayTimes.Morning Then
|
|
Return TextureManager.GetTexture("SkyDomeResource\Clouds_Morning")
|
|
ElseIf time = World.DayTimes.Day Then
|
|
Return TextureManager.GetTexture("SkyDomeResource\Clouds_Day")
|
|
ElseIf time = World.DayTimes.Evening Then
|
|
Return TextureManager.GetTexture("SkyDomeResource\Clouds_Evening")
|
|
Else
|
|
Return TextureManager.GetTexture("SkyDomeResource\Clouds_Night")
|
|
End If
|
|
End Select
|
|
Return Nothing
|
|
End Function
|
|
Private Function GetSkyTexture() As Texture2D
|
|
If World.IsAurora Then
|
|
Return TextureManager.GetTexture("SkyDomeResource\AuroraBorealis")
|
|
End If
|
|
Select Case Screen.Level.DayTime
|
|
Case 1
|
|
Return TextureManager.GetTexture("SkyDomeResource\Sky_Night")
|
|
Case 2
|
|
Return TextureManager.GetTexture("SkyDomeResource\Sky_Morning")
|
|
Case 3
|
|
Return TextureManager.GetTexture("SkyDomeResource\Sky_Day")
|
|
Case 4
|
|
Return TextureManager.GetTexture("SkyDomeResource\Sky_Evening")
|
|
End Select
|
|
Dim time As World.DayTimes = World.GetTime
|
|
Select Case Screen.Level.World.CurrentMapWeather
|
|
Case World.Weathers.Clear
|
|
If time = World.DayTimes.Morning Then
|
|
Return TextureManager.GetTexture("SkyDomeResource\Sky_Morning")
|
|
ElseIf time = World.DayTimes.Day Then
|
|
Return TextureManager.GetTexture("SkyDomeResource\Sky_Day")
|
|
ElseIf time = World.DayTimes.Evening Then
|
|
Return TextureManager.GetTexture("SkyDomeResource\Sky_Evening")
|
|
Else
|
|
Return TextureManager.GetTexture("SkyDomeResource\Sky_Night")
|
|
End If
|
|
End Select
|
|
Return TextureUp
|
|
End Function
|
|
|
|
Public Function GetWeatherColorMultiplier(ByVal v As Vector3) As Vector3
|
|
Dim progress As Integer = GetTimeValue()
|
|
|
|
Dim p As Single = 0.0F
|
|
|
|
If progress < 720 Then
|
|
p = CSng((720 - progress) / 720)
|
|
Else
|
|
p = CSng((progress - 720) / 720)
|
|
End If
|
|
|
|
Return New Vector3(v.X + ((1 - v.X) * p),
|
|
v.Y + ((1 - v.Y) * p),
|
|
v.Z + ((1 - v.Z) * p))
|
|
End Function
|
|
|
|
Private Function GetTimeValue() As Integer
|
|
If FASTTIMECYCLE = True Then
|
|
Return Hour * 60 + Minute
|
|
Else
|
|
If World.IsMainMenu Then
|
|
Return 720
|
|
End If
|
|
Return World.MinutesOfDay
|
|
End If
|
|
End Function
|
|
|
|
End Class |