向量运算(lua,三维) 点乘、叉乘、模、夹角

向量运算在游戏制作中经常用到,稍微总结一下。

一、点乘

 

 

 如图,假设  

 

 

向量a与b的点乘表示a在b上的投影与b的模的乘积

公式:

 

 

 

 

 

 代码:

function MathHelper.GetVector3Dot(v1, v2)
    return v1.x * v2.x + v1.y * v2.y + v1.z * v2.z
end

 

二、叉乘

向量的叉乘,即求同时垂直两个向量的向量

公式:

 

 

代码:

-- 向量叉乘
function MathHelper.GetVector3Cross(v1, v2)
    local v3 ={x = v1.y*v2.z - v2.y*v1.z , y = v2.x*v1.z-v1.x*v2.z , z = v1.x*v2.y-v2.x*v1.y}
    return v3
end

 

三、模

 向量的长度

公式:

 

 

 代码:

-- 向量的模
function MathHelper.GetVector3Module(v)
    return math.sqrt(v.x * v.x + v.y * v.y + v.z * v.z)
end

 

四、夹角

公式:

 

 

 代码:

-- 求两向量间夹角
function MathHelper.GetVector3Angle(v1, v2)
    local cos = MathHelper.GetVector3Dot(v1, v2)/ (MathHelper.GetVector3Module(v1)*MathHelper.GetVector3Module(v2))
    return math.acos(cos) * 180 / math.pi
end

 

完整代码:

 1 MathHelper = {}
 2 -- 向量点乘
 3 function MathHelper.GetVector3Dot(v1, v2)
 4     return v1.x * v2.x + v1.y * v2.y + v1.z * v2.z
 5 end
 6 
 7 -- 向量叉乘
 8 function MathHelper.GetVector3Cross(v1, v2)
 9     local v3 ={x = v1.y*v2.z - v2.y*v1.z , y = v2.x*v1.z-v1.x*v2.z , z = v1.x*v2.y-v2.x*v1.y}
10     return v3
11 end
12 
13 -- 向量的模
14 function MathHelper.GetVector3Module(v)
15     return math.sqrt(v.x * v.x + v.y * v.y + v.z * v.z)
16 end
17 
18 -- 求两向量间夹角
19 function MathHelper.GetVector3Angle(v1, v2)
20     local cos = MathHelper.GetVector3Dot(v1, v2)/ (MathHelper.GetVector3Module(v1)*MathHelper.GetVector3Module(v2))
21     return math.acos(cos) * 180 / math.pi
22 end
View Code

 

posted @ 2019-11-24 17:33  吃斤欢乐豆  阅读(3520)  评论(0编辑  收藏  举报