溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

Unity3D如何實現(xiàn)攻擊范圍檢測

發(fā)布時間:2020-07-29 14:06:27 來源:億速云 閱讀:542 作者:小豬 欄目:編程語言

小編這次要給大家分享的是Unity3D如何實現(xiàn)攻擊范圍檢測,文章內容豐富,感興趣的小伙伴可以來了解一下,希望大家閱讀完這篇文章之后能夠有所收獲。

一、扇形攻擊范圍檢測

using UnityEngine;
using System.Collections;


public class AttackCHeck : MonoBehaviour
{
 //要攻擊的目標
 public Transform Target;
 //扇形距離 攻擊距離 扇形的半徑 
 private float SkillDistance = 5;
 //扇形的角度 也就是攻擊的角度
 private float SkillJiaodu = 60;

 private void Update()
 {
  //與敵人的距離
  float distance = Vector3.Distance(transform.position, Target.position);
  //玩家正前方的向量
  Vector3 norVec = transform.rotation * Vector3.forward;
  //玩家與敵人的方向向量
  Vector3 temVec = Target.position - transform.position;
  //求兩個向量的夾角
  float jiajiao = Mathf.Acos(Vector3.Dot(norVec.normalized, temVec.normalized)) * Mathf.Rad2Deg;
  if (distance < SkillDistance)
  {
   if (jiajiao <= SkillJiaodu * 0.5f)
   {
    Debug.Log("在扇形范圍內");
   }
  }
 }
}

二、長方形范圍攻擊檢測

using UnityEngine;
using System.Collections;


public class AttackCHeck : MonoBehaviour
{
 //要攻擊的目標
 public Transform Target;

 private void Update()
 {
  //計算玩家與敵人的距離
  float distance = Vector3.Distance(transform.position, Target.position);
  //玩家與敵人的方向向量
  Vector3 temVec = Target.position - transform.position;
  //與玩家正前方做點積
  float forwardDistance = Vector3.Dot(temVec, transform.forward.normalized);
  if (forwardDistance > 0 && forwardDistance <= 10)
  {
   float rightDistance = Vector3.Dot(temVec, transform.right.normalized);

   if (Mathf.Abs(rightDistance) <= 3)
   {
    Debug.Log("進入攻擊范圍");
   }
  }

 }
}

三、半圓形攻擊范圍檢測

using UnityEngine;
using System.Collections;


public class AttackCHeck : MonoBehaviour
{
 //要攻擊的目標
 public Transform Target;
 private void Update()
 {
  //計算玩家與敵人的距離
  float distance = Vector3.Distance(transform.position, Target.position);
  //玩家與敵人的方向向量
  Vector3 temVec = Target.position - transform.position;
  //與玩家正前方做點積
  float forwardDistance = Vector3.Dot(temVec, transform.forward.normalized);
  if (forwardDistance > 0 && forwardDistance <= 10)
  {
   if (distance <= 5)
   {
    Debug.Log("進入攻擊范圍");
   }
  }
 }
}

暫時就寫三種吧!目前就遇到三種,以后遇到再更新.接下來介紹一下算法的核心知識點吧

其實這些小算法基本上用的全是向量的計算,向量的計算有兩種

1.向量的點乘

–>A . B = |A| * |B| * cos θ
–>點乘應用

1).如果 讓 A 等于單位向量 |A| ==1 c點積 等于 B 在 A 上的投影
2).如果 讓 A B等于單位向量 arccos(a.b) == 夾角

2.向量的叉乘

–>A* B = C C就是A和B的法向量
–>叉乘應用

1).c 是有方向 。 通過 左手 定則 可以知道 C 的方向
2).所以叉乘一般是用來計算方向的
3).A 和 B 都是單位向量 arcsin(|A*B|) 等于 夾角

看完這篇關于Unity3D如何實現(xiàn)攻擊范圍檢測的文章,如果覺得文章內容寫得不錯的話,可以把它分享出去給更多人看到。

向AI問一下細節(jié)

免責聲明:本站發(fā)布的內容(圖片、視頻和文字)以原創(chuàng)、轉載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權請聯(lián)系站長郵箱:is@yisu.com進行舉報,并提供相關證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權內容。

AI