P3D-Legacy/P3D/Resources/ModelManager.vb

92 lines
4.2 KiB
VB.net
Raw Normal View History

2016-09-19 03:26:44 +02:00
Public Class ModelManager
2016-09-07 18:50:38 +02:00
Shared ModelList As New Dictionary(Of String, Model)
Public Const MODELSCALE As Single = 0.00625F
2016-09-07 18:50:38 +02:00
Public Shared Function GetModel(ByVal Path As String) As Model
Dim cContent As ContentManager = ContentPackManager.GetContentManager(Path, ".xnb")
Dim tKey As String = cContent.RootDirectory & "\" & Path
If ModelList.Keys.Contains(tKey) = False Then
Dim m As Model = cContent.Load(Of Model)(Path)
ModelList.Add(tKey, CreateShallowCopy(m))
End If
Return ModelList(tKey)
End Function
''' <summary>
''' This method creates a shallow copy of the Model class.
''' And because there's no other way to properly do this, we access its Protected method MemberwiseClone (inherited from Object) via reflection.
''' </summary>
''' <param name="m">The model to copy.</param>
Private Shared Function CreateShallowCopy(ByVal m As Model) As Model
Dim memberWiseCloneMethod As Reflection.MethodInfo = m.GetType().GetMethod("MemberwiseClone", Reflection.BindingFlags.NonPublic Or 'I AM SO SORRY!!!
Reflection.BindingFlags.Instance Or
Reflection.BindingFlags.FlattenHierarchy)
Return CType(memberWiseCloneMethod.Invoke(m, {}), Model) 'invokes the method on the passed in Model instance to create a shallow copy.
End Function
Public Shared Function ModelExist(ByVal Path As String) As Boolean
Dim cContent As ContentManager = ContentPackManager.GetContentManager(Path, ".xnb")
If cContent.RootDirectory = "Content" Then
If GameModeManager.ActiveGameMode.DirectoryName <> "Kolben" Then
Return False
End If
End If
2016-09-07 18:50:38 +02:00
If Path = "" Then
Return False
End If
If System.IO.File.Exists(GameController.GamePath & "\" & cContent.RootDirectory & "\" & Path & ".xnb") = True Then
Return True
Else
Return False
End If
End Function
Public Shared Sub Clear()
ModelList.Clear()
End Sub
Public Shared Function DrawModelToTexture(ByVal modelName As String, ByVal renderTarget As RenderTarget2D, ByVal modelPosition As Vector3, ByVal cameraPosition As Vector3, ByVal cameraRotation As Vector3, ByVal Scale As Single, ByVal enableLight As Boolean) As Texture2D
Dim _scale As Single = Scale * MODELSCALE
2016-09-07 18:50:38 +02:00
Core.GraphicsDevice.SetRenderTarget(renderTarget)
Core.GraphicsDevice.Clear(Color.Transparent)
Core.GraphicsDevice.BlendState = BlendState.Opaque
Core.GraphicsDevice.SamplerStates(0) = Core.sampler
Dim m As Model = ModelManager.GetModel(modelName)
If enableLight = True Then
For Each mesh As ModelMesh In m.Meshes
For Each Effect As BasicEffect In mesh.Effects
Lighting.UpdateLighting(Effect, True)
Effect.DirectionalLight0.DiffuseColor = New Vector3(0.7)
Effect.DirectionalLight1.DiffuseColor = New Vector3(0.7)
Effect.DirectionalLight2.DiffuseColor = New Vector3(0.7)
Effect.DirectionalLight0.Direction = New Vector3(0, 1, 0)
Effect.DirectionalLight1.Direction = New Vector3(1, 0, 0)
Effect.DirectionalLight2.Direction = New Vector3(0, 0, 1)
Effect.DirectionalLight0.Enabled = True
Effect.DirectionalLight1.Enabled = True
Effect.DirectionalLight2.Enabled = True
Next
Next
End If
m.Draw(Matrix.CreateFromYawPitchRoll(cameraRotation.X, cameraRotation.Y, cameraRotation.Z) * Matrix.CreateScale(New Vector3(_scale)) * Matrix.CreateTranslation(modelPosition), Matrix.CreateLookAt(cameraPosition, modelPosition, Vector3.Up), Matrix.CreatePerspectiveFieldOfView(MathHelper.ToRadians(45.0F), Core.GraphicsDevice.Viewport.AspectRatio, 0.1F, 10000.0F))
2016-09-07 18:50:38 +02:00
Core.GraphicsDevice.SetRenderTarget(Nothing)
Return renderTarget
End Function
2016-09-19 03:26:44 +02:00
End Class