當前位置: 首頁>>代碼示例>>C#>>正文


C# Quaternion.ToAngleAxis方法代碼示例

本文整理匯總了C#中UnityEngine.Quaternion.ToAngleAxis方法的典型用法代碼示例。如果您正苦於以下問題:C# Quaternion.ToAngleAxis方法的具體用法?C# Quaternion.ToAngleAxis怎麽用?C# Quaternion.ToAngleAxis使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在UnityEngine.Quaternion的用法示例。


在下文中一共展示了Quaternion.ToAngleAxis方法的13個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的C#代碼示例。

示例1: SetRotation

 public void SetRotation(Quaternion rotation)
 {
     Vector3 axis;
     float angle;
     rotation.ToAngleAxis(out angle, out axis);
     EffekseerSystem.Plugin.EffekseerSetRotation(handle, axis.x, axis.y, axis.z, angle * Mathf.Deg2Rad);
 }
開發者ID:saihe,項目名稱:Effekseer,代碼行數:7,代碼來源:EffekseerSystem.cs

示例2: ToString

        /// <summary>
        /// Converts the data to a string value
        /// </summary>
        /// <returns>The string.</returns>
        /// <param name="rInput">Value to convert</param>
        public static string ToString(Quaternion rInput)
        {
            Vector3 lEuler = rInput.eulerAngles;

            float lAngle = 0f;
            Vector3 lAxis = Vector3.zero;
            rInput.ToAngleAxis(out lAngle, out lAxis);

            return String.Format("[p:{0:f4} y:{1:f4} r:{2:f4} x:{3:f7} y:{4:f7} z:{5:f7} w:{6:f7} angle:{7:f7} axis:{8}]", lEuler.x, lEuler.y, lEuler.z, rInput.x, rInput.y, rInput.z, rInput.w, lAngle, ToString(lAxis));
        }
開發者ID:bmjoy,項目名稱:Immortal,代碼行數:15,代碼來源:StringHelper.cs

示例3: ToAngularVelocity

    public static Vector3 ToAngularVelocity(Quaternion deltaRotation, float deltaTime) {
      Vector3 deltaAxis;
      float deltaAngle;
      deltaRotation.ToAngleAxis(out deltaAngle, out deltaAxis);

      if (float.IsInfinity(deltaAxis.x)) {
        deltaAxis = Vector3.zero;
        deltaAngle = 0;
      }

      if (deltaAngle > 180) {
        deltaAngle -= 360.0f;
      }

      return deltaAxis * deltaAngle * Mathf.Deg2Rad / deltaTime;
    }
開發者ID:WilliamRADFunk,項目名稱:vedic,代碼行數:16,代碼來源:PhysicsUtility.cs

示例4: Update

    // Update is called once per frame
    // TODO: use fixedupdate for rigidbody manip
    void Update()
    {
        //people recommend doing rigidbody stuff with fixedupdate?
        if(attachedWand && currentlyInteracting)
        {
            posDelta = attachedWand.transform.position - interactionPoint.position;
            this.rigidbody.velocity = posDelta * velocityFactor * Time.fixedDeltaTime;

            rotationDelta = attachedWand.transform.rotation * Quaternion.Inverse(interactionPoint.rotation);
            rotationDelta.ToAngleAxis(out angle, out axis);

            if(angle > 180) // if you rotate your hand quickly enough, there are two ways to rotate towards
            {
                angle -= 360;
            }

            this.rigidbody.angularVelocity = (Time.fixedDeltaTime * angle * axis) * rotationFactor;

        }
    }
開發者ID:Rosstin,項目名稱:BreakupSimulator201606,代碼行數:22,代碼來源:InteractableItem.cs

示例5: UpdateRotation

        public void UpdateRotation(Vector3 startPos, Quaternion referenceTransform, Quaternion inputQuat)
        {
            Vector3 vec3 = new Vector3(3f, 3f, 3f);
            Vector3 vec15 = new Vector3(1.5f, 1.5f, 1.5f);
            Vector3 vec05 = new Vector3(0.5f, 0.5f, 0.5f);
            Vector3 vec025 = new Vector3(0.25f, 0.25f, 0.25f);
            float inputTheta;
            Vector3 inputAxis;
            inputQuat.ToAngleAxis(out inputTheta, out inputAxis);
            //Rotate so unrotated is up.
            Vector3 upVector = FlightGlobals.upAxis;
            //Theta stuff
            Vector3 thetaStart = startPos + (Vector3.Scale(referenceTransform * inputAxis, vec15));
            Vector3 refDirection = Vector3.up;
            float thetaX = Mathf.Sin(inputTheta * Mathf.Deg2Rad);
            float thetaY = Mathf.Cos(inputTheta * Mathf.Deg2Rad);
            Vector3 thetaDirection = new Vector3(thetaX, thetaY, 0f);


            axis.UpdatePosition(startPos, startPos + Vector3.Scale(referenceTransform * inputAxis, vec3));
            reference0.UpdatePosition(thetaStart, thetaStart + Vector3.Scale(referenceTransform * refDirection, vec025));
            theta.UpdatePosition(thetaStart, thetaStart + Vector3.Scale(referenceTransform * thetaDirection, vec05));
        }
開發者ID:Opice,項目名稱:DarkMultiPlayer,代碼行數:23,代碼來源:3DDebug.cs

示例6: Rotate

 void Rotate(Quaternion q)
 {
     Vector3 r = new Vector3();
     float a=0;
     q.ToAngleAxis(out a,out r);
     transform.Rotate(r, a);
 }
開發者ID:cWalters2,項目名稱:ShSoul,代碼行數:7,代碼來源:plSerenSword.cs

示例7: UpdateAnimation

    // fonction de mise à jour des données d'animation
    void UpdateAnimation()
    {
        // mise à jour de la tête de lecture de l'animation
        playhead = ((Time.time - start) * speed) / duration;

        // borner la position de la tête de lecture dans l'intervalle [0,1]
        playhead = playhead > 1.0f ? 1.0f : playhead < 0.0f ? 0.0f : playhead;

        // mise à jour des quaternions d'orientation par interpolation sphérique linéaire (slerp)
        yQuaternionCurrent = Quaternion.Slerp(yQuaternionFrom, yQuaternionTo, playhead);
        xQuaternionCurrent = Quaternion.Slerp(xQuaternionFrom, xQuaternionTo, playhead);

        // extraction de l'orientation du quaternion sous forme d'un axe de rotation et d'un angle
        yQuaternionCurrent.ToAngleAxis(out angle, out axis);

        // orienter le point de pivot en Y de l'oiseau
        pivotY.transform.Rotate(axis, angle, Space.Self);

        // réinitialiser l'orientation du point de pivot en X, pour le ramener à l'orientation du parent hiérarchique (point de pivot en Y)
        pivotX.transform.rotation = Quaternion.identity;

        // extraction de l'orientation du quaternion sous forme d'un axe de rotation et d'un angle
        yQuaternionCurrent.ToAngleAxis(out angle, out axis);

        // orienter le point de pivot en X de l'oiseau
        pivotX.transform.Rotate(axis, angle, Space.Self);

        // extraction de l'orientation du quaternion sous forme d'un axe de rotation et d'un angle
        xQuaternionCurrent.ToAngleAxis(out angle,out axis);

        // orienter le point de pivot en X de l'oiseau
        pivotX.transform.Rotate(axis, angle, Space.Self);

        // valider si l'animaton est complétée
        if(playhead >= 1.0f)
        {
            // valider la direction de l'animation
            if(reverse)
            {
                reverse = false;
                animate = false;

                xQuaternionFrom = xQuaternionTo;
                yQuaternionFrom = yQuaternionTo;
            }
            else
            {
                // inverser l'animation
                reverse = true;

                xQuaternionFrom = xQuaternionTo;
                yQuaternionFrom = yQuaternionTo;

                xQuaternionTo = Quaternion.identity;
                yQuaternionTo = yQuaternionFrom;

                // réinitialiser les données d'animation
                Setup();
            }
        }
    }
開發者ID:philvoyer,項目名稱:ANI2012A15,代碼行數:62,代碼來源:Engine.cs

示例8: rtuRotation

 static Quaternion rtuRotation(Quaternion q)
 {
     Vector3 v;
     float a;
     q.ToAngleAxis(out a, out v);
     return Quaternion.AngleAxis(-a, new Vector3(v.x, v.z, v.y));
 }
開發者ID:brett19,項目名稱:RoseTwoPointOh,代碼行數:7,代碼來源:Main.cs

示例9: r2uRotation

 public static Quaternion r2uRotation(Quaternion q)
 {
     Vector3 axis;
     float angle;
     q.ToAngleAxis(out angle, out axis);
     return Quaternion.AngleAxis(angle, new Vector3(axis.x, axis.z, -axis.y));
 }
開發者ID:osROSE,項目名稱:UnityRose,代碼行數:7,代碼來源:Utils.cs

示例10: Drag

 public void Drag(Vector3 position, Vector3 move, Quaternion rotate)
 {
     transform.Translate(move, Space.World);
     Vector3 axis;
     float angle;
     rotate.ToAngleAxis(out angle, out axis);
     transform.RotateAround(position, axis, angle);
 }
開發者ID:vildninja,項目名稱:voxel,代碼行數:8,代碼來源:ChunkManager.cs

示例11: OrientationFromAngle

 //! Get orientation from old orientation and angle.
 private ja2.LookDirection OrientationFromAngle(Quaternion Orientation)
 {
     Vector3 vec;
     float angle;
     Orientation.ToAngleAxis(out angle, out vec);
     // Get number of 45 rotations
     float angle_count = (vec.y > 0 ? angle : 360 - angle) / 45;
     // Lower bound
     byte lower_bound = (byte)Mathf.FloorToInt(angle_count);
     // Compute new rotation look
     return (ja2.LookDirection)(((angle_count - lower_bound >= 0.5f ? lower_bound + 1 : lower_bound) % 8));
 }
開發者ID:Trigve,項目名稱:ja2_unity,代碼行數:13,代碼來源:SoldierController.cs

示例12: ConvertRotation

        public static rotate ConvertRotation(Quaternion input)
        {
            rotate output = new rotate();

            Vector3 axis;
            float angle;
            input.ToAngleAxis(out angle, out axis);

            output.Values = new double[] { axis.x, axis.y, axis.z, angle };
            output.sid = "rotate";
            return output;
        }
開發者ID:JapaMala,項目名稱:armok-vision,代碼行數:12,代碼來源:MeshToCollada.cs

示例13: getHandEyeCalibration

        /**
         * Get hand-eye calibration in Unity coordinate system (left-handed)
         */
        public static void getHandEyeCalibration(out Vector3 translation, out Quaternion rotation, CameraType cameraType)
        {
            float[] res = new float[7];
            GCHandle arrayHandle = GCHandle.Alloc(res, GCHandleType.Pinned);
            IntPtr ptr = arrayHandle.AddrOfPinnedObject();
            getHandEyeCalibrationInternal(ptr, (int)cameraType);
            arrayHandle.Free();

            // To Unity coordinates
            translation = new Vector3(res[0], res[1], -res[2]);
            rotation = new Quaternion(res[3], res[4], res[5], res[6]);

            float angle;
            Vector3 axis;
            rotation.ToAngleAxis(out angle, out axis);
            axis.x *= -1;
            axis.y *= -1;
            rotation = Quaternion.AngleAxis(angle, axis);
        }
開發者ID:hqt08,項目名稱:ARGame,代碼行數:22,代碼來源:MetaioSDKUnity.cs


注:本文中的UnityEngine.Quaternion.ToAngleAxis方法示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。