当前位置: 首页>>代码示例>>C#>>正文


C# Vector3D.ToShader方法代码示例

本文整理汇总了C#中IrrlichtNETCP.Vector3D.ToShader方法的典型用法代码示例。如果您正苦于以下问题:C# Vector3D.ToShader方法的具体用法?C# Vector3D.ToShader怎么用?C# Vector3D.ToShader使用的例子?那么, 这里精选的方法代码示例或许可以为您提供帮助。您也可以进一步了解该方法所在IrrlichtNETCP.Vector3D的用法示例。


在下文中一共展示了Vector3D.ToShader方法的1个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的C#代码示例。

示例1: ShaderEvent

        public override void ShaderEvent(IrrlichtNETCP.MaterialRendererServices services, int userData)
        {
            if (updateOnce)
            {
                return;
            }
            else
            {
                updateOnce = true;
            }

            if (Reference.Viewer.SkyQuality == Viewer.ShaderLevelType.High)
            {
                Matrix4 worldViewProj = Reference.VideoDriver.GetTransform(TransformationState.Projection);
                worldViewProj *= Reference.VideoDriver.GetTransform(TransformationState.View);
                worldViewProj *= Reference.VideoDriver.GetTransform(TransformationState.World);
                services.SetVertexShaderConstant("WVPMatrix", worldViewProj.ToShader());
            }

            Vector3D camPos, camPosXZ;
            camPosXZ = camPos = new Vector3D(Reference.Viewer.Camera.Position.X, Reference.Viewer.Camera.Position.Y, Reference.Viewer.Camera.Position.Z);
            camPosXZ.Y = 0f;

            //// Sun position calculation
            SkyMaths.AltAzAngles sunAngles = SkyMaths.CalculateSunPosition(julianDay + (float)worldTime.TimeOfDay.TotalDays, LATITUDE);
            sunPosition = SkyMaths.MoveAroundPoint(camPosXZ, 12500f, sunAngles.azimuth, -sunAngles.altitude);
            if (sunNode != null)
                sunNode.Position = sunPosition * 0.4f;

            //// Moon position (approximate inverse of the sun, l0lz.)
            moonPosition = sunPosition;
            moonPosition.X *= -1.0f;
            moonPosition.Y *= -1.0f;
            moonPosition.Z *= -1.0f;
            moonPosition = moonPosition.Normalize();
            if (moonNode != null)
                moonNode.Position = moonPosition * 9000.0f;

            // Set the sun normalized vector and the sunTheta to the shader
            Vector3D sunNormedPos = new Vector3D();
            sunNormedPos = sunPosition - camPosXZ;
            sunNormedPos = sunNormedPos.Normalize();
            float sunTheta = SkyMaths.VectorToTheta(sunNormedPos);

            // Sun lightning direction
            Vector3D sunDirection = new Vector3D();
            sunDirection = sunPosition - camPosXZ;
            sunDirection = sunDirection.Normalize();

            // Stars and moon opacity
            moonIntensity = SkyMaths.Saturate(SkyMaths.Lerp(sunAngles.altitude, 0f, SUN_SET)) * 0.95f;
            moonIntensity += 0.05f;

            // A hack to kill the orange tones in the nightsky
            float darkness = 1f - (moonIntensity - 0.05f);

            // Calculate the constant matrices
            SkyMaths.xyYColor _zenithColors = SkyMaths.SkyZenithColor(turbidity, sunTheta);
            Vector3D _zenithColorsVector = new Vector3D(_zenithColors.x, _zenithColors.y, _zenithColors.Y);
            SkyMaths.xyYCoeffs _distribCoeffs = SkyMaths.DistributionCoefficients(turbidity);

            if (Reference.Viewer.SkyQuality == Viewer.ShaderLevelType.High)
            {
                services.SetVertexShaderConstant("SunTheta", sunTheta);
                services.SetVertexShaderConstant("SunVector", sunNormedPos.ToShader());
                services.SetVertexShaderConstant("NightDarkness", darkness);
                services.SetVertexShaderConstant("ZenithColor", _zenithColorsVector.ToShader());

                for (int i = 0; i < 5; i++)
                {
                    services.SetVertexShaderConstant("_xDistribCoeffs[" + i + "]", _distribCoeffs.x[i]);
                    services.SetVertexShaderConstant("_yDistribCoeffs[" + i + "]", _distribCoeffs.y[i]);
                    services.SetVertexShaderConstant("_YDistribCoeffs[" + i + "]", _distribCoeffs.Y[i]);
                }

                // Set the adaptative luminance and gamma corrections
                float gamma = 1f / (1.6f + (turbidity - 2f) * 0.1f);
                services.SetVertexShaderConstant("InvGammaCorrection", 1.5f * gamma);
                services.SetVertexShaderConstant("InvPowLumFactor", gamma);
                services.SetVertexShaderConstant("InvNegMaxLum", -1.25f / SkyMaths.MaximumLuminance(turbidity, sunTheta, _zenithColors, _distribCoeffs));

                float calcAlpha = ((12 - 1) * 60 * 60 + (60 - 1) * 60 + 60) - ((worldTime.Hour - 1) * 60 * 60 + (worldTime.Minute - 1) * 60 + worldTime.Second);
                calcAlpha = 1 - Math.Abs(calcAlpha) / cloudChangeSec;
                calcAlpha = Util.Clamp<float>(calcAlpha, 0, 1);
                calcAlpha = calcAlpha * calcAlpha;

                float minAlpha = 0.05f;
                calcAlpha = (calcAlpha * 1.5f) + minAlpha;
                calcAlpha = Util.Clamp<float>(calcAlpha, 0, 1);

                services.SetPixelShaderConstant("CloudAlpha", calcAlpha);
                services.SetPixelShaderConstant("BlendingRate", 0);
            }

            // Clouds coloring
            float[] atmoCol = SkyMaths.AtmosphereColor(turbidity, sunTheta, _zenithColors, _distribCoeffs);
            Vector3D atmoColVec = new Vector3D(atmoCol[0], atmoCol[1], atmoCol[2]);
            float dayState = SkyMaths.Saturate(SkyMaths.Lerp(sunAngles.altitude, (float)(Math.PI * 1f / (6f - turbidity / 2f)), SUN_RISE));

            // Sun lightning intensity
//.........这里部分代码省略.........
开发者ID:caocao,项目名称:3di-viewer-rei,代码行数:101,代码来源:Sky.cs


注:本文中的IrrlichtNETCP.Vector3D.ToShader方法示例由纯净天空整理自Github/MSDocs等开源代码及文档管理平台,相关代码片段筛选自各路编程大神贡献的开源项目,源码版权归原作者所有,传播和使用请参考对应项目的License;未经允许,请勿转载。