# UnityMathf中的数学运算

Mathf.Abs绝对值

Mathf.Acos反余弦

staticfunction Acos (f : float) : float

Mathf.Approximately近似

staticfunction Approximately (a : float, b: float) : bool

publicclass example : MonoBehaviour {

publicvoid Awake() {

if(Mathf.Approximately(1.0F, 10.0F / 10.0F))

print("same");

}

}

Mathf.Asin反正弦

staticfunction Asin (f : float) : float

Mathf.Atan2反正切

staticfunction Atan2 (y : float, x :float) : float

publicclass example : MonoBehaviour {

publicTransform target;

voidUpdate() {

Vector3relative =transform.InverseTransformPoint(target.position);

transform.Rotate(0,angle, 0);

}

}

Mathf.Atan反正切

staticfunction Atan (f : float) :float

Mathf.CeilToInt最小整数

staticfunction CeilToInt (f : float) : int

Mathf.Ceil上限值

staticfunction Ceil (f : float) : float

Mathf.Clamp01限制0~1

staticfunction Clamp01 (value : float) :float

Mathf.Clamp限制

staticfunction Clamp (value : float, min :float, max : float) : float

staticfunction Clamp (value : int, min :int, max : int) : int

Mathf.ClosestPowerOfTwo最近的二次方

staticfunction ClosestPowerOfTwo (value :int) : int

Mathf.Cos余弦

staticfunction Cos (f : float) : float

Mathf.DeltaAngle增量角

staticfunction DeltaAngle (current :float, target : float) : float

//Prints 90

Debug.Log(Mathf.DeltaAngle(1080,90));

Mathf.Epsilon小正数

staticvar Epsilon : float

-    anyValue + Epsilon = anyValue

-    anyValue - Epsilon = anyValue

-    0 + Epsilon = Epsilon

-    0 - Epsilon = -Epsilon

publicclass example : MonoBehaviour {

boolisEqual(float a, float b) {

if(a >= b -Mathf.Epsilon && a <= b + Mathf.Epsilon)

returntrue;

else

returnfalse;

}

}

Mathf.Exp指数

staticfunction Exp (power : float) : float

Mathf.FloorToInt最大整数

staticfunction FloorToInt (f : float) :int

Mathf.Floor下限值

staticfunction Floor (f : float) : float

Mathf.Infinity正无穷

staticvar Infinity : float

Mathf.InverseLerp反插值

//现在参数是3/5

floatparameter =Mathf.InverseLerp(walkSpeed, runSpeed, speed);

Mathf.IsPowerOfTwo是否2的幂

staticfunction IsPowerOfTwo (value : int): bool

//prints false

Debug.Log(Mathf.IsPowerOfTwo(7));

//prints true

Debug.Log(Mathf.IsPowerOfTwo(32));

Mathf.LerpAngle插值角度

staticfunction LerpAngle (a : float, b :float, t : float) : float

a和b是代表度数。

publicclass example : MonoBehaviour {

publicfloat minAngle = 0.0F;

publicfloat maxAngle = 90.0F;

voidUpdate() {

floatangle =Mathf.LerpAngle(minAngle, maxAngle, Time.time);

transform.eulerAngles=new Vector3(0, angle, 0);

}

}

Mathf.Lerp插值

staticfunction Lerp (from : float, to :float, t : float) : float

Mathf.Log10基数10的对数

staticfunction Log10 (f : float) : float

Mathf.Log对数

staticfunction Log (f : float, p : float): float

//logarithm of 6 in base 2

//以2为底6的对数

//prints 2.584963

print(Mathf.Log(6,2));

Mathf.Max最大值

staticfunction Max (a : float, b : float): float

staticfunction Max (params values :float[]) : float

Mathf.Min最小值

staticfunction Min (a : float, b : float): float

staticfunction Min (params values :float[]) : float

Mathf.MoveTowardsAngle移动角

staticfunction MoveTowardsAngle (current :float, target : float, maxDelta : float) :float

Mathf.MoveTowards移向

staticfunction MoveTowards (current :float, target : float, maxDelta : float) : float

Mathf.NegativeInfinity负无穷

staticvar NegativeInfinity : float

Mathf.NextPowerOfTwo下个2的幂

Mathf.PingPong乒乓

staticfunction PingPong (t : float, length: float) : float

0到length之间往返。t值永远不会大于length的值，也永远不会小于0。

Thereturned value will move back and forthbetween 0 and length.

Mathf.PI圆周率

staticvar PI : float

PI（读pai）的值，也就是圆周率（π）的值3.14159265358979323846...（只读）

Mathf.Pow次方

staticfunction Pow (f : float, p : float): float

Mathf.Repeat重复

staticfunction Repeat (t : float, length :float) : float

publicclass example : MonoBehaviour {

voidUpdate() {

transform.position= newVector3(Mathf.Repeat(Time.time, 3), transform.position.y,transform.position.z);

}

}

Mathf.RoundToInt四舍五入到整数

staticfunction RoundToInt (f : float) :int

Mathf.Round四舍五入

staticfunction Round (f : float) : float

Mathf.Sign符号

staticfunction Sign (f : float) : float

Mathf.Sin正弦

staticfunction Sin (f : float) : float

Mathf.SmoothDampAngle平滑阻尼角度

staticfunction SmoothDampAngle (current :float, target : float, ref currentVelocity :float, smoothTime : float,maxSpeed : float = Mathf.Infinity, deltaTime : float= Time.deltaTime) : float

current

target

currentVelocity

smoothTime

thetarget faster.

maxSpeed

deltaTime

//一个简单的平滑跟随摄像机

//跟随目标的朝向

publicclass example : MonoBehaviour {

publicTransform target;

publicfloat smooth = 0.3F;

publicfloat distance = 5.0F;

privatefloat yVelocity = 0.0F;

voidUpdate() {

//从目前的y角度变换到目标y角度

floatyAngle = Mathf.SmoothDampAngle(transform.eulerAngles.y,target.eulerAngles.y,ref yVelocity, smooth);

//target的位置

Vector3position =target.position;

//然后，新角度之后的距离偏移

position+=Quaternion.Euler(0, yAngle, 0) * new Vector3(0, 0, -distance);

//应用位置

transform.position=position;

//看向目标

transform.LookAt(target);

}

}

Mathf.SmoothDamp平滑阻尼

staticfunction SmoothDamp (current :float, target : float, ref currentVelocity :float, smoothTime : float,maxSpeed : float = Mathf.Infinity, deltaTime : float= Time.deltaTime) : float

current

target

currentVelocity

smoothTime

maxSpeed

deltaTime

publicclass example : MonoBehaviour {

publicTransform target;

publicfloat smoothTime = 0.3F;

privatefloat yVelocity = 0.0F;

voidUpdate() {

floatnewPosition =Mathf.SmoothDamp(transform.position.y, target.position.y, refyVelocity,smoothTime);

transform.position= newVector3(transform.position.x, newPosition, transform.position.z);

}

}

Mathf.SmoothStep平滑插值

staticfunction SmoothStep (from : float,to : float, t : float) : float

publicclass example : MonoBehaviour {

publicfloat minimum = 10.0F;

publicfloat maximum = 20.0F;

voidUpdate() {

transform.position= newVector3(Mathf.SmoothStep(minimum, maximum, Time.time), 0, 0);

}

}

Mathf.Sqrt平方根

staticfunction Sqrt (f : float) : float

Mathf.Tan正切

staticfunction Tan (f : float) : float

• 本文已收录于以下专栏：

## python中数学运算

python中数学运算 Python 提供的基本数据类型 int、float 可以做整数和浮点的四则运算以及乘方等运算。 但是，四则运算不局限于int和float，还可以是有理数、矩阵等。...
• GoodLuckAC
• 2016年11月11日 16:48
• 1123

## 【C++】数学运算

C++ 数学运算 在 C++ 中，除了可以创建各种函数，还包含了各种有用的函数供您使用。这些函数写在标准 C 和 C++ 库中，叫做内置函数。您可以在程序中引用这些函数。 C++ 内置了丰...
• Grevi
• 2017年02月02日 15:24
• 375

## Matlab常用数学函数和数学运算符

Matlab的内部常数  eps   浮点相对精度  pi  圆周率  exp  自然对数的底数e  i 或j  虚数单位  ...
• cc198877
• 2012年10月24日 11:16
• 1774

## 浅谈java中的数学运算

• u011277123
• 2016年10月27日 18:22
• 1016

## shell脚本中的数学运算

shell中的赋值和操作默认都是字符串处理，在此记下shell中进行数学运算的几个特殊方法，以后用到的时候可以来看，呵呵 1、错误方法举例 a) var=1+1 echo \$va...
• sunlei1980
• 2015年06月24日 15:48
• 948

## linux shell 脚本【2】 ---- 数学运算

• liu_zhen_wei
• 2013年12月25日 15:31
• 1601

## java/android 中的数学计算

A:你可在android开发中操作过数学计算？比如：a * b / c + (d + e)^n + √f B:简单，Math类就可以搞定 A:那等式呢？比如x + 8 - a= 0 B:变换一...
• chinajpr
• 2017年01月13日 11:24
• 462

## Linux中的数学运算

Linux中的数学运算方式只要以下几种方式： 1）expr 表达式 具体语法为： expr 1 + 5 这种方式要求比较严格，空格必须有，且在脚本中容易出问题，比如在脚本中乘号可能被识别为通...
• YW_Vine
• 2018年01月12日 22:11
• 7

## shell中的数学运算

http://craftor.org/?p=690
• zhaowei3828
• 2014年02月12日 11:58
• 341

## SELECT语句中的数学问题

6.2SELECT语句中的数学问题 6.2.1 SQL Server中的变量 Transact-SQL语言中有两种形式的变量，一种是用户自己定义的局部变量，另外一种是系统提供的全局变量。 1. ...
• zhubo22
• 2012年10月07日 12:00
• 1857

举报原因： 您举报文章：UnityMathf中的数学运算 色情 政治 抄袭 广告 招聘 骂人 其他 (最多只允许输入30个字)