/// <summary>
        /// Add Each Nif Geometry as an Instanced Meshes with World Matrix computed
        /// </summary>
        /// <param name="geometries">Collection of Nif Geometry</param>
        protected void AddNifInstancesYZSwapped(IEnumerable <NifGeometry> geometries)
        {
            var result = new List <KeyValuePair <int, Matrix> >();

            foreach (var geometry in geometries)
            {
                var trees     = TreeReplacement[geometry.FileName];
                var nifMatrix = ComputeWorldMatrix(geometry, UnitFactor);
                // Tree match, Compose Matrix
                if (trees.Length > 0)
                {
                    foreach (var tree in trees)
                    {
                        Matrix instance;
                        Matrix translate;
                        ZoneDrawingExtensions.CreateTranslation(tree.OffsetX * UnitFactor, tree.OffsetZ * UnitFactor, tree.OffsetY * UnitFactor, out instance);
                        ZoneDrawingExtensions.Mult(ref nifMatrix, ref instance, out translate);
                        nifMatrix = translate;
                    }
                }

                result.Add(new KeyValuePair <int, Matrix>(geometry.MeshID, nifMatrix));
            }

            InstancesMatrix = InstancesMatrix.Concat(result).ToArray();
        }
Exemplo n.º 2
0
        /// <summary>
        /// Get World Matrix For NifGeometry
        /// </summary>
        /// <param name="nifGeom"></param>
        /// <param name="UnitFactor"></param>
        /// <param name="heightCalculator"></param>
        /// <returns></returns>
        protected static Matrix ComputeWorldMatrix(NifGeometry nifGeom, float UnitFactor, TerrainHeightCalculator heightCalculator)
        {
            if (nifGeom == null)
            {
                throw new ArgumentNullException("nifGeom");
            }

            // Find Ground
            float nifHeight = nifGeom.Z * UnitFactor;

            if (nifGeom.OnGround)
            {
                nifHeight = heightCalculator[nifGeom.X, nifGeom.Y] * UnitFactor;
            }

            // Get Translation (XY Inverted), Scale, Rotation
            Matrix translation;

            ZoneDrawingExtensions.CreateTranslation(nifGeom.X * UnitFactor, nifHeight, nifGeom.Y * UnitFactor, out translation);
            Matrix scale;

            ZoneDrawingExtensions.CreateScale(nifGeom.Scale * UnitFactor, out scale);
            Matrix rotation;

            ZoneDrawingExtensions.CreateRotation(new Vector3(nifGeom.RotationX, nifGeom.RotationY, nifGeom.RotationZ), nifGeom.Angle, out rotation);

            Matrix result = Matrix.Identity;

            // Flip if needed
            if (nifGeom.Flip)
            {
                Matrix flip;
                ZoneDrawingExtensions.CreateScale(-1f, 1f, 1f, out flip);
                result = flip;
            }

            Matrix intermediateResult;

            // Combine Scale, Rotation, Invertion Rotation, Translation
            ZoneDrawingExtensions.Mult(ref result, ref scale, out intermediateResult);
            result = intermediateResult;
            ZoneDrawingExtensions.Mult(ref result, ref rotation, out intermediateResult);
            result = intermediateResult;
            ZoneDrawingExtensions.Mult(ref result, ref RotationMatrix, out intermediateResult);
            result = intermediateResult;
            ZoneDrawingExtensions.Mult(ref result, ref translation, out intermediateResult);
            result = intermediateResult;

            // Combine Matrix with Parent Matrix
            if (nifGeom.RelativeTo != null)
            {
                Matrix relativeMatrix = ComputeWorldMatrix(nifGeom.RelativeTo, UnitFactor, heightCalculator);
                ZoneDrawingExtensions.Mult(ref result, ref relativeMatrix, out intermediateResult);
                result = intermediateResult;
            }

            return(result);
        }
Exemplo n.º 3
0
        public CityRenderer(int id, IEnumerable <FileInfo> files, ZoneType type, ClientDataWrapper wrapper)
            : base(id, files, type, wrapper)
        {
            var nifs = CityNifs;

            AddNifCache(nifs);
            Matrix scaleMatrix;

            ZoneDrawingExtensions.CreateScale(UnitFactor, UnitFactor, UnitFactor, out scaleMatrix);
            Matrix rotated;

            ZoneDrawingExtensions.Mult(ref scaleMatrix, ref RotationMatrix, out rotated);
            InstancesMatrix = nifs.Select(n => new KeyValuePair <int, Matrix>(n.Key, rotated)).ToArray();
        }