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


C# Vessel.GetSrfVelocity方法代码示例

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


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

示例1: GetVelocity

 /// <summary>
 /// Returns the velocity of the reference frame in world-space.
 /// </summary>
 public static Vector3d GetVelocity(ReferenceFrame referenceFrame, Vessel vessel)
 {
     switch (referenceFrame) {
     case ReferenceFrame.Orbital:
     case ReferenceFrame.Maneuver:
         return Vector3d.zero;
     // Relative to the surface velocity vector
     case ReferenceFrame.Surface:
         return ((Vector3d)vessel.GetObtVelocity ()) - ((Vector3d)vessel.GetSrfVelocity ());
     // Relative to the target's velocity vector, or relative to the orbit if there is no target
     case ReferenceFrame.Target:
         throw new NotImplementedException ();
     // Relative to the negative surface normal of the target docking port, or relative to the target if the target is not a docking port
     case ReferenceFrame.Docking:
         throw new NotImplementedException ();
     default:
         throw new ArgumentException ("No such reference frame");
     }
 }
开发者ID:BasConijn,项目名称:krpc,代码行数:22,代码来源:ReferenceFrameTransform.cs

示例2: FixedUpdate

        void FixedUpdate()
        {
            time = Planetarium.GetUniversalTime();
            fixedDeltaTime = TimeWarp.fixedDeltaTime;

            vesselName = null;
            engineName = null;

            vessel = FlightGlobals.ActiveVessel;
            if (wireVessel != vessel)
            {
                if (wireVessel != null) wireVessel.OnFlyByWire -= FlyByWire;
                wireVessel = vessel;
                if (wireVessel != null) wireVessel.OnFlyByWire += FlyByWire;
            }
            if (vessel == null) return;
            vesselName = vessel.vesselName;
            var engine = vessel.GetActiveParts().SelectMany(part => part.Modules.OfType<ModuleEngines>()).FirstOrDefault();
            if (engine == null) return;
            engineName = engine.name;

            finalThrust = engine.finalThrust;
            fuelFlowGui = engine.fuelFlowGui;
            status = engine.status;
            statusL2 = engine.statusL2;
            thrustPercentage = engine.thrustPercentage;

            currentThrottle = engine.currentThrottle;
            EngineIgnited = engine.EngineIgnited;
            maxThrust = engine.maxThrust;
            minThrust = engine.minThrust;
            requestedThrottle = engine.requestedThrottle;
            requestedThrust = engine.requestedThrust;
            useEngineResponseTime = engine.useEngineResponseTime;
            engineAccelerationSpeed = engine.engineAccelerationSpeed;
            engineDecelerationSpeed = engine.engineDecelerationSpeed;
            useVelocityCurve = engine.useVelocityCurve;

            com = vessel.findWorldCenterOfMass();
            up = (com - vessel.mainBody.position).normalized;
            east = vessel.mainBody.getRFrmVel(com).normalized;
            north = -Vector3.Cross(up, east);

            var headingDir = vessel.GetSrfVelocity();
            headingDir -= Vector3.Dot(headingDir, up) * up;
            if (headingDir.sqrMagnitude > 0.5f)
            {
                headingDir = headingDir.normalized;
                heading = Mathf.Acos(Vector3.Dot(north, headingDir)) * Mathf.Rad2Deg;
                if (Vector3.Dot(east, headingDir) < 0) heading = -heading;
            }

            var pitchDir = vessel.GetSrfVelocity();
            if (pitchDir.sqrMagnitude > 0.5f)
            {
                pitchDir = pitchDir.normalized;
                pitch = Mathf.Acos(Vector3.Dot(up, pitchDir)) * Mathf.Rad2Deg;
            }

            //if (useCamera)
            //{
            //    var q = vessel.VesselSAS.lockedHeading;
            //    var forward = q * Vector3.up;
            //    q = Quaternion.LookRotation(forward, up);
            //    vessel.VesselSAS.LockHeading(q);
            //}

            thrustMultiplier = thrustPercentage / 100f;
            thrustEfficiency = 1;
            if (useVelocityCurve) thrustEfficiency *= engine.velocityCurve.Evaluate((float)vessel.srf_velocity.magnitude);

            up = (vessel.findWorldCenterOfMass() - vessel.mainBody.position).normalized;

            thrustDirection = Vector3.zero;
            foreach (var thrust in engine.thrustTransforms) thrustDirection += thrust.forward;
            if (engine.thrustTransforms.Count > 0) thrustDirection = thrustDirection.normalized;
            thrustEfficiency *= Vector3.Dot(-thrustDirection, up);

            //if (desire)
            //{
            //    desireCrank = Mathf.Round((desiredThrottle * thrustPercentage / 100f - currentThrottle) * 10000f) / 10000f;
            //    if (desireCrank > 0) desireCrank /= engineAccelerationSpeed * fixedDeltaTime;
            //    else if (desireCrank < 0) desireCrank /= engineDecelerationSpeed * fixedDeltaTime;
            //    if (currentThrottle + desireCrank >= 1) desireCrank = 1;
            //    else if (currentThrottle + desireCrank <= 0) desireCrank = 0;
            //    else if (desireCrank > 0) desireCrank = currentThrottle + desireCrank * desireCrank;
            //    else if (desireCrank < 0) desireCrank = currentThrottle - desireCrank * desireCrank;
            //    else desireCrank = desiredThrottle;
            //    desireCrank = Mathf.Clamp01(desireCrank * 100f / thrustPercentage);
            //}

            var deadzone = 0.01f;
            var ascend = Mathf.Clamp01((Input.GetAxis("joy0.9") - deadzone) / (1.0f - deadzone));
            var descend = Mathf.Clamp01((Input.GetAxis("joy0.8") - deadzone) / (1.0f - deadzone));
            if (ascend > 0 || descend > 0 || mode == Mode.CONTROLLED)
            {
                mode = Mode.CONTROLLED;
                desiredVelocity = (ControlMap(ascend) - ControlMap(descend)) * 30f;
            }

//.........这里部分代码省略.........
开发者ID:uffefl,项目名称:JetEngineTesting,代码行数:101,代码来源:JetEngineTesting.cs

示例3: Waypoint

        public Waypoint(Vessel v)
        {
            longitude = v.longitude;
            latitude = v.latitude;
            altitude = v.altitude;

            velocity = v.GetSrfVelocity();
            orientation = v.rigidbody.rotation;

            recordTime = Planetarium.GetUniversalTime();
        }
开发者ID:GrJo,项目名称:KSPPersistentTrails,代码行数:11,代码来源:Track.cs


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