Unity人工智能学习—确定性AI算法之追踪算法一

版权声明:本文为博主原创文章,转载请注明出处。 https://blog.csdn.net/zhangxiao13627093203/article/details/47451063

尽管随机运动可能完全不可预知,它还是相当无趣的,因为它完全是以相同的方式工作——完全随机。下面要学习到的算法是根据具体环境作出不同响应的处理。作为例子,这里选择了追踪算法。追踪AI考虑到跟踪目标的位置,然后改变AI对象的轨道好让它移向被追踪的对象。

追踪可以是将方向矢量直接指向目标,或者采用跟真实的模型,使得物体像导弹那样行动。

本文将的就是第一种,直接矢量追踪,效果如下图所示:

通过键盘方向键控制幽灵,然后蚊子会追踪幽灵,在这里我做了一些界面处理,当蚊子或者幽灵运动超过了屏幕范围的时候让它们出现在屏幕的另一边而不是消失在屏幕上

代码如下:

using UnityEngine;
using System.Collections;
using UnityEngine.UI;

public class AITrack : MonoBehaviour {
    public Image target;
    public float moveSpeed;//追踪目标移动速度
    public float targetSpeed;//追踪速度
    public float target_x;//追踪移动的单位量
    public float target_y;
	// Use this for initialization
	void Start () {
	    
	}
	// Update is called once per frame
	void Update () {
        MoveTarget();
        Track_AI();
	}
    void Track_AI()
    {
        //x方向的追踪
        if(target.transform.position.x>this.transform.position.x)
        {
            this.transform.position += new Vector3(target_x, 0, 0)*targetSpeed;
        }
        else if(target.transform.position.x<this.transform.position.x)
        {
            this.transform.position -= new Vector3(target_x, 0, 0)*targetSpeed;
        }
        //y方向的追踪
        if(target.transform.position.y>this.transform.position.y)
        {
            this.transform.position += new Vector3(0, target_y, 0)*targetSpeed;
        }
        else if(target.transform.position.y<this.transform.position.y)
        {
            this.transform.position -= new Vector3(0, target_y, 0)*targetSpeed;
        }
        //检测是否超出了边界
        if(this.transform.position.x>=Screen.width)
        {
            this.transform.position = new Vector3(-this.GetComponent<Image>().rectTransform.lossyScale.x, 0, 0);
        }
        else if(this.transform.position.x<-this.GetComponent<Image>().rectTransform.lossyScale.x)
        {
            this.transform.position = new Vector3(Screen.width, this.transform.position.y, 0);
        }
        if(this.transform.position.y>=Screen.height)
        {
            this.transform.position = new Vector3(this.transform.position.x,-this.GetComponent<Image>().rectTransform.lossyScale.y, 0);
        }
        else if(this.transform.position.y<-this.GetComponent<Image>().rectTransform.lossyScale.y)
        {
            this.transform.position = new Vector3(this.transform.position.x, Screen.height, 0);
        }
    }
    void MoveTarget()
    {
        float x = Input.GetAxis("Horizontal")*100;
        float y = Input.GetAxis("Vertical")*100;

        target.transform.Translate(x*Time.deltaTime*moveSpeed,y*Time.deltaTime*moveSpeed,0);
        //如果超出屏幕范围则让它出现在另一面
        if (target.transform.position.x >= Screen.width)
        {
            //使用了Image的target.rectTransform.lossyScale.x来表示显示的图片宽度
            target.transform.position = new Vector3(-target.rectTransform.lossyScale.x, target.transform.position.y, 0);
        }
        else if(target.transform.position.x<-target.rectTransform.lossyScale.x)
        {
            target.transform.position = new Vector3(Screen.width, target.transform.position.y, 0);
        }
        if(target.transform.position.y>=Screen.height)
        {
            target.transform.position = new Vector3(target.transform.position.x, -target.rectTransform.lossyScale.y, 0);
        }
        else if(target.transform.position.y<-target.rectTransform.lossyScale.y)
        {
            target.transform.position = new Vector3(target.transform.position.x, Screen.height, 0);
        }
    }
}



阅读更多
换一批

没有更多推荐了,返回首页