Version: 2022.3
public void AddTorque (Vector3 torque, ForceMode mode= ForceMode.Force);

参数

torque 扭矩矢量(世界坐标)。
mode The type of torque to apply.

描述

向刚体添加扭矩。

力只能应用于处于活动状态的刚体。如果 GameObject 处于非活动状态,则 AddTorque 没有效果。

The effects of the torques applied with this function are accumulated at the time of the call. The physics system applies the effects during the next simulation run (either after FixedUpdate, or when the script explicitly calls the Physics.Simulate method). Because this function has different modes, the physics system only accumulates the resulting angular velocity change, not the passed torque values. Assuming deltaTime (DT) is equal to the simulation step length (Time.fixedDeltaTime), and mass is equal to the mass of the Rigidbody the torque is being applied to, here is how the angular velocity change is calculated for all the modes: ForceMode.Force: Interprets the input as torque (measured in Newton-metres), and changes the angular velocity by the value of torque * DT / mass. The effect depends on the simulation step length and the mass of the body. ForceMode.Acceleration: Interprets the parameter as angular acceleration (measured in degrees per second squared), and changes the angular velocity by the value of torque * DT. The effect depends on the simulation step length but does not depend on the mass of the body. ForceMode.Impulse: Interprets the parameter as an angular momentum (measured in kilogram-meters-squared per second), and changes the angular velocity by the value of torque / mass. The effect depends on the mass of the body but doesn't depend on the simulation step length. ForceMode.VelocityChange: Interprets the parameter as a direct angular velocity change (measured in degrees per second), and changes the angular velocity by the value of torque. The effect doesn't depend on the mass of the body and the simulation step length. 默认将唤醒刚体。如果扭矩大小为零,则不会唤醒刚体。

另请参阅:AddRelativeTorqueAddForce

// Rotate an object around its Y (upward) axis in response to
// left/right controls.
using UnityEngine;
using System.Collections;

public class ExampleClass : MonoBehaviour { public float torque; public Rigidbody rb;

void Start() { rb = GetComponent<Rigidbody>(); }

void FixedUpdate() { float turn = Input.GetAxis("Horizontal"); rb.AddTorque(transform.up * torque * turn); } }

public void AddTorque (float x, float y, float z, ForceMode mode= ForceMode.Force);

参数

x 沿世界 X 轴的扭矩大小。
y 沿世界 Y 轴的扭矩大小。
z 沿世界 Z 轴的扭矩大小。
mode The type of torque to apply.

描述

向刚体添加扭矩。

力只能应用于处于活动状态的刚体。如果 GameObject 处于非活动状态,则 AddTorque 没有效果。

默认将唤醒刚体。如果扭矩大小为零,则不会唤醒刚体。

Copyright © 2023 Unity Technologies
优美缔软件(上海)有限公司 版权所有
"Unity"、Unity 徽标及其他 Unity 商标是 Unity Technologies 或其附属机构在美国及其他地区的商标或注册商标。其他名称或品牌是其各自所有者的商标。
公安部备案号:
31010902002961