''' ''' A class to handle entity lighting. ''' Public Class Lighting Shared LightingColorTexture As Texture2D = TextureManager.GetTexture("SkyDomeResource\LightingColors") Shared FogColorTexture As Texture2D = TextureManager.GetTexture("SkyDomeResource\FogColors") #Region "Methods" Public Shared Function GetEnvironmentColor(TextureType As Integer) As Vector3 '0 = Directional light, 1 = Ambient light, 2 = Fog color Dim ColorTexture As Texture2D Dim EnvironmentColor As Vector3 = Nothing Dim x As Integer = 0 Dim y As Integer = 0 Select Case TextureType Case 0 x = Screen.Level.DayTime - 1 If x >= 0 AndAlso x <= 3 Then ColorTexture = LightingColorTexture Dim ColorData(0) As Color ColorTexture.GetData(0, New Rectangle(x, 0, 1, 1), ColorData, 0, 1) Dim DarkOrBrightData(0) As Color ColorTexture.GetData(0, New Rectangle(x, 1, 1, 1), DarkOrBrightData, 0, 1) EnvironmentColor = ColorData(0).ToVector3 If DarkOrBrightData(0) = Color.Black Then EnvironmentColor = New Vector3(0.0F) - EnvironmentColor End If Else EnvironmentColor = New Vector3(0.0F) End If Case 1 x = Screen.Level.DayTime - 1 If x >= 0 AndAlso x <= 3 Then ColorTexture = LightingColorTexture Dim ColorData(0) As Color ColorTexture.GetData(0, New Rectangle(x, 2, 1, 1), ColorData, 0, 1) Dim DarkOrBrightData(0) As Color ColorTexture.GetData(0, New Rectangle(x, 3, 1, 1), DarkOrBrightData, 0, 1) EnvironmentColor = ColorData(0).ToVector3 If DarkOrBrightData(0) = Color.Black Then EnvironmentColor = New Vector3(0.0F) - EnvironmentColor End If Else EnvironmentColor = New Vector3(0.0F) End If Case 2 ColorTexture = FogColorTexture Select Case Screen.Level.EnvironmentType Case 0 x = Screen.Level.DayTime - 1 If x > 2 Then x = 0 y += 1 End If Case 1 x = 1 y = 1 Case 2 x = 2 y = 1 Case 3 x = 0 y = 2 Case 4 x = 1 y = 2 Case 5 x = 2 y = 2 End Select Dim ColorData(0) As Color ColorTexture.GetData(0, New Rectangle(x, y, 1, 1), ColorData, 0, 1) EnvironmentColor = ColorData(0).ToVector3 End Select Return EnvironmentColor End Function ''' ''' Updates the lighting values of a BasicEffect instance. ''' ''' A reference to the BasicEffect that should receive the lighting update. ''' Checks, if the lighting update on the effect should be forced. Public Shared Sub UpdateLighting(ByRef refEffect As BasicEffect, Optional ByVal ForceLighting As Boolean = False) If Core.GameOptions.LightingEnabled = True Or ForceLighting = True Then ' Only update the lighting if either the currently loaded level instance allows this, or it's getting forced. ' Set default parameters: refEffect.LightingEnabled = True ' Enable lighting (gets disabled later, if not used) refEffect.PreferPerPixelLighting = True ' Yes. Please. refEffect.SpecularPower = 2000.0F ' LightType results: ' 0 = Night ' 1 = Morning ' 2 = Day ' 3 = Evening ' Anything higher than 3 = No Lighting Select Case GetLightingType() Case 0 ' Night refEffect.AmbientLightColor = GetEnvironmentColor(1) refEffect.DirectionalLight0.DiffuseColor = GetEnvironmentColor(0) refEffect.DirectionalLight0.Direction = Vector3.Normalize(New Vector3(1.0F, 1.0F, -1.0F)) refEffect.DirectionalLight0.SpecularColor = New Vector3(0.0F) refEffect.DirectionalLight0.Enabled = True Case 1 ' Morning refEffect.AmbientLightColor = GetEnvironmentColor(1) refEffect.DirectionalLight0.DiffuseColor = GetEnvironmentColor(0) refEffect.DirectionalLight0.Direction = Vector3.Normalize(New Vector3(-1.0F, 0.0F, 1.0F)) refEffect.DirectionalLight0.SpecularColor = New Vector3(0.0F) refEffect.DirectionalLight0.Enabled = True Case 2 ' Day refEffect.AmbientLightColor = GetEnvironmentColor(1) refEffect.DirectionalLight0.DiffuseColor = GetEnvironmentColor(0) refEffect.DirectionalLight0.Direction = Vector3.Normalize(New Vector3(-1.0F, 0.0F, 1.0F)) refEffect.DirectionalLight0.SpecularColor = New Vector3(0.0F) refEffect.DirectionalLight0.Enabled = True Case 3 ' Evening refEffect.AmbientLightColor = GetEnvironmentColor(1) refEffect.DirectionalLight0.DiffuseColor = GetEnvironmentColor(0) refEffect.DirectionalLight0.Direction = Vector3.Normalize(New Vector3(1.0F, 1.0F, -1.0F)) refEffect.DirectionalLight0.SpecularColor = New Vector3(0.0F) refEffect.DirectionalLight0.Enabled = True Case Else 'Disable lighting on the effect refEffect.LightingEnabled = False End Select Else ' Disable lighting if the effect isn't supposed to have light. refEffect.LightingEnabled = False End If End Sub Public Shared Function GetLightingType() As Integer Dim LightType As Integer = CInt(World.GetTime()) ' Determine default lighting type by the world time. ' Level's lighttype values: ' 0 = Get lighting from the current time of day. ' 1 = Disable lighting ' 2 = Always Night ' 3 = Always Morning ' 4 = Always Day ' 5 = Always Evening If Screen.Level.EnvironmentType = World.EnvironmentTypes.Outside Then Select Case Screen.Level.DayTime Case 1 LightType = 0 Case 2 LightType = 1 Case 3 LightType = 2 Case 4 LightType = 3 End Select End If If Screen.Level.LightingType = 1 Then ' If the level lighting type is 1, disable lighting (set index to 99). LightType = 99 End If If Screen.Level.LightingType > 1 And Screen.Level.LightingType < 6 Then ' If the level's lighting type is 2, 3, 4 or 5, set to the respective LightType (set time of day). LightType = Screen.Level.LightingType - 2 End If If Screen.Level.LightingType = 6 AndAlso Screen.Level.EnvironmentType = 1 OrElse Screen.Level.LightingType > 6 Then LightType = 99 End If Return LightType End Function #End Region End Class