常用数学公式

using UnityEngine;

using System.Collections;

using System;

public class MathUtilLite

{

#region常量

public static Vector3 AxisX = new Vector3(1, 0, 0);

public static Vector3 AxisY = new Vector3(0, 1, 0);

public static Vector3 AxisZ = new Vector3(0, 0, 1);

public static Vector3 XYZ1 = Vector3.one;

public static float ONE_DIV_PI = 1.0f / Mathf.PI;

public static float COS_15 = Mathf.Cos(Mathf.Deg2Rad * 15.0f);

public static float COS_35 = Mathf.Cos(Mathf.Deg2Rad * 35.0f);

public static float COS_45 = Mathf.Cos(Mathf.Deg2Rad * 45.0f);

public static float COS_75 = Mathf.Cos(Mathf.Deg2Rad * 75.0f);

public static float COS_60 = Mathf.Cos(Mathf.Deg2Rad * 60.0f);

public static float COS_30 = Mathf.Cos(Mathf.Deg2Rad * 30.0f);

public static float COS_20 = Mathf.Cos(Mathf.Deg2Rad * 20.0f);

public static Vector2 AxisX2D = new Vector2(1, 0);

public static Vector2 AxisY2D = new Vector2(0, 1);

public static float EPSILON = 0.001f;

#endregion

///

///时间戳转换成时间

///

/// 时间戳

///

public static System.DateTime TransToDateTime(uint t)

{

System.DateTime dt = System.TimeZone.CurrentTimeZone.ToLocalTime(newSystem.DateTime(1970, 1, 1));

long lTime = long.Parse(t.ToString() + "0000000");

System.TimeSpan toNow = new System.TimeSpan(lTime);

return dt.Add(toNow);

}

///

///计算两个三维坐标相差的距离

///

///

///

/// 距离

public static float DistancePow(Vector3 a, Vector3 b)

{

return (a.x - b.x) * (a.x - b.x) + (a.y - b.y) * (a.y - b.y) + (a.z -b.z) * (a.z - b.z);

}

///

///计算两个二维坐标相差的距离

///

///

///

/// 长度

public static float DistancePow(Vector2 a, Vector2 b)

{

return (a.x - b.x) * (a.x - b.x) + (a.y - b.y) * (a.y - b.y);

}

//andeeee from the Unity forum's steller Catmull-Rom class (http://forum.unity3d.com/viewtopic.php?p=218400#218400 ):

public static Vector3 Interp(Vector3[] pts, float t)

{

t = Mathf.Clamp(t, 0.0f, 2.0f);

int numSections = pts.Length - 3;

int currPt = Mathf.Min(Mathf.FloorToInt(t * numSections), numSections -1);

float u = t * numSections - currPt;

Vector3 a = pts[currPt];

Vector3 b = pts[currPt + 1];

Vector3 c = pts[currPt + 2];

Vector3 d = pts[currPt + 3];

return .5f * (

(-a + 3f * b - 3f * c + d) * (u * u * u)

+ (2f * a - 5f * b + 4f * c - d) * (u * u)

+ (-a + c) * u

+ 2f * b

);

}

///

///获取两个点间的夹角

///

///

///

///

public static float GetAngle(Vector3 form, Vector3 to)

{

Vector3 nVector = Vector3.zero;

nVector.x = to.x;

nVector.y = form.y;

float a = to.y - nVector.y;

float b = nVector.x - form.x;

float tan = a / b;

return Mathf.Atan(tan) * 180.0f * ONE_DIV_PI;

}

public static Vector3 ApproximateDir(Vector3 dir)

{

float dotX = Vector3.Dot(dir, AxisX);

float dotZ = Vector3.Dot(dir, AxisZ);

if (Mathf.Abs(dotX) > Mathf.Abs(dotZ))

{

return dotX > 0 ? AxisX : -AxisX;

}

else

{

return dotZ > 0 ? AxisZ : -AxisZ;

}

}

///

/// normalize并且返回长度

///

///

///

public static float Normalize(ref Vector3 vec)

{

float length = Mathf.Sqrt((vec.x * vec.x) + (vec.y * vec.y) + (vec.z *vec.z));

if (length > 0)

{

float oneDivLength = 1.0f / length;

vec.x = vec.x * oneDivLength;

vec.y = vec.y * oneDivLength;

vec.z = vec.z * oneDivLength;

}

return length;

}

///

///尝试到达那个点

///

///

///

///

///

///

public static Vector3 TryToMoveToPosWithSpeed(Vector3 dest, Vector3 cur,float speed, float time)

{

Vector3 dir = dest - cur;

float dis = Normalize(ref dir);

if (speed * time < dis)

{

return cur + dir * speed * time;

}

else

{

return dest;

}

}

///

///移动人物制定距离相差多少的值

///

/// 目标点

/// 当前坐标

///

/// 速度

///

public static Vector3 OffsetToMoveToPosWithSpeed(Vector3 dest, Vector3cur, float speed, float time)

{

Vector3 dir = dest - cur;

Vector3 maxOffset = dir;

float dis = Normalize(ref dir);

if (speed * time < dis)

{

return dir * speed * time;

}

else

{

return maxOffset;

}

}

///

/// float近似相等

///

///

///

///

public static bool IsEqualFloat(float a, float b)

{

return (Math.Abs(a - b) < 0.001f);

}

public static bool IsEqualFloatRaw(float a, float b)

{

return (Math.Abs(a - b) < 0.05f);

}

#region 3D空间投影到屏幕坐标

public static Vector2 ProjectToScreen(Camera cam, Vector3 point)

{

Vector3 screenPoint = cam.WorldToScreenPoint(point);

return new Vector2(screenPoint.x, screenPoint.y);

}

#endregion

}}

ns":["œ�C��

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 214,377评论 6 496
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,390评论 3 389
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 159,967评论 0 349
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,344评论 1 288
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,441评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,492评论 1 292
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,497评论 3 412
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,274评论 0 269
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,732评论 1 307
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,008评论 2 328
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,184评论 1 342
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,837评论 4 337
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,520评论 3 322
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,156评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,407评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,056评论 2 365
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,074评论 2 352

推荐阅读更多精彩内容